mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-10-29 10:57:44 +09:00 
			
		
		
		
	* 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)
 | |
| }
 |