Платформа ЦРНП "Мирокод" для разработки проектов
https://git.mirocod.ru
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
300 lines
10 KiB
300 lines
10 KiB
// Copyright 2019 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 issue |
|
|
|
import ( |
|
"testing" |
|
|
|
"code.gitea.io/gitea/models" |
|
repo_model "code.gitea.io/gitea/models/repo" |
|
"code.gitea.io/gitea/models/unittest" |
|
user_model "code.gitea.io/gitea/models/user" |
|
"code.gitea.io/gitea/modules/repository" |
|
"code.gitea.io/gitea/modules/setting" |
|
|
|
"github.com/stretchr/testify/assert" |
|
) |
|
|
|
func TestUpdateIssuesCommit(t *testing.T) { |
|
assert.NoError(t, unittest.PrepareTestDatabase()) |
|
pushCommits := []*repository.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 := unittest.AssertExistsAndLoadBean(t, &user_model.User{ID: 2}).(*user_model.User) |
|
repo := unittest.AssertExistsAndLoadBean(t, &repo_model.Repository{ID: 1}).(*repo_model.Repository) |
|
repo.Owner = user |
|
|
|
commentBean := &models.Comment{ |
|
Type: models.CommentTypeCommitRef, |
|
CommitSHA: "abcdef1", |
|
PosterID: user.ID, |
|
IssueID: 1, |
|
} |
|
issueBean := &models.Issue{RepoID: repo.ID, Index: 4} |
|
|
|
unittest.AssertNotExistsBean(t, commentBean) |
|
unittest.AssertNotExistsBean(t, &models.Issue{RepoID: repo.ID, Index: 2}, "is_closed=1") |
|
assert.NoError(t, UpdateIssuesCommit(user, repo, pushCommits, repo.DefaultBranch)) |
|
unittest.AssertExistsAndLoadBean(t, commentBean) |
|
unittest.AssertExistsAndLoadBean(t, issueBean, "is_closed=1") |
|
unittest.CheckConsistencyFor(t, &models.Action{}) |
|
|
|
// Test that push to a non-default branch closes no issue. |
|
pushCommits = []*repository.PushCommit{ |
|
{ |
|
Sha1: "abcdef1", |
|
CommitterEmail: "user2@example.com", |
|
CommitterName: "User Two", |
|
AuthorEmail: "user4@example.com", |
|
AuthorName: "User Four", |
|
Message: "close #1", |
|
}, |
|
} |
|
repo = unittest.AssertExistsAndLoadBean(t, &repo_model.Repository{ID: 3}).(*repo_model.Repository) |
|
commentBean = &models.Comment{ |
|
Type: models.CommentTypeCommitRef, |
|
CommitSHA: "abcdef1", |
|
PosterID: user.ID, |
|
IssueID: 6, |
|
} |
|
issueBean = &models.Issue{RepoID: repo.ID, Index: 1} |
|
|
|
unittest.AssertNotExistsBean(t, commentBean) |
|
unittest.AssertNotExistsBean(t, &models.Issue{RepoID: repo.ID, Index: 1}, "is_closed=1") |
|
assert.NoError(t, UpdateIssuesCommit(user, repo, pushCommits, "non-existing-branch")) |
|
unittest.AssertExistsAndLoadBean(t, commentBean) |
|
unittest.AssertNotExistsBean(t, issueBean, "is_closed=1") |
|
unittest.CheckConsistencyFor(t, &models.Action{}) |
|
|
|
pushCommits = []*repository.PushCommit{ |
|
{ |
|
Sha1: "abcdef3", |
|
CommitterEmail: "user2@example.com", |
|
CommitterName: "User Two", |
|
AuthorEmail: "user2@example.com", |
|
AuthorName: "User Two", |
|
Message: "close " + setting.AppURL + repo.FullName() + "/pulls/1", |
|
}, |
|
} |
|
repo = unittest.AssertExistsAndLoadBean(t, &repo_model.Repository{ID: 3}).(*repo_model.Repository) |
|
commentBean = &models.Comment{ |
|
Type: models.CommentTypeCommitRef, |
|
CommitSHA: "abcdef3", |
|
PosterID: user.ID, |
|
IssueID: 6, |
|
} |
|
issueBean = &models.Issue{RepoID: repo.ID, Index: 1} |
|
|
|
unittest.AssertNotExistsBean(t, commentBean) |
|
unittest.AssertNotExistsBean(t, &models.Issue{RepoID: repo.ID, Index: 1}, "is_closed=1") |
|
assert.NoError(t, UpdateIssuesCommit(user, repo, pushCommits, repo.DefaultBranch)) |
|
unittest.AssertExistsAndLoadBean(t, commentBean) |
|
unittest.AssertExistsAndLoadBean(t, issueBean, "is_closed=1") |
|
unittest.CheckConsistencyFor(t, &models.Action{}) |
|
} |
|
|
|
func TestUpdateIssuesCommit_Colon(t *testing.T) { |
|
assert.NoError(t, unittest.PrepareTestDatabase()) |
|
pushCommits := []*repository.PushCommit{ |
|
{ |
|
Sha1: "abcdef2", |
|
CommitterEmail: "user2@example.com", |
|
CommitterName: "User Two", |
|
AuthorEmail: "user2@example.com", |
|
AuthorName: "User Two", |
|
Message: "close: #2", |
|
}, |
|
} |
|
|
|
user := unittest.AssertExistsAndLoadBean(t, &user_model.User{ID: 2}).(*user_model.User) |
|
repo := unittest.AssertExistsAndLoadBean(t, &repo_model.Repository{ID: 1}).(*repo_model.Repository) |
|
repo.Owner = user |
|
|
|
issueBean := &models.Issue{RepoID: repo.ID, Index: 4} |
|
|
|
unittest.AssertNotExistsBean(t, &models.Issue{RepoID: repo.ID, Index: 2}, "is_closed=1") |
|
assert.NoError(t, UpdateIssuesCommit(user, repo, pushCommits, repo.DefaultBranch)) |
|
unittest.AssertExistsAndLoadBean(t, issueBean, "is_closed=1") |
|
unittest.CheckConsistencyFor(t, &models.Action{}) |
|
} |
|
|
|
func TestUpdateIssuesCommit_Issue5957(t *testing.T) { |
|
assert.NoError(t, unittest.PrepareTestDatabase()) |
|
user := unittest.AssertExistsAndLoadBean(t, &user_model.User{ID: 2}).(*user_model.User) |
|
|
|
// Test that push to a non-default branch closes an issue. |
|
pushCommits := []*repository.PushCommit{ |
|
{ |
|
Sha1: "abcdef1", |
|
CommitterEmail: "user2@example.com", |
|
CommitterName: "User Two", |
|
AuthorEmail: "user4@example.com", |
|
AuthorName: "User Four", |
|
Message: "close #2", |
|
}, |
|
} |
|
|
|
repo := unittest.AssertExistsAndLoadBean(t, &repo_model.Repository{ID: 2}).(*repo_model.Repository) |
|
commentBean := &models.Comment{ |
|
Type: models.CommentTypeCommitRef, |
|
CommitSHA: "abcdef1", |
|
PosterID: user.ID, |
|
IssueID: 7, |
|
} |
|
|
|
issueBean := &models.Issue{RepoID: repo.ID, Index: 2, ID: 7} |
|
|
|
unittest.AssertNotExistsBean(t, commentBean) |
|
unittest.AssertNotExistsBean(t, issueBean, "is_closed=1") |
|
assert.NoError(t, UpdateIssuesCommit(user, repo, pushCommits, "non-existing-branch")) |
|
unittest.AssertExistsAndLoadBean(t, commentBean) |
|
unittest.AssertExistsAndLoadBean(t, issueBean, "is_closed=1") |
|
unittest.CheckConsistencyFor(t, &models.Action{}) |
|
} |
|
|
|
func TestUpdateIssuesCommit_AnotherRepo(t *testing.T) { |
|
assert.NoError(t, unittest.PrepareTestDatabase()) |
|
user := unittest.AssertExistsAndLoadBean(t, &user_model.User{ID: 2}).(*user_model.User) |
|
|
|
// Test that a push to default branch closes issue in another repo |
|
// If the user also has push permissions to that repo |
|
pushCommits := []*repository.PushCommit{ |
|
{ |
|
Sha1: "abcdef1", |
|
CommitterEmail: "user2@example.com", |
|
CommitterName: "User Two", |
|
AuthorEmail: "user2@example.com", |
|
AuthorName: "User Two", |
|
Message: "close user2/repo1#1", |
|
}, |
|
} |
|
|
|
repo := unittest.AssertExistsAndLoadBean(t, &repo_model.Repository{ID: 2}).(*repo_model.Repository) |
|
commentBean := &models.Comment{ |
|
Type: models.CommentTypeCommitRef, |
|
CommitSHA: "abcdef1", |
|
PosterID: user.ID, |
|
IssueID: 1, |
|
} |
|
|
|
issueBean := &models.Issue{RepoID: 1, Index: 1, ID: 1} |
|
|
|
unittest.AssertNotExistsBean(t, commentBean) |
|
unittest.AssertNotExistsBean(t, issueBean, "is_closed=1") |
|
assert.NoError(t, UpdateIssuesCommit(user, repo, pushCommits, repo.DefaultBranch)) |
|
unittest.AssertExistsAndLoadBean(t, commentBean) |
|
unittest.AssertExistsAndLoadBean(t, issueBean, "is_closed=1") |
|
unittest.CheckConsistencyFor(t, &models.Action{}) |
|
} |
|
|
|
func TestUpdateIssuesCommit_AnotherRepo_FullAddress(t *testing.T) { |
|
assert.NoError(t, unittest.PrepareTestDatabase()) |
|
user := unittest.AssertExistsAndLoadBean(t, &user_model.User{ID: 2}).(*user_model.User) |
|
|
|
// Test that a push to default branch closes issue in another repo |
|
// If the user also has push permissions to that repo |
|
pushCommits := []*repository.PushCommit{ |
|
{ |
|
Sha1: "abcdef1", |
|
CommitterEmail: "user2@example.com", |
|
CommitterName: "User Two", |
|
AuthorEmail: "user2@example.com", |
|
AuthorName: "User Two", |
|
Message: "close " + setting.AppURL + "user2/repo1/issues/1", |
|
}, |
|
} |
|
|
|
repo := unittest.AssertExistsAndLoadBean(t, &repo_model.Repository{ID: 2}).(*repo_model.Repository) |
|
commentBean := &models.Comment{ |
|
Type: models.CommentTypeCommitRef, |
|
CommitSHA: "abcdef1", |
|
PosterID: user.ID, |
|
IssueID: 1, |
|
} |
|
|
|
issueBean := &models.Issue{RepoID: 1, Index: 1, ID: 1} |
|
|
|
unittest.AssertNotExistsBean(t, commentBean) |
|
unittest.AssertNotExistsBean(t, issueBean, "is_closed=1") |
|
assert.NoError(t, UpdateIssuesCommit(user, repo, pushCommits, repo.DefaultBranch)) |
|
unittest.AssertExistsAndLoadBean(t, commentBean) |
|
unittest.AssertExistsAndLoadBean(t, issueBean, "is_closed=1") |
|
unittest.CheckConsistencyFor(t, &models.Action{}) |
|
} |
|
|
|
func TestUpdateIssuesCommit_AnotherRepoNoPermission(t *testing.T) { |
|
assert.NoError(t, unittest.PrepareTestDatabase()) |
|
user := unittest.AssertExistsAndLoadBean(t, &user_model.User{ID: 10}).(*user_model.User) |
|
|
|
// Test that a push with close reference *can not* close issue |
|
// If the committer doesn't have push rights in that repo |
|
pushCommits := []*repository.PushCommit{ |
|
{ |
|
Sha1: "abcdef3", |
|
CommitterEmail: "user10@example.com", |
|
CommitterName: "User Ten", |
|
AuthorEmail: "user10@example.com", |
|
AuthorName: "User Ten", |
|
Message: "close user3/repo3#1", |
|
}, |
|
{ |
|
Sha1: "abcdef4", |
|
CommitterEmail: "user10@example.com", |
|
CommitterName: "User Ten", |
|
AuthorEmail: "user10@example.com", |
|
AuthorName: "User Ten", |
|
Message: "close " + setting.AppURL + "user3/repo3/issues/1", |
|
}, |
|
} |
|
|
|
repo := unittest.AssertExistsAndLoadBean(t, &repo_model.Repository{ID: 6}).(*repo_model.Repository) |
|
commentBean := &models.Comment{ |
|
Type: models.CommentTypeCommitRef, |
|
CommitSHA: "abcdef3", |
|
PosterID: user.ID, |
|
IssueID: 6, |
|
} |
|
commentBean2 := &models.Comment{ |
|
Type: models.CommentTypeCommitRef, |
|
CommitSHA: "abcdef4", |
|
PosterID: user.ID, |
|
IssueID: 6, |
|
} |
|
|
|
issueBean := &models.Issue{RepoID: 3, Index: 1, ID: 6} |
|
|
|
unittest.AssertNotExistsBean(t, commentBean) |
|
unittest.AssertNotExistsBean(t, commentBean2) |
|
unittest.AssertNotExistsBean(t, issueBean, "is_closed=1") |
|
assert.NoError(t, UpdateIssuesCommit(user, repo, pushCommits, repo.DefaultBranch)) |
|
unittest.AssertNotExistsBean(t, commentBean) |
|
unittest.AssertNotExistsBean(t, commentBean2) |
|
unittest.AssertNotExistsBean(t, issueBean, "is_closed=1") |
|
unittest.CheckConsistencyFor(t, &models.Action{}) |
|
}
|
|
|