mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-10-29 10:57:44 +09:00 
			
		
		
		
	* reject reactions wich ar not allowed
* dont duble check CreateReaction now throw ErrForbiddenIssueReaction
* add /repos/{owner}/{repo}/issues/comments/{id}/reactions endpoint
* add Find Functions
* fix some swagger stuff + add issue reaction endpoints + GET ReactionList now use FindReactions...
* explicite Issue Only Reaction for FindReactionsOptions with "-1" commentID
* load issue; load user ...
* return error again
* swagger def canged after LINT
* check if user has ben loaded
* add Tests
* better way of comparing results
* add suggestion
* use different issue for test
(dont interfear with integration test)
* test dont compare Location on timeCompare
* TEST: add forbidden dubble add
* add comments in code to explain
* add settings.UI.ReactionsMap
so if !setting.UI.ReactionsMap[opts.Type] works
		
	
		
			
				
	
	
		
			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()
 | |
| 
 | |
| 	issue := AssertExistsAndLoadBean(t, &Issue{ID: 2}).(*Issue)
 | |
| 
 | |
| 	addReaction(t, user1, issue, nil, "heart")
 | |
| 	addReaction(t, user2, issue, nil, "heart")
 | |
| 	addReaction(t, user3, issue, nil, "heart")
 | |
| 	addReaction(t, user3, issue, nil, "+1")
 | |
| 	addReaction(t, user4, issue, nil, "+1")
 | |
| 	addReaction(t, user4, issue, nil, "heart")
 | |
| 	addReaction(t, ghost, issue, nil, "-1")
 | |
| 
 | |
| 	err := issue.loadReactions(x)
 | |
| 	assert.NoError(t, err)
 | |
| 
 | |
| 	assert.Len(t, issue.Reactions, 7)
 | |
| 
 | |
| 	reactions := issue.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})
 | |
| }
 |