mirror of
				https://github.com/go-gitea/gitea
				synced 2025-10-26 17:08:25 +00:00 
			
		
		
		
	* Ensure valid git author names passed in signatures Fix #5772 - Git author names are not allowed to include `\n` `<` or `>` and must not be empty. Ensure that the name passed in a signature is valid. * Account for pathologically named external users LDAP and the like usernames are not checked in the same way that users who signup are. Therefore just ensure that user names are also git safe and if totally pathological - Set them to "user-$UID" * Add Tests and adjust test users Make our testcases a little more pathological so that we be sure that integration tests have a chance to spot these cases. Signed-off-by: Andrew Thornton <art27@cantab.net>
		
			
				
	
	
		
			167 lines
		
	
	
		
			5.1 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			167 lines
		
	
	
		
			5.1 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| // Copyright 2017 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 models
 | |
| 
 | |
| import (
 | |
| 	"testing"
 | |
| 
 | |
| 	"code.gitea.io/gitea/modules/setting"
 | |
| 
 | |
| 	"github.com/stretchr/testify/assert"
 | |
| )
 | |
| 
 | |
| func addReaction(t *testing.T, doer *User, issue *Issue, comment *Comment, content string) {
 | |
| 	var reaction *Reaction
 | |
| 	var err error
 | |
| 	if comment == nil {
 | |
| 		reaction, err = CreateIssueReaction(doer, issue, content)
 | |
| 	} else {
 | |
| 		reaction, err = CreateCommentReaction(doer, issue, comment, content)
 | |
| 	}
 | |
| 	assert.NoError(t, err)
 | |
| 	assert.NotNil(t, reaction)
 | |
| }
 | |
| 
 | |
| func TestIssueAddReaction(t *testing.T) {
 | |
| 	assert.NoError(t, PrepareTestDatabase())
 | |
| 
 | |
| 	user1 := AssertExistsAndLoadBean(t, &User{ID: 1}).(*User)
 | |
| 
 | |
| 	issue1 := AssertExistsAndLoadBean(t, &Issue{ID: 1}).(*Issue)
 | |
| 
 | |
| 	addReaction(t, user1, issue1, nil, "heart")
 | |
| 
 | |
| 	AssertExistsAndLoadBean(t, &Reaction{Type: "heart", UserID: user1.ID, IssueID: issue1.ID})
 | |
| }
 | |
| 
 | |
| func TestIssueAddDuplicateReaction(t *testing.T) {
 | |
| 	assert.NoError(t, PrepareTestDatabase())
 | |
| 
 | |
| 	user1 := AssertExistsAndLoadBean(t, &User{ID: 1}).(*User)
 | |
| 
 | |
| 	issue1 := AssertExistsAndLoadBean(t, &Issue{ID: 1}).(*Issue)
 | |
| 
 | |
| 	addReaction(t, user1, issue1, nil, "heart")
 | |
| 
 | |
| 	reaction, err := CreateReaction(&ReactionOptions{
 | |
| 		Doer:  user1,
 | |
| 		Issue: issue1,
 | |
| 		Type:  "heart",
 | |
| 	})
 | |
| 	assert.Error(t, err)
 | |
| 	assert.Nil(t, reaction)
 | |
| 
 | |
| 	AssertExistsAndLoadBean(t, &Reaction{Type: "heart", UserID: user1.ID, IssueID: issue1.ID})
 | |
| }
 | |
| 
 | |
| func TestIssueDeleteReaction(t *testing.T) {
 | |
| 	assert.NoError(t, PrepareTestDatabase())
 | |
| 
 | |
| 	user1 := AssertExistsAndLoadBean(t, &User{ID: 1}).(*User)
 | |
| 
 | |
| 	issue1 := AssertExistsAndLoadBean(t, &Issue{ID: 1}).(*Issue)
 | |
| 
 | |
| 	addReaction(t, user1, issue1, nil, "heart")
 | |
| 
 | |
| 	err := DeleteIssueReaction(user1, issue1, "heart")
 | |
| 	assert.NoError(t, err)
 | |
| 
 | |
| 	AssertNotExistsBean(t, &Reaction{Type: "heart", UserID: user1.ID, IssueID: issue1.ID})
 | |
| }
 | |
| 
 | |
| func TestIssueReactionCount(t *testing.T) {
 | |
| 	assert.NoError(t, PrepareTestDatabase())
 | |
| 
 | |
| 	setting.UI.ReactionMaxUserNum = 2
 | |
| 
 | |
| 	user1 := AssertExistsAndLoadBean(t, &User{ID: 1}).(*User)
 | |
| 	user2 := AssertExistsAndLoadBean(t, &User{ID: 2}).(*User)
 | |
| 	user3 := AssertExistsAndLoadBean(t, &User{ID: 3}).(*User)
 | |
| 	user4 := AssertExistsAndLoadBean(t, &User{ID: 4}).(*User)
 | |
| 	ghost := NewGhostUser()
 | |
| 
 | |
| 	issue1 := AssertExistsAndLoadBean(t, &Issue{ID: 1}).(*Issue)
 | |
| 
 | |
| 	addReaction(t, user1, issue1, nil, "heart")
 | |
| 	addReaction(t, user2, issue1, nil, "heart")
 | |
| 	addReaction(t, user3, issue1, nil, "heart")
 | |
| 	addReaction(t, user3, issue1, nil, "+1")
 | |
| 	addReaction(t, user4, issue1, nil, "+1")
 | |
| 	addReaction(t, user4, issue1, nil, "heart")
 | |
| 	addReaction(t, ghost, issue1, nil, "-1")
 | |
| 
 | |
| 	err := issue1.loadReactions(x)
 | |
| 	assert.NoError(t, err)
 | |
| 
 | |
| 	assert.Len(t, issue1.Reactions, 7)
 | |
| 
 | |
| 	reactions := issue1.Reactions.GroupByType()
 | |
| 	assert.Len(t, reactions["heart"], 4)
 | |
| 	assert.Equal(t, 2, reactions["heart"].GetMoreUserCount())
 | |
| 	assert.Equal(t, user1.DisplayName()+", "+user2.DisplayName(), reactions["heart"].GetFirstUsers())
 | |
| 	assert.True(t, reactions["heart"].HasUser(1))
 | |
| 	assert.False(t, reactions["heart"].HasUser(5))
 | |
| 	assert.False(t, reactions["heart"].HasUser(0))
 | |
| 	assert.Len(t, reactions["+1"], 2)
 | |
| 	assert.Equal(t, 0, reactions["+1"].GetMoreUserCount())
 | |
| 	assert.Len(t, reactions["-1"], 1)
 | |
| }
 | |
| 
 | |
| func TestIssueCommentAddReaction(t *testing.T) {
 | |
| 	assert.NoError(t, PrepareTestDatabase())
 | |
| 
 | |
| 	user1 := AssertExistsAndLoadBean(t, &User{ID: 1}).(*User)
 | |
| 
 | |
| 	issue1 := AssertExistsAndLoadBean(t, &Issue{ID: 1}).(*Issue)
 | |
| 
 | |
| 	comment1 := AssertExistsAndLoadBean(t, &Comment{ID: 1}).(*Comment)
 | |
| 
 | |
| 	addReaction(t, user1, issue1, comment1, "heart")
 | |
| 
 | |
| 	AssertExistsAndLoadBean(t, &Reaction{Type: "heart", UserID: user1.ID, IssueID: issue1.ID, CommentID: comment1.ID})
 | |
| }
 | |
| 
 | |
| func TestIssueCommentDeleteReaction(t *testing.T) {
 | |
| 	assert.NoError(t, PrepareTestDatabase())
 | |
| 
 | |
| 	user1 := AssertExistsAndLoadBean(t, &User{ID: 1}).(*User)
 | |
| 	user2 := AssertExistsAndLoadBean(t, &User{ID: 2}).(*User)
 | |
| 	user3 := AssertExistsAndLoadBean(t, &User{ID: 3}).(*User)
 | |
| 	user4 := AssertExistsAndLoadBean(t, &User{ID: 4}).(*User)
 | |
| 	ghost := NewGhostUser()
 | |
| 
 | |
| 	issue1 := AssertExistsAndLoadBean(t, &Issue{ID: 1}).(*Issue)
 | |
| 
 | |
| 	comment1 := AssertExistsAndLoadBean(t, &Comment{ID: 1}).(*Comment)
 | |
| 
 | |
| 	addReaction(t, user1, issue1, comment1, "heart")
 | |
| 	addReaction(t, user2, issue1, comment1, "heart")
 | |
| 	addReaction(t, user3, issue1, comment1, "heart")
 | |
| 	addReaction(t, user4, issue1, comment1, "+1")
 | |
| 	addReaction(t, ghost, issue1, comment1, "heart")
 | |
| 
 | |
| 	err := comment1.LoadReactions()
 | |
| 	assert.NoError(t, err)
 | |
| 	assert.Len(t, comment1.Reactions, 5)
 | |
| 
 | |
| 	reactions := comment1.Reactions.GroupByType()
 | |
| 	assert.Len(t, reactions["heart"], 4)
 | |
| 	assert.Len(t, reactions["+1"], 1)
 | |
| }
 | |
| 
 | |
| func TestIssueCommentReactionCount(t *testing.T) {
 | |
| 	assert.NoError(t, PrepareTestDatabase())
 | |
| 
 | |
| 	user1 := AssertExistsAndLoadBean(t, &User{ID: 1}).(*User)
 | |
| 
 | |
| 	issue1 := AssertExistsAndLoadBean(t, &Issue{ID: 1}).(*Issue)
 | |
| 
 | |
| 	comment1 := AssertExistsAndLoadBean(t, &Comment{ID: 1}).(*Comment)
 | |
| 
 | |
| 	addReaction(t, user1, issue1, comment1, "heart")
 | |
| 	DeleteCommentReaction(user1, issue1, comment1, "heart")
 | |
| 
 | |
| 	AssertNotExistsBean(t, &Reaction{Type: "heart", UserID: user1.ID, IssueID: issue1.ID, CommentID: comment1.ID})
 | |
| }
 |