mirror of
https://codeberg.org/forgejo/forgejo.git
synced 2024-11-30 00:01:24 +00:00
1f40933d38
* Add config option to hide issue events Adds a config option `HIDE_ISSUE_EVENTS` to hide most issue events (changed labels, milestones, projects...) on the issue detail page. If this is true, only the following events (comment types) are shown: * plain comments * closed/reopned/merged * reviews * Make configurable using a list * Add docs * Add missing newline * Fix merge issues * Allow changes per user settings * Fix lint * Rm old docs * Apply suggestions from code review * Use bitsets * Rm comment * fmt * Fix lint * Use variable/constant to provide key * fmt * fix lint * refactor * Add a prefix for user setting key * Add license comment * Add license comment * Update services/forms/user_form_hidden_comments.go Co-authored-by: Gusted <williamzijl7@hotmail.com> * check len == 0 Co-authored-by: wxiaoguang <wxiaoguang@gmail.com> Co-authored-by: zeripath <art27@cantab.net> Co-authored-by: Gusted <williamzijl7@hotmail.com> Co-authored-by: 6543 <6543@obermui.de>
60 lines
1.8 KiB
Go
60 lines
1.8 KiB
Go
// Copyright 2021 The Gitea Authors. All rights reserved.
|
|
// Use of this source code is governed by a MIT-style
|
|
// license that can be found in the LICENSE file.
|
|
|
|
package user
|
|
|
|
import (
|
|
"testing"
|
|
|
|
"code.gitea.io/gitea/models/unittest"
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
)
|
|
|
|
func TestSettings(t *testing.T) {
|
|
keyName := "test_user_setting"
|
|
assert.NoError(t, unittest.PrepareTestDatabase())
|
|
|
|
newSetting := &Setting{UserID: 99, SettingKey: keyName, SettingValue: "Gitea User Setting Test"}
|
|
|
|
// create setting
|
|
err := SetUserSetting(newSetting.UserID, newSetting.SettingKey, newSetting.SettingValue)
|
|
assert.NoError(t, err)
|
|
// test about saving unchanged values
|
|
err = SetUserSetting(newSetting.UserID, newSetting.SettingKey, newSetting.SettingValue)
|
|
assert.NoError(t, err)
|
|
|
|
// get specific setting
|
|
settings, err := GetUserSettings(99, []string{keyName})
|
|
assert.NoError(t, err)
|
|
assert.Len(t, settings, 1)
|
|
assert.EqualValues(t, newSetting.SettingValue, settings[keyName].SettingValue)
|
|
|
|
settingValue, err := GetUserSetting(99, keyName)
|
|
assert.NoError(t, err)
|
|
assert.EqualValues(t, newSetting.SettingValue, settingValue)
|
|
|
|
settingValue, err = GetUserSetting(99, "no_such")
|
|
assert.NoError(t, err)
|
|
assert.EqualValues(t, "", settingValue)
|
|
|
|
// updated setting
|
|
updatedSetting := &Setting{UserID: 99, SettingKey: keyName, SettingValue: "Updated"}
|
|
err = SetUserSetting(updatedSetting.UserID, updatedSetting.SettingKey, updatedSetting.SettingValue)
|
|
assert.NoError(t, err)
|
|
|
|
// get all settings
|
|
settings, err = GetUserAllSettings(99)
|
|
assert.NoError(t, err)
|
|
assert.Len(t, settings, 1)
|
|
assert.EqualValues(t, updatedSetting.SettingValue, settings[updatedSetting.SettingKey].SettingValue)
|
|
|
|
// delete setting
|
|
err = DeleteUserSetting(99, keyName)
|
|
assert.NoError(t, err)
|
|
settings, err = GetUserAllSettings(99)
|
|
assert.NoError(t, err)
|
|
assert.Len(t, settings, 0)
|
|
}
|