mirror of
				https://gitee.com/gitea/gitea
				synced 2025-11-04 08:30:25 +08:00 
			
		
		
		
	Fix hidden commit status on multiple checks (#22889)
Since #22632, when a commit status has multiple checks, no check is shown at all (hence no way to see the other checks). This PR fixes this by always adding a tag with the `.commit-statuses-trigger` to the DOM (the `.vm` is for vertical alignment).  --------- Co-authored-by: Lunny Xiao <xiaolunwen@gmail.com>
This commit is contained in:
		@@ -630,8 +630,17 @@ func doAutoPRMerge(baseCtx *APITestContext, dstPath string) func(t *testing.T) {
 | 
			
		||||
 | 
			
		||||
		commitID := path.Base(commitURL)
 | 
			
		||||
 | 
			
		||||
		addCommitStatus := func(status api.CommitStatusState) func(*testing.T) {
 | 
			
		||||
			return doAPICreateCommitStatus(ctx, commitID, api.CreateStatusOption{
 | 
			
		||||
				State:       status,
 | 
			
		||||
				TargetURL:   "http://test.ci/",
 | 
			
		||||
				Description: "",
 | 
			
		||||
				Context:     "testci",
 | 
			
		||||
			})
 | 
			
		||||
		}
 | 
			
		||||
 | 
			
		||||
		// Call API to add Pending status for commit
 | 
			
		||||
		t.Run("CreateStatus", doAPICreateCommitStatus(ctx, commitID, api.CommitStatusPending))
 | 
			
		||||
		t.Run("CreateStatus", addCommitStatus(api.CommitStatusPending))
 | 
			
		||||
 | 
			
		||||
		// Cancel not existing auto merge
 | 
			
		||||
		ctx.ExpectedCode = http.StatusNotFound
 | 
			
		||||
@@ -660,7 +669,7 @@ func doAutoPRMerge(baseCtx *APITestContext, dstPath string) func(t *testing.T) {
 | 
			
		||||
		assert.False(t, pr.HasMerged)
 | 
			
		||||
 | 
			
		||||
		// Call API to add Failure status for commit
 | 
			
		||||
		t.Run("CreateStatus", doAPICreateCommitStatus(ctx, commitID, api.CommitStatusFailure))
 | 
			
		||||
		t.Run("CreateStatus", addCommitStatus(api.CommitStatusFailure))
 | 
			
		||||
 | 
			
		||||
		// Check pr status
 | 
			
		||||
		pr, err = doAPIGetPullRequest(ctx, baseCtx.Username, baseCtx.Reponame, pr.Index)(t)
 | 
			
		||||
@@ -668,7 +677,7 @@ func doAutoPRMerge(baseCtx *APITestContext, dstPath string) func(t *testing.T) {
 | 
			
		||||
		assert.False(t, pr.HasMerged)
 | 
			
		||||
 | 
			
		||||
		// Call API to add Success status for commit
 | 
			
		||||
		t.Run("CreateStatus", doAPICreateCommitStatus(ctx, commitID, api.CommitStatusSuccess))
 | 
			
		||||
		t.Run("CreateStatus", addCommitStatus(api.CommitStatusSuccess))
 | 
			
		||||
 | 
			
		||||
		// wait to let gitea merge stuff
 | 
			
		||||
		time.Sleep(time.Second)
 | 
			
		||||
 
 | 
			
		||||
@@ -70,7 +70,12 @@ func TestPullCreate_CommitStatus(t *testing.T) {
 | 
			
		||||
		for _, status := range statusList {
 | 
			
		||||
 | 
			
		||||
			// Call API to add status for commit
 | 
			
		||||
			t.Run("CreateStatus", doAPICreateCommitStatus(testCtx, commitID, status))
 | 
			
		||||
			t.Run("CreateStatus", doAPICreateCommitStatus(testCtx, commitID, api.CreateStatusOption{
 | 
			
		||||
				State:       status,
 | 
			
		||||
				TargetURL:   "http://test.ci/",
 | 
			
		||||
				Description: "",
 | 
			
		||||
				Context:     "testci",
 | 
			
		||||
			}))
 | 
			
		||||
 | 
			
		||||
			req = NewRequestf(t, "GET", "/user1/repo1/pulls/1/commits")
 | 
			
		||||
			resp = session.MakeRequest(t, req, http.StatusOK)
 | 
			
		||||
@@ -88,15 +93,13 @@ func TestPullCreate_CommitStatus(t *testing.T) {
 | 
			
		||||
	})
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func doAPICreateCommitStatus(ctx APITestContext, commitID string, status api.CommitStatusState) func(*testing.T) {
 | 
			
		||||
func doAPICreateCommitStatus(ctx APITestContext, commitID string, data api.CreateStatusOption) func(*testing.T) {
 | 
			
		||||
	return func(t *testing.T) {
 | 
			
		||||
		req := NewRequestWithJSON(t, http.MethodPost, fmt.Sprintf("/api/v1/repos/%s/%s/statuses/%s?token=%s", ctx.Username, ctx.Reponame, commitID, ctx.Token),
 | 
			
		||||
			api.CreateStatusOption{
 | 
			
		||||
				State:       status,
 | 
			
		||||
				TargetURL:   "http://test.ci/",
 | 
			
		||||
				Description: "",
 | 
			
		||||
				Context:     "testci",
 | 
			
		||||
			},
 | 
			
		||||
		req := NewRequestWithJSON(
 | 
			
		||||
			t,
 | 
			
		||||
			http.MethodPost,
 | 
			
		||||
			fmt.Sprintf("/api/v1/repos/%s/%s/statuses/%s?token=%s", ctx.Username, ctx.Reponame, commitID, ctx.Token),
 | 
			
		||||
			data,
 | 
			
		||||
		)
 | 
			
		||||
		if ctx.ExpectedCode != 0 {
 | 
			
		||||
			ctx.Session.MakeRequest(t, req, ctx.ExpectedCode)
 | 
			
		||||
 
 | 
			
		||||
@@ -52,14 +52,19 @@ func doTestRepoCommitWithStatus(t *testing.T, state string, classes ...string) {
 | 
			
		||||
 | 
			
		||||
	// Call API to add status for commit
 | 
			
		||||
	ctx := NewAPITestContext(t, "user2", "repo1", auth_model.AccessTokenScopeRepo)
 | 
			
		||||
	t.Run("CreateStatus", doAPICreateCommitStatus(ctx, path.Base(commitURL), api.CommitStatusState(state)))
 | 
			
		||||
	t.Run("CreateStatus", doAPICreateCommitStatus(ctx, path.Base(commitURL), api.CreateStatusOption{
 | 
			
		||||
		State:       api.CommitStatusState(state),
 | 
			
		||||
		TargetURL:   "http://test.ci/",
 | 
			
		||||
		Description: "",
 | 
			
		||||
		Context:     "testci",
 | 
			
		||||
	}))
 | 
			
		||||
 | 
			
		||||
	req = NewRequest(t, "GET", "/user2/repo1/commits/branch/master")
 | 
			
		||||
	resp = session.MakeRequest(t, req, http.StatusOK)
 | 
			
		||||
 | 
			
		||||
	doc = NewHTMLParser(t, resp.Body)
 | 
			
		||||
	// Check if commit status is displayed in message column
 | 
			
		||||
	sel := doc.doc.Find("#commits-table tbody tr td.message a.commit-statuses-trigger .commit-status")
 | 
			
		||||
	// Check if commit status is displayed in message column (.tippy-target to ignore the tippy trigger)
 | 
			
		||||
	sel := doc.doc.Find("#commits-table tbody tr td.message .tippy-target .commit-status")
 | 
			
		||||
	assert.Equal(t, 1, sel.Length())
 | 
			
		||||
	for _, class := range classes {
 | 
			
		||||
		assert.True(t, sel.HasClass(class))
 | 
			
		||||
@@ -145,7 +150,12 @@ func TestRepoCommitsStatusParallel(t *testing.T) {
 | 
			
		||||
		go func(parentT *testing.T, i int) {
 | 
			
		||||
			parentT.Run(fmt.Sprintf("ParallelCreateStatus_%d", i), func(t *testing.T) {
 | 
			
		||||
				ctx := NewAPITestContext(t, "user2", "repo1", auth_model.AccessTokenScopeRepoStatus)
 | 
			
		||||
				runBody := doAPICreateCommitStatus(ctx, path.Base(commitURL), api.CommitStatusState("pending"))
 | 
			
		||||
				runBody := doAPICreateCommitStatus(ctx, path.Base(commitURL), api.CreateStatusOption{
 | 
			
		||||
					State:       api.CommitStatusPending,
 | 
			
		||||
					TargetURL:   "http://test.ci/",
 | 
			
		||||
					Description: "",
 | 
			
		||||
					Context:     "testci",
 | 
			
		||||
				})
 | 
			
		||||
				runBody(t)
 | 
			
		||||
				wg.Done()
 | 
			
		||||
			})
 | 
			
		||||
@@ -153,3 +163,43 @@ func TestRepoCommitsStatusParallel(t *testing.T) {
 | 
			
		||||
	}
 | 
			
		||||
	wg.Wait()
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func TestRepoCommitsStatusMultiple(t *testing.T) {
 | 
			
		||||
	defer tests.PrepareTestEnv(t)()
 | 
			
		||||
 | 
			
		||||
	session := loginUser(t, "user2")
 | 
			
		||||
 | 
			
		||||
	// Request repository commits page
 | 
			
		||||
	req := NewRequest(t, "GET", "/user2/repo1/commits/branch/master")
 | 
			
		||||
	resp := session.MakeRequest(t, req, http.StatusOK)
 | 
			
		||||
 | 
			
		||||
	doc := NewHTMLParser(t, resp.Body)
 | 
			
		||||
	// Get first commit URL
 | 
			
		||||
	commitURL, exists := doc.doc.Find("#commits-table tbody tr td.sha a").Attr("href")
 | 
			
		||||
	assert.True(t, exists)
 | 
			
		||||
	assert.NotEmpty(t, commitURL)
 | 
			
		||||
 | 
			
		||||
	// Call API to add status for commit
 | 
			
		||||
	ctx := NewAPITestContext(t, "user2", "repo1", auth_model.AccessTokenScopeRepo)
 | 
			
		||||
	t.Run("CreateStatus", doAPICreateCommitStatus(ctx, path.Base(commitURL), api.CreateStatusOption{
 | 
			
		||||
		State:       api.CommitStatusSuccess,
 | 
			
		||||
		TargetURL:   "http://test.ci/",
 | 
			
		||||
		Description: "",
 | 
			
		||||
		Context:     "testci",
 | 
			
		||||
	}))
 | 
			
		||||
 | 
			
		||||
	t.Run("CreateStatus", doAPICreateCommitStatus(ctx, path.Base(commitURL), api.CreateStatusOption{
 | 
			
		||||
		State:       api.CommitStatusSuccess,
 | 
			
		||||
		TargetURL:   "http://test.ci/",
 | 
			
		||||
		Description: "",
 | 
			
		||||
		Context:     "other_context",
 | 
			
		||||
	}))
 | 
			
		||||
 | 
			
		||||
	req = NewRequest(t, "GET", "/user2/repo1/commits/branch/master")
 | 
			
		||||
	resp = session.MakeRequest(t, req, http.StatusOK)
 | 
			
		||||
 | 
			
		||||
	doc = NewHTMLParser(t, resp.Body)
 | 
			
		||||
	// Check that the data-tippy="commit-statuses" (for trigger) and commit-status (svg) are present
 | 
			
		||||
	sel := doc.doc.Find("#commits-table tbody tr td.message [data-tippy=\"commit-statuses\"] .commit-status")
 | 
			
		||||
	assert.Equal(t, 1, sel.Length())
 | 
			
		||||
}
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user