mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-10-27 00:23:41 +09:00 
			
		
		
		
	* fixes #5957 * add tests to make sure config option is respected * use already defined struct * - use migration to make the flag repo wide not for the entire gitea instance Also note that the config value can still be set so as to be able to control the value for new repositories that are to be created - fix copy/paste error in copyright header year and rearrange import - use repo config instead of server config value to determine if a commit should close an issue - update testsuite * use global config only when creating a new repository * allow repo admin toggle feature via UI * fix typo and improve testcase * fix fixtures * add DEFAULT prefix to config value * fix test
		
			
				
	
	
		
			516 lines
		
	
	
		
			14 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			516 lines
		
	
	
		
			14 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| package models
 | |
| 
 | |
| import (
 | |
| 	"fmt"
 | |
| 	"path"
 | |
| 	"strings"
 | |
| 	"testing"
 | |
| 
 | |
| 	"code.gitea.io/git"
 | |
| 	"code.gitea.io/gitea/modules/setting"
 | |
| 
 | |
| 	"github.com/stretchr/testify/assert"
 | |
| )
 | |
| 
 | |
| func TestAction_GetRepoPath(t *testing.T) {
 | |
| 	assert.NoError(t, PrepareTestDatabase())
 | |
| 	repo := AssertExistsAndLoadBean(t, &Repository{}).(*Repository)
 | |
| 	owner := AssertExistsAndLoadBean(t, &User{ID: repo.OwnerID}).(*User)
 | |
| 	action := &Action{RepoID: repo.ID}
 | |
| 	assert.Equal(t, path.Join(owner.Name, repo.Name), action.GetRepoPath())
 | |
| }
 | |
| 
 | |
| func TestAction_GetRepoLink(t *testing.T) {
 | |
| 	assert.NoError(t, PrepareTestDatabase())
 | |
| 	repo := AssertExistsAndLoadBean(t, &Repository{}).(*Repository)
 | |
| 	owner := AssertExistsAndLoadBean(t, &User{ID: repo.OwnerID}).(*User)
 | |
| 	action := &Action{RepoID: repo.ID}
 | |
| 	setting.AppSubURL = "/suburl/"
 | |
| 	expected := path.Join(setting.AppSubURL, owner.Name, repo.Name)
 | |
| 	assert.Equal(t, expected, action.GetRepoLink())
 | |
| }
 | |
| 
 | |
| func TestNewRepoAction(t *testing.T) {
 | |
| 	assert.NoError(t, PrepareTestDatabase())
 | |
| 
 | |
| 	user := AssertExistsAndLoadBean(t, &User{ID: 2}).(*User)
 | |
| 	repo := AssertExistsAndLoadBean(t, &Repository{OwnerID: user.ID}).(*Repository)
 | |
| 	repo.Owner = user
 | |
| 
 | |
| 	actionBean := &Action{
 | |
| 		OpType:    ActionCreateRepo,
 | |
| 		ActUserID: user.ID,
 | |
| 		RepoID:    repo.ID,
 | |
| 		ActUser:   user,
 | |
| 		Repo:      repo,
 | |
| 		IsPrivate: repo.IsPrivate,
 | |
| 	}
 | |
| 
 | |
| 	AssertNotExistsBean(t, actionBean)
 | |
| 	assert.NoError(t, NewRepoAction(user, repo))
 | |
| 	AssertExistsAndLoadBean(t, actionBean)
 | |
| 	CheckConsistencyFor(t, &Action{})
 | |
| }
 | |
| 
 | |
| func TestRenameRepoAction(t *testing.T) {
 | |
| 	assert.NoError(t, PrepareTestDatabase())
 | |
| 
 | |
| 	user := AssertExistsAndLoadBean(t, &User{ID: 2}).(*User)
 | |
| 	repo := AssertExistsAndLoadBean(t, &Repository{OwnerID: user.ID}).(*Repository)
 | |
| 	repo.Owner = user
 | |
| 
 | |
| 	oldRepoName := repo.Name
 | |
| 	const newRepoName = "newRepoName"
 | |
| 	repo.Name = newRepoName
 | |
| 	repo.LowerName = strings.ToLower(newRepoName)
 | |
| 
 | |
| 	actionBean := &Action{
 | |
| 		OpType:    ActionRenameRepo,
 | |
| 		ActUserID: user.ID,
 | |
| 		ActUser:   user,
 | |
| 		RepoID:    repo.ID,
 | |
| 		Repo:      repo,
 | |
| 		IsPrivate: repo.IsPrivate,
 | |
| 		Content:   oldRepoName,
 | |
| 	}
 | |
| 	AssertNotExistsBean(t, actionBean)
 | |
| 	assert.NoError(t, RenameRepoAction(user, oldRepoName, repo))
 | |
| 	AssertExistsAndLoadBean(t, actionBean)
 | |
| 
 | |
| 	_, err := x.ID(repo.ID).Cols("name", "lower_name").Update(repo)
 | |
| 	assert.NoError(t, err)
 | |
| 	CheckConsistencyFor(t, &Action{})
 | |
| }
 | |
| 
 | |
| func TestPushCommits_ToAPIPayloadCommits(t *testing.T) {
 | |
| 	pushCommits := NewPushCommits()
 | |
| 	pushCommits.Commits = []*PushCommit{
 | |
| 		{
 | |
| 			Sha1:           "abcdef1",
 | |
| 			CommitterEmail: "user2@example.com",
 | |
| 			CommitterName:  "User Two",
 | |
| 			AuthorEmail:    "user4@example.com",
 | |
| 			AuthorName:     "User Four",
 | |
| 			Message:        "message1",
 | |
| 		},
 | |
| 		{
 | |
| 			Sha1:           "abcdef2",
 | |
| 			CommitterEmail: "user2@example.com",
 | |
| 			CommitterName:  "User Two",
 | |
| 			AuthorEmail:    "user2@example.com",
 | |
| 			AuthorName:     "User Two",
 | |
| 			Message:        "message2",
 | |
| 		},
 | |
| 	}
 | |
| 	pushCommits.Len = len(pushCommits.Commits)
 | |
| 
 | |
| 	payloadCommits := pushCommits.ToAPIPayloadCommits("/username/reponame")
 | |
| 	if assert.Len(t, payloadCommits, 2) {
 | |
| 		assert.Equal(t, "abcdef1", payloadCommits[0].ID)
 | |
| 		assert.Equal(t, "message1", payloadCommits[0].Message)
 | |
| 		assert.Equal(t, "/username/reponame/commit/abcdef1", payloadCommits[0].URL)
 | |
| 		assert.Equal(t, "User Two", payloadCommits[0].Committer.Name)
 | |
| 		assert.Equal(t, "user2", payloadCommits[0].Committer.UserName)
 | |
| 		assert.Equal(t, "User Four", payloadCommits[0].Author.Name)
 | |
| 		assert.Equal(t, "user4", payloadCommits[0].Author.UserName)
 | |
| 
 | |
| 		assert.Equal(t, "abcdef2", payloadCommits[1].ID)
 | |
| 		assert.Equal(t, "message2", payloadCommits[1].Message)
 | |
| 		assert.Equal(t, "/username/reponame/commit/abcdef2", payloadCommits[1].URL)
 | |
| 		assert.Equal(t, "User Two", payloadCommits[1].Committer.Name)
 | |
| 		assert.Equal(t, "user2", payloadCommits[1].Committer.UserName)
 | |
| 		assert.Equal(t, "User Two", payloadCommits[1].Author.Name)
 | |
| 		assert.Equal(t, "user2", payloadCommits[1].Author.UserName)
 | |
| 	}
 | |
| }
 | |
| 
 | |
| func TestPushCommits_AvatarLink(t *testing.T) {
 | |
| 	pushCommits := NewPushCommits()
 | |
| 	pushCommits.Commits = []*PushCommit{
 | |
| 		{
 | |
| 			Sha1:           "abcdef1",
 | |
| 			CommitterEmail: "user2@example.com",
 | |
| 			CommitterName:  "User Two",
 | |
| 			AuthorEmail:    "user4@example.com",
 | |
| 			AuthorName:     "User Four",
 | |
| 			Message:        "message1",
 | |
| 		},
 | |
| 		{
 | |
| 			Sha1:           "abcdef2",
 | |
| 			CommitterEmail: "user2@example.com",
 | |
| 			CommitterName:  "User Two",
 | |
| 			AuthorEmail:    "user2@example.com",
 | |
| 			AuthorName:     "User Two",
 | |
| 			Message:        "message2",
 | |
| 		},
 | |
| 	}
 | |
| 	pushCommits.Len = len(pushCommits.Commits)
 | |
| 
 | |
| 	assert.Equal(t,
 | |
| 		"https://secure.gravatar.com/avatar/ab53a2911ddf9b4817ac01ddcd3d975f?d=identicon",
 | |
| 		pushCommits.AvatarLink("user2@example.com"))
 | |
| 
 | |
| 	assert.Equal(t,
 | |
| 		"https://secure.gravatar.com/avatar/19ade630b94e1e0535b3df7387434154?d=identicon",
 | |
| 		pushCommits.AvatarLink("nonexistent@example.com"))
 | |
| }
 | |
| 
 | |
| func Test_getIssueFromRef(t *testing.T) {
 | |
| 	assert.NoError(t, PrepareTestDatabase())
 | |
| 	repo := AssertExistsAndLoadBean(t, &Repository{ID: 1}).(*Repository)
 | |
| 	for _, test := range []struct {
 | |
| 		Ref             string
 | |
| 		ExpectedIssueID int64
 | |
| 	}{
 | |
| 		{"#2", 2},
 | |
| 		{"reopen #2", 2},
 | |
| 		{"user2/repo2#1", 4},
 | |
| 		{"fixes user2/repo2#1", 4},
 | |
| 	} {
 | |
| 		issue, err := getIssueFromRef(repo, test.Ref)
 | |
| 		assert.NoError(t, err)
 | |
| 		if assert.NotNil(t, issue) {
 | |
| 			assert.EqualValues(t, test.ExpectedIssueID, issue.ID)
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	for _, badRef := range []string{
 | |
| 		"doesnotexist/doesnotexist#1",
 | |
| 		fmt.Sprintf("#%d", NonexistentID),
 | |
| 	} {
 | |
| 		issue, err := getIssueFromRef(repo, badRef)
 | |
| 		assert.NoError(t, err)
 | |
| 		assert.Nil(t, issue)
 | |
| 	}
 | |
| }
 | |
| 
 | |
| func TestUpdateIssuesCommit(t *testing.T) {
 | |
| 	assert.NoError(t, PrepareTestDatabase())
 | |
| 	pushCommits := []*PushCommit{
 | |
| 		{
 | |
| 			Sha1:           "abcdef1",
 | |
| 			CommitterEmail: "user2@example.com",
 | |
| 			CommitterName:  "User Two",
 | |
| 			AuthorEmail:    "user4@example.com",
 | |
| 			AuthorName:     "User Four",
 | |
| 			Message:        "start working on #FST-1, #1",
 | |
| 		},
 | |
| 		{
 | |
| 			Sha1:           "abcdef2",
 | |
| 			CommitterEmail: "user2@example.com",
 | |
| 			CommitterName:  "User Two",
 | |
| 			AuthorEmail:    "user2@example.com",
 | |
| 			AuthorName:     "User Two",
 | |
| 			Message:        "a plain message",
 | |
| 		},
 | |
| 		{
 | |
| 			Sha1:           "abcdef2",
 | |
| 			CommitterEmail: "user2@example.com",
 | |
| 			CommitterName:  "User Two",
 | |
| 			AuthorEmail:    "user2@example.com",
 | |
| 			AuthorName:     "User Two",
 | |
| 			Message:        "close #2",
 | |
| 		},
 | |
| 	}
 | |
| 
 | |
| 	user := AssertExistsAndLoadBean(t, &User{ID: 2}).(*User)
 | |
| 	repo := AssertExistsAndLoadBean(t, &Repository{ID: 1}).(*Repository)
 | |
| 	repo.Owner = user
 | |
| 
 | |
| 	commentBean := &Comment{
 | |
| 		Type:      CommentTypeCommitRef,
 | |
| 		CommitSHA: "abcdef1",
 | |
| 		PosterID:  user.ID,
 | |
| 		IssueID:   1,
 | |
| 	}
 | |
| 	issueBean := &Issue{RepoID: repo.ID, Index: 2}
 | |
| 
 | |
| 	AssertNotExistsBean(t, commentBean)
 | |
| 	AssertNotExistsBean(t, &Issue{RepoID: repo.ID, Index: 2}, "is_closed=1")
 | |
| 	assert.NoError(t, UpdateIssuesCommit(user, repo, pushCommits, repo.DefaultBranch))
 | |
| 	AssertExistsAndLoadBean(t, commentBean)
 | |
| 	AssertExistsAndLoadBean(t, issueBean, "is_closed=1")
 | |
| 	CheckConsistencyFor(t, &Action{})
 | |
| 
 | |
| 	// Test that push to a non-default branch closes no issue.
 | |
| 	pushCommits = []*PushCommit{
 | |
| 		{
 | |
| 			Sha1:           "abcdef1",
 | |
| 			CommitterEmail: "user2@example.com",
 | |
| 			CommitterName:  "User Two",
 | |
| 			AuthorEmail:    "user4@example.com",
 | |
| 			AuthorName:     "User Four",
 | |
| 			Message:        "close #1",
 | |
| 		},
 | |
| 	}
 | |
| 	repo = AssertExistsAndLoadBean(t, &Repository{ID: 3}).(*Repository)
 | |
| 	commentBean = &Comment{
 | |
| 		Type:      CommentTypeCommitRef,
 | |
| 		CommitSHA: "abcdef1",
 | |
| 		PosterID:  user.ID,
 | |
| 		IssueID:   6,
 | |
| 	}
 | |
| 	issueBean = &Issue{RepoID: repo.ID, Index: 1}
 | |
| 
 | |
| 	AssertNotExistsBean(t, commentBean)
 | |
| 	AssertNotExistsBean(t, &Issue{RepoID: repo.ID, Index: 1}, "is_closed=1")
 | |
| 	assert.NoError(t, UpdateIssuesCommit(user, repo, pushCommits, "non-existing-branch"))
 | |
| 	AssertExistsAndLoadBean(t, commentBean)
 | |
| 	AssertNotExistsBean(t, issueBean, "is_closed=1")
 | |
| 	CheckConsistencyFor(t, &Action{})
 | |
| }
 | |
| 
 | |
| func TestUpdateIssuesCommit_Issue5957(t *testing.T) {
 | |
| 	assert.NoError(t, PrepareTestDatabase())
 | |
| 	user := AssertExistsAndLoadBean(t, &User{ID: 2}).(*User)
 | |
| 
 | |
| 	// Test that push to a non-default branch closes an issue.
 | |
| 	pushCommits := []*PushCommit{
 | |
| 		{
 | |
| 			Sha1:           "abcdef1",
 | |
| 			CommitterEmail: "user2@example.com",
 | |
| 			CommitterName:  "User Two",
 | |
| 			AuthorEmail:    "user4@example.com",
 | |
| 			AuthorName:     "User Four",
 | |
| 			Message:        "close #2",
 | |
| 		},
 | |
| 	}
 | |
| 
 | |
| 	repo := AssertExistsAndLoadBean(t, &Repository{ID: 2}).(*Repository)
 | |
| 	commentBean := &Comment{
 | |
| 		Type:      CommentTypeCommitRef,
 | |
| 		CommitSHA: "abcdef1",
 | |
| 		PosterID:  user.ID,
 | |
| 		IssueID:   7,
 | |
| 	}
 | |
| 
 | |
| 	issueBean := &Issue{RepoID: repo.ID, Index: 2, ID: 7}
 | |
| 
 | |
| 	AssertNotExistsBean(t, commentBean)
 | |
| 	AssertNotExistsBean(t, issueBean, "is_closed=1")
 | |
| 	assert.NoError(t, UpdateIssuesCommit(user, repo, pushCommits, "non-existing-branch"))
 | |
| 	AssertExistsAndLoadBean(t, commentBean)
 | |
| 	AssertExistsAndLoadBean(t, issueBean, "is_closed=1")
 | |
| 	CheckConsistencyFor(t, &Action{})
 | |
| }
 | |
| 
 | |
| func testCorrectRepoAction(t *testing.T, opts CommitRepoActionOptions, actionBean *Action) {
 | |
| 	AssertNotExistsBean(t, actionBean)
 | |
| 	assert.NoError(t, CommitRepoAction(opts))
 | |
| 	AssertExistsAndLoadBean(t, actionBean)
 | |
| 	CheckConsistencyFor(t, &Action{})
 | |
| }
 | |
| 
 | |
| func TestCommitRepoAction(t *testing.T) {
 | |
| 	samples := []struct {
 | |
| 		userID                  int64
 | |
| 		repositoryID            int64
 | |
| 		commitRepoActionOptions CommitRepoActionOptions
 | |
| 		action                  Action
 | |
| 	}{
 | |
| 		{
 | |
| 			userID:       2,
 | |
| 			repositoryID: 2,
 | |
| 			commitRepoActionOptions: CommitRepoActionOptions{
 | |
| 				RefFullName: "refName",
 | |
| 				OldCommitID: "oldCommitID",
 | |
| 				NewCommitID: "newCommitID",
 | |
| 				Commits: &PushCommits{
 | |
| 					avatars: make(map[string]string),
 | |
| 					Commits: []*PushCommit{
 | |
| 						{
 | |
| 							Sha1:           "abcdef1",
 | |
| 							CommitterEmail: "user2@example.com",
 | |
| 							CommitterName:  "User Two",
 | |
| 							AuthorEmail:    "user4@example.com",
 | |
| 							AuthorName:     "User Four",
 | |
| 							Message:        "message1",
 | |
| 						},
 | |
| 						{
 | |
| 							Sha1:           "abcdef2",
 | |
| 							CommitterEmail: "user2@example.com",
 | |
| 							CommitterName:  "User Two",
 | |
| 							AuthorEmail:    "user2@example.com",
 | |
| 							AuthorName:     "User Two",
 | |
| 							Message:        "message2",
 | |
| 						},
 | |
| 					},
 | |
| 					Len: 2,
 | |
| 				},
 | |
| 			},
 | |
| 			action: Action{
 | |
| 				OpType:  ActionCommitRepo,
 | |
| 				RefName: "refName",
 | |
| 			},
 | |
| 		},
 | |
| 		{
 | |
| 			userID:       2,
 | |
| 			repositoryID: 1,
 | |
| 			commitRepoActionOptions: CommitRepoActionOptions{
 | |
| 				RefFullName: git.TagPrefix + "v1.1",
 | |
| 				OldCommitID: git.EmptySHA,
 | |
| 				NewCommitID: "newCommitID",
 | |
| 				Commits:     &PushCommits{},
 | |
| 			},
 | |
| 			action: Action{
 | |
| 				OpType:  ActionPushTag,
 | |
| 				RefName: "v1.1",
 | |
| 			},
 | |
| 		},
 | |
| 		{
 | |
| 			userID:       2,
 | |
| 			repositoryID: 1,
 | |
| 			commitRepoActionOptions: CommitRepoActionOptions{
 | |
| 				RefFullName: git.TagPrefix + "v1.1",
 | |
| 				OldCommitID: "oldCommitID",
 | |
| 				NewCommitID: git.EmptySHA,
 | |
| 				Commits:     &PushCommits{},
 | |
| 			},
 | |
| 			action: Action{
 | |
| 				OpType:  ActionDeleteTag,
 | |
| 				RefName: "v1.1",
 | |
| 			},
 | |
| 		},
 | |
| 		{
 | |
| 			userID:       2,
 | |
| 			repositoryID: 1,
 | |
| 			commitRepoActionOptions: CommitRepoActionOptions{
 | |
| 				RefFullName: git.BranchPrefix + "feature/1",
 | |
| 				OldCommitID: "oldCommitID",
 | |
| 				NewCommitID: git.EmptySHA,
 | |
| 				Commits:     &PushCommits{},
 | |
| 			},
 | |
| 			action: Action{
 | |
| 				OpType:  ActionDeleteBranch,
 | |
| 				RefName: "feature/1",
 | |
| 			},
 | |
| 		},
 | |
| 	}
 | |
| 
 | |
| 	for _, s := range samples {
 | |
| 		PrepareTestEnv(t)
 | |
| 
 | |
| 		user := AssertExistsAndLoadBean(t, &User{ID: s.userID}).(*User)
 | |
| 		repo := AssertExistsAndLoadBean(t, &Repository{ID: s.repositoryID, OwnerID: user.ID}).(*Repository)
 | |
| 		repo.Owner = user
 | |
| 
 | |
| 		s.commitRepoActionOptions.PusherName = user.Name
 | |
| 		s.commitRepoActionOptions.RepoOwnerID = user.ID
 | |
| 		s.commitRepoActionOptions.RepoName = repo.Name
 | |
| 
 | |
| 		s.action.ActUserID = user.ID
 | |
| 		s.action.RepoID = repo.ID
 | |
| 		s.action.Repo = repo
 | |
| 		s.action.IsPrivate = repo.IsPrivate
 | |
| 
 | |
| 		testCorrectRepoAction(t, s.commitRepoActionOptions, &s.action)
 | |
| 	}
 | |
| }
 | |
| 
 | |
| func TestTransferRepoAction(t *testing.T) {
 | |
| 	assert.NoError(t, PrepareTestDatabase())
 | |
| 
 | |
| 	user2 := AssertExistsAndLoadBean(t, &User{ID: 2}).(*User)
 | |
| 	user4 := AssertExistsAndLoadBean(t, &User{ID: 4}).(*User)
 | |
| 	repo := AssertExistsAndLoadBean(t, &Repository{ID: 1, OwnerID: user2.ID}).(*Repository)
 | |
| 
 | |
| 	repo.OwnerID = user4.ID
 | |
| 	repo.Owner = user4
 | |
| 
 | |
| 	actionBean := &Action{
 | |
| 		OpType:    ActionTransferRepo,
 | |
| 		ActUserID: user2.ID,
 | |
| 		ActUser:   user2,
 | |
| 		RepoID:    repo.ID,
 | |
| 		Repo:      repo,
 | |
| 		IsPrivate: repo.IsPrivate,
 | |
| 	}
 | |
| 	AssertNotExistsBean(t, actionBean)
 | |
| 	assert.NoError(t, TransferRepoAction(user2, user2, repo))
 | |
| 	AssertExistsAndLoadBean(t, actionBean)
 | |
| 
 | |
| 	_, err := x.ID(repo.ID).Cols("owner_id").Update(repo)
 | |
| 	assert.NoError(t, err)
 | |
| 	CheckConsistencyFor(t, &Action{})
 | |
| }
 | |
| 
 | |
| func TestMergePullRequestAction(t *testing.T) {
 | |
| 	assert.NoError(t, PrepareTestDatabase())
 | |
| 	user := AssertExistsAndLoadBean(t, &User{ID: 2}).(*User)
 | |
| 	repo := AssertExistsAndLoadBean(t, &Repository{ID: 1, OwnerID: user.ID}).(*Repository)
 | |
| 	repo.Owner = user
 | |
| 	issue := AssertExistsAndLoadBean(t, &Issue{ID: 3, RepoID: repo.ID}).(*Issue)
 | |
| 
 | |
| 	actionBean := &Action{
 | |
| 		OpType:    ActionMergePullRequest,
 | |
| 		ActUserID: user.ID,
 | |
| 		ActUser:   user,
 | |
| 		RepoID:    repo.ID,
 | |
| 		Repo:      repo,
 | |
| 		IsPrivate: repo.IsPrivate,
 | |
| 	}
 | |
| 	AssertNotExistsBean(t, actionBean)
 | |
| 	assert.NoError(t, MergePullRequestAction(user, repo, issue))
 | |
| 	AssertExistsAndLoadBean(t, actionBean)
 | |
| 	CheckConsistencyFor(t, &Action{})
 | |
| }
 | |
| 
 | |
| func TestGetFeeds(t *testing.T) {
 | |
| 	// test with an individual user
 | |
| 	assert.NoError(t, PrepareTestDatabase())
 | |
| 	user := AssertExistsAndLoadBean(t, &User{ID: 2}).(*User)
 | |
| 
 | |
| 	actions, err := GetFeeds(GetFeedsOptions{
 | |
| 		RequestedUser:    user,
 | |
| 		RequestingUserID: user.ID,
 | |
| 		IncludePrivate:   true,
 | |
| 		OnlyPerformedBy:  false,
 | |
| 		IncludeDeleted:   true,
 | |
| 	})
 | |
| 	assert.NoError(t, err)
 | |
| 	if assert.Len(t, actions, 1) {
 | |
| 		assert.EqualValues(t, 1, actions[0].ID)
 | |
| 		assert.EqualValues(t, user.ID, actions[0].UserID)
 | |
| 	}
 | |
| 
 | |
| 	actions, err = GetFeeds(GetFeedsOptions{
 | |
| 		RequestedUser:    user,
 | |
| 		RequestingUserID: user.ID,
 | |
| 		IncludePrivate:   false,
 | |
| 		OnlyPerformedBy:  false,
 | |
| 	})
 | |
| 	assert.NoError(t, err)
 | |
| 	assert.Len(t, actions, 0)
 | |
| }
 | |
| 
 | |
| func TestGetFeeds2(t *testing.T) {
 | |
| 	// test with an organization user
 | |
| 	assert.NoError(t, PrepareTestDatabase())
 | |
| 	org := AssertExistsAndLoadBean(t, &User{ID: 3}).(*User)
 | |
| 	const userID = 2 // user2 is an owner of the organization
 | |
| 
 | |
| 	actions, err := GetFeeds(GetFeedsOptions{
 | |
| 		RequestedUser:    org,
 | |
| 		RequestingUserID: userID,
 | |
| 		IncludePrivate:   true,
 | |
| 		OnlyPerformedBy:  false,
 | |
| 		IncludeDeleted:   true,
 | |
| 	})
 | |
| 	assert.NoError(t, err)
 | |
| 	assert.Len(t, actions, 1)
 | |
| 	if assert.Len(t, actions, 1) {
 | |
| 		assert.EqualValues(t, 2, actions[0].ID)
 | |
| 		assert.EqualValues(t, org.ID, actions[0].UserID)
 | |
| 	}
 | |
| 
 | |
| 	actions, err = GetFeeds(GetFeedsOptions{
 | |
| 		RequestedUser:    org,
 | |
| 		RequestingUserID: userID,
 | |
| 		IncludePrivate:   false,
 | |
| 		OnlyPerformedBy:  false,
 | |
| 		IncludeDeleted:   true,
 | |
| 	})
 | |
| 	assert.NoError(t, err)
 | |
| 	assert.Len(t, actions, 0)
 | |
| }
 |