mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-10-27 00:23:41 +09:00 
			
		
		
		
	With the introduction of Actions, the pending commit icon has changed from yellow to grey for Drone integrations which never set the "running" status, so it stays in "pending" until completion. I find it better to have this icon colored like on 1.19. Now both the "pending" and "running" icons look the same, but I guess we could add an animation to the "running" state similar to GitHub has to it later. Before: <img width="339" alt="Screenshot 2023-07-17 at 19 14 19" src="https://github.com/go-gitea/gitea/assets/115237/2f4886e4-74fd-42ea-b59e-9af8f141bf1f"> After: <img width="335" alt="Screenshot 2023-07-17 at 19 14 30" src="https://github.com/go-gitea/gitea/assets/115237/53189642-e72d-47f6-9cbe-f14eda28f730"> Also, it matches GH's icon: <img width="466" alt="image" src="https://github.com/go-gitea/gitea/assets/115237/5804ff90-d223-4a3c-8093-7a9abbaacf87"> --------- Co-authored-by: delvh <dev.lh@web.de>
		
			
				
	
	
		
			210 lines
		
	
	
		
			7.4 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			210 lines
		
	
	
		
			7.4 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| // Copyright 2017 The Gitea Authors. All rights reserved.
 | |
| // SPDX-License-Identifier: MIT
 | |
| 
 | |
| package integration
 | |
| 
 | |
| import (
 | |
| 	"fmt"
 | |
| 	"net/http"
 | |
| 	"net/http/httptest"
 | |
| 	"path"
 | |
| 	"sync"
 | |
| 	"testing"
 | |
| 
 | |
| 	auth_model "code.gitea.io/gitea/models/auth"
 | |
| 	"code.gitea.io/gitea/modules/json"
 | |
| 	"code.gitea.io/gitea/modules/setting"
 | |
| 	api "code.gitea.io/gitea/modules/structs"
 | |
| 	"code.gitea.io/gitea/tests"
 | |
| 
 | |
| 	"github.com/stretchr/testify/assert"
 | |
| )
 | |
| 
 | |
| func TestRepoCommits(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)
 | |
| 	commitURL, exists := doc.doc.Find("#commits-table tbody tr td.sha a").Attr("href")
 | |
| 	assert.True(t, exists)
 | |
| 	assert.NotEmpty(t, commitURL)
 | |
| }
 | |
| 
 | |
| func doTestRepoCommitWithStatus(t *testing.T, state string, classes ...string) {
 | |
| 	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.AccessTokenScopeWriteRepository)
 | |
| 	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 (.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))
 | |
| 	}
 | |
| 
 | |
| 	// By SHA
 | |
| 	req = NewRequest(t, "GET", "/api/v1/repos/user2/repo1/commits/"+path.Base(commitURL)+"/statuses")
 | |
| 	reqOne := NewRequest(t, "GET", "/api/v1/repos/user2/repo1/commits/"+path.Base(commitURL)+"/status")
 | |
| 	testRepoCommitsWithStatus(t, session.MakeRequest(t, req, http.StatusOK), session.MakeRequest(t, reqOne, http.StatusOK), state)
 | |
| 
 | |
| 	// By short SHA
 | |
| 	req = NewRequest(t, "GET", "/api/v1/repos/user2/repo1/commits/"+path.Base(commitURL)[:10]+"/statuses")
 | |
| 	reqOne = NewRequest(t, "GET", "/api/v1/repos/user2/repo1/commits/"+path.Base(commitURL)[:10]+"/status")
 | |
| 	testRepoCommitsWithStatus(t, session.MakeRequest(t, req, http.StatusOK), session.MakeRequest(t, reqOne, http.StatusOK), state)
 | |
| 
 | |
| 	// By Ref
 | |
| 	req = NewRequest(t, "GET", "/api/v1/repos/user2/repo1/commits/master/statuses")
 | |
| 	reqOne = NewRequest(t, "GET", "/api/v1/repos/user2/repo1/commits/master/status")
 | |
| 	testRepoCommitsWithStatus(t, session.MakeRequest(t, req, http.StatusOK), session.MakeRequest(t, reqOne, http.StatusOK), state)
 | |
| 	req = NewRequest(t, "GET", "/api/v1/repos/user2/repo1/commits/v1.1/statuses")
 | |
| 	reqOne = NewRequest(t, "GET", "/api/v1/repos/user2/repo1/commits/v1.1/status")
 | |
| 	testRepoCommitsWithStatus(t, session.MakeRequest(t, req, http.StatusOK), session.MakeRequest(t, reqOne, http.StatusOK), state)
 | |
| }
 | |
| 
 | |
| func testRepoCommitsWithStatus(t *testing.T, resp, respOne *httptest.ResponseRecorder, state string) {
 | |
| 	var statuses []*api.CommitStatus
 | |
| 	assert.NoError(t, json.Unmarshal(resp.Body.Bytes(), &statuses))
 | |
| 	var status api.CombinedStatus
 | |
| 	assert.NoError(t, json.Unmarshal(respOne.Body.Bytes(), &status))
 | |
| 	assert.NotNil(t, status)
 | |
| 
 | |
| 	if assert.Len(t, statuses, 1) {
 | |
| 		assert.Equal(t, api.CommitStatusState(state), statuses[0].State)
 | |
| 		assert.Equal(t, setting.AppURL+"api/v1/repos/user2/repo1/statuses/65f1bf27bc3bf70f64657658635e66094edbcb4d", statuses[0].URL)
 | |
| 		assert.Equal(t, "http://test.ci/", statuses[0].TargetURL)
 | |
| 		assert.Equal(t, "", statuses[0].Description)
 | |
| 		assert.Equal(t, "testci", statuses[0].Context)
 | |
| 
 | |
| 		assert.Len(t, status.Statuses, 1)
 | |
| 		assert.Equal(t, statuses[0], status.Statuses[0])
 | |
| 		assert.Equal(t, "65f1bf27bc3bf70f64657658635e66094edbcb4d", status.SHA)
 | |
| 	}
 | |
| }
 | |
| 
 | |
| func TestRepoCommitsWithStatusPending(t *testing.T) {
 | |
| 	doTestRepoCommitWithStatus(t, "pending", "octicon-dot-fill", "yellow")
 | |
| }
 | |
| 
 | |
| func TestRepoCommitsWithStatusSuccess(t *testing.T) {
 | |
| 	doTestRepoCommitWithStatus(t, "success", "octicon-check", "green")
 | |
| }
 | |
| 
 | |
| func TestRepoCommitsWithStatusError(t *testing.T) {
 | |
| 	doTestRepoCommitWithStatus(t, "error", "gitea-exclamation", "red")
 | |
| }
 | |
| 
 | |
| func TestRepoCommitsWithStatusFailure(t *testing.T) {
 | |
| 	doTestRepoCommitWithStatus(t, "failure", "octicon-x", "red")
 | |
| }
 | |
| 
 | |
| func TestRepoCommitsWithStatusWarning(t *testing.T) {
 | |
| 	doTestRepoCommitWithStatus(t, "warning", "gitea-exclamation", "yellow")
 | |
| }
 | |
| 
 | |
| func TestRepoCommitsWithStatusRunning(t *testing.T) {
 | |
| 	doTestRepoCommitWithStatus(t, "running", "octicon-dot-fill", "yellow")
 | |
| }
 | |
| 
 | |
| func TestRepoCommitsStatusParallel(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)
 | |
| 
 | |
| 	var wg sync.WaitGroup
 | |
| 	for i := 0; i < 10; i++ {
 | |
| 		wg.Add(1)
 | |
| 		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.AccessTokenScopeWriteRepository)
 | |
| 				runBody := doAPICreateCommitStatus(ctx, path.Base(commitURL), api.CreateStatusOption{
 | |
| 					State:       api.CommitStatusPending,
 | |
| 					TargetURL:   "http://test.ci/",
 | |
| 					Description: "",
 | |
| 					Context:     "testci",
 | |
| 				})
 | |
| 				runBody(t)
 | |
| 				wg.Done()
 | |
| 			})
 | |
| 		}(t, i)
 | |
| 	}
 | |
| 	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.AccessTokenScopeWriteRepository)
 | |
| 	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())
 | |
| }
 |