aboutsummaryrefslogtreecommitdiffstats
path: root/tests/integration
diff options
context:
space:
mode:
authorLunny Xiao <xiaolunwen@gmail.com>2023-06-05 18:33:47 +0800
committerGitHub <noreply@github.com>2023-06-05 10:33:47 +0000
commit315124b4693dd56d94d52cda3015611184a49a27 (patch)
tree273ea4fcb2c1bff7409834477d2a7287c7580ce1 /tests/integration
parent3d1fda737bc36e80a670f856fd85f6b884872b73 (diff)
downloadgitea-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.go45
-rw-r--r--tests/integration/repo_commits_test.go4
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")