diff options
author | Lunny Xiao <xiaolunwen@gmail.com> | 2023-06-05 18:33:47 +0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2023-06-05 10:33:47 +0000 |
commit | 315124b4693dd56d94d52cda3015611184a49a27 (patch) | |
tree | 273ea4fcb2c1bff7409834477d2a7287c7580ce1 /tests/integration | |
parent | 3d1fda737bc36e80a670f856fd85f6b884872b73 (diff) | |
download | gitea-315124b4693dd56d94d52cda3015611184a49a27.tar.gz gitea-315124b4693dd56d94d52cda3015611184a49a27.zip |
Fix parallelly generating index failure with Mysql (#24567)
Diffstat (limited to 'tests/integration')
-rw-r--r-- | tests/integration/api_issue_test.go | 45 | ||||
-rw-r--r-- | tests/integration/repo_commits_test.go | 4 |
2 files changed, 45 insertions, 4 deletions
diff --git a/tests/integration/api_issue_test.go b/tests/integration/api_issue_test.go index 324f5ddbee..8b02342d88 100644 --- a/tests/integration/api_issue_test.go +++ b/tests/integration/api_issue_test.go @@ -7,6 +7,8 @@ import ( "fmt" "net/http" "net/url" + "strconv" + "sync" "testing" "time" @@ -106,6 +108,49 @@ func TestAPICreateIssue(t *testing.T) { assert.Equal(t, repoBefore.NumClosedIssues, repoAfter.NumClosedIssues) } +func TestAPICreateIssueParallel(t *testing.T) { + defer tests.PrepareTestEnv(t)() + const body, title = "apiTestBody", "apiTestTitle" + + repoBefore := unittest.AssertExistsAndLoadBean(t, &repo_model.Repository{ID: 1}) + owner := unittest.AssertExistsAndLoadBean(t, &user_model.User{ID: repoBefore.OwnerID}) + + session := loginUser(t, owner.Name) + token := getTokenForLoggedInUser(t, session, auth_model.AccessTokenScopeWriteIssue) + urlStr := fmt.Sprintf("/api/v1/repos/%s/%s/issues?state=all&token=%s", owner.Name, repoBefore.Name, token) + + var wg sync.WaitGroup + for i := 0; i < 10; i++ { + wg.Add(1) + go func(parentT *testing.T, i int) { + parentT.Run(fmt.Sprintf("ParallelCreateIssue_%d", i), func(t *testing.T) { + newTitle := title + strconv.Itoa(i) + newBody := body + strconv.Itoa(i) + req := NewRequestWithJSON(t, "POST", urlStr, &api.CreateIssueOption{ + Body: newBody, + Title: newTitle, + Assignee: owner.Name, + }) + resp := MakeRequest(t, req, http.StatusCreated) + var apiIssue api.Issue + DecodeJSON(t, resp, &apiIssue) + assert.Equal(t, newBody, apiIssue.Body) + assert.Equal(t, newTitle, apiIssue.Title) + + unittest.AssertExistsAndLoadBean(t, &issues_model.Issue{ + RepoID: repoBefore.ID, + AssigneeID: owner.ID, + Content: newBody, + Title: newTitle, + }) + + wg.Done() + }) + }(t, i) + } + wg.Wait() +} + func TestAPIEditIssue(t *testing.T) { defer tests.PrepareTestEnv(t)() diff --git a/tests/integration/repo_commits_test.go b/tests/integration/repo_commits_test.go index 99927f1929..5f580a0268 100644 --- a/tests/integration/repo_commits_test.go +++ b/tests/integration/repo_commits_test.go @@ -7,7 +7,6 @@ import ( "fmt" "net/http" "net/http/httptest" - "os" "path" "sync" "testing" @@ -135,9 +134,6 @@ func TestRepoCommitsWithStatusRunning(t *testing.T) { } func TestRepoCommitsStatusParallel(t *testing.T) { - if os.Getenv("CI") != "" { - t.Skip("Skipping because test is flaky on CI") - } defer tests.PrepareTestEnv(t)() session := loginUser(t, "user2") |