forked from Shiloh/githaven
dfd2db5695
Unfortunately, #22295 introduced a bug that when set a cached system setting, it will not affect. This PR make sure to remove the cache key when updating a system setting. Fix #22332
57 lines
1.6 KiB
Go
57 lines
1.6 KiB
Go
// Copyright 2021 The Gitea Authors. All rights reserved.
|
|
// SPDX-License-Identifier: MIT
|
|
|
|
package system_test
|
|
|
|
import (
|
|
"strings"
|
|
"testing"
|
|
|
|
"code.gitea.io/gitea/models/system"
|
|
"code.gitea.io/gitea/models/unittest"
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
)
|
|
|
|
func TestSettings(t *testing.T) {
|
|
keyName := "server.LFS_LOCKS_PAGING_NUM"
|
|
assert.NoError(t, unittest.PrepareTestDatabase())
|
|
|
|
newSetting := &system.Setting{SettingKey: keyName, SettingValue: "50"}
|
|
|
|
// create setting
|
|
err := system.SetSetting(newSetting)
|
|
assert.NoError(t, err)
|
|
// test about saving unchanged values
|
|
err = system.SetSetting(newSetting)
|
|
assert.NoError(t, err)
|
|
|
|
// get specific setting
|
|
settings, err := system.GetSettings([]string{keyName})
|
|
assert.NoError(t, err)
|
|
assert.Len(t, settings, 1)
|
|
assert.EqualValues(t, newSetting.SettingValue, settings[strings.ToLower(keyName)].SettingValue)
|
|
|
|
// updated setting
|
|
updatedSetting := &system.Setting{SettingKey: keyName, SettingValue: "100", Version: settings[strings.ToLower(keyName)].Version}
|
|
err = system.SetSetting(updatedSetting)
|
|
assert.NoError(t, err)
|
|
|
|
value, err := system.GetSetting(keyName)
|
|
assert.NoError(t, err)
|
|
assert.EqualValues(t, updatedSetting.SettingValue, value)
|
|
|
|
// get all settings
|
|
settings, err = system.GetAllSettings()
|
|
assert.NoError(t, err)
|
|
assert.Len(t, settings, 3)
|
|
assert.EqualValues(t, updatedSetting.SettingValue, settings[strings.ToLower(updatedSetting.SettingKey)].SettingValue)
|
|
|
|
// delete setting
|
|
err = system.DeleteSetting(&system.Setting{SettingKey: strings.ToLower(keyName)})
|
|
assert.NoError(t, err)
|
|
settings, err = system.GetAllSettings()
|
|
assert.NoError(t, err)
|
|
assert.Len(t, settings, 2)
|
|
}
|