mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-10-31 21:28:11 +09:00 
			
		
		
		
	Kd/ci playwright go test (#20123)
* Add initial playwright config * Simplify Makefile * Simplify Makefile * Use correct config files * Update playwright settings * Fix package-lock file * Don't use test logger for e2e tests * fix frontend lint * Allow passing TEST_LOGGER variable * Init postgres database * use standard gitea env variables * Update playwright * update drone * Move empty env var to commands * Cleanup * Move integrations to subfolder * tests integrations to tests integraton * Run e2e tests with go test * Fix linting * install CI deps * Add files to ESlint * Fix drone typo * Don't log to console in CI * Use go test http server * Add build step before tests * Move shared init function to common package * fix drone * Clean up tests * Fix linting * Better mocking for page + version string * Cleanup test generation * Remove dependency on gitea binary * Fix linting * add initial support for running specific tests * Add ACCEPT_VISUAL variable * don't require git-lfs * Add initial documentation * Review feedback * Add logged in session test * Attempt fixing drone race * Cleanup and bump version * Bump deps * Review feedback * simplify installation * Fix ci * Update install docs
This commit is contained in:
		
							
								
								
									
										157
									
								
								tests/integration/pull_status_test.go
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										157
									
								
								tests/integration/pull_status_test.go
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,157 @@ | ||||
| // 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 integration | ||||
|  | ||||
| import ( | ||||
| 	"fmt" | ||||
| 	"net/http" | ||||
| 	"net/url" | ||||
| 	"path" | ||||
| 	"strings" | ||||
| 	"testing" | ||||
|  | ||||
| 	api "code.gitea.io/gitea/modules/structs" | ||||
|  | ||||
| 	"github.com/stretchr/testify/assert" | ||||
| ) | ||||
|  | ||||
| func TestPullCreate_CommitStatus(t *testing.T) { | ||||
| 	onGiteaRun(t, func(t *testing.T, u *url.URL) { | ||||
| 		session := loginUser(t, "user1") | ||||
| 		testRepoFork(t, session, "user2", "repo1", "user1", "repo1") | ||||
| 		testEditFileToNewBranch(t, session, "user1", "repo1", "master", "status1", "README.md", "status1") | ||||
|  | ||||
| 		url := path.Join("user1", "repo1", "compare", "master...status1") | ||||
| 		req := NewRequestWithValues(t, "POST", url, | ||||
| 			map[string]string{ | ||||
| 				"_csrf": GetCSRF(t, session, url), | ||||
| 				"title": "pull request from status1", | ||||
| 			}, | ||||
| 		) | ||||
| 		session.MakeRequest(t, req, http.StatusSeeOther) | ||||
|  | ||||
| 		req = NewRequest(t, "GET", "/user1/repo1/pulls") | ||||
| 		resp := session.MakeRequest(t, req, http.StatusOK) | ||||
| 		NewHTMLParser(t, resp.Body) | ||||
|  | ||||
| 		// Request repository commits page | ||||
| 		req = NewRequest(t, "GET", "/user1/repo1/pulls/1/commits") | ||||
| 		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").Last().Attr("href") | ||||
| 		assert.True(t, exists) | ||||
| 		assert.NotEmpty(t, commitURL) | ||||
|  | ||||
| 		commitID := path.Base(commitURL) | ||||
|  | ||||
| 		statusList := []api.CommitStatusState{ | ||||
| 			api.CommitStatusPending, | ||||
| 			api.CommitStatusError, | ||||
| 			api.CommitStatusFailure, | ||||
| 			api.CommitStatusWarning, | ||||
| 			api.CommitStatusSuccess, | ||||
| 		} | ||||
|  | ||||
| 		statesIcons := map[api.CommitStatusState]string{ | ||||
| 			api.CommitStatusPending: "octicon-dot-fill", | ||||
| 			api.CommitStatusSuccess: "octicon-check", | ||||
| 			api.CommitStatusError:   "gitea-exclamation", | ||||
| 			api.CommitStatusFailure: "octicon-x", | ||||
| 			api.CommitStatusWarning: "gitea-exclamation", | ||||
| 		} | ||||
|  | ||||
| 		testCtx := NewAPITestContext(t, "user1", "repo1") | ||||
|  | ||||
| 		// Update commit status, and check if icon is updated as well | ||||
| 		for _, status := range statusList { | ||||
|  | ||||
| 			// Call API to add status for commit | ||||
| 			t.Run("CreateStatus", doAPICreateCommitStatus(testCtx, commitID, status)) | ||||
|  | ||||
| 			req = NewRequestf(t, "GET", "/user1/repo1/pulls/1/commits") | ||||
| 			resp = session.MakeRequest(t, req, http.StatusOK) | ||||
| 			doc = NewHTMLParser(t, resp.Body) | ||||
|  | ||||
| 			commitURL, exists = doc.doc.Find("#commits-table tbody tr td.sha a").Last().Attr("href") | ||||
| 			assert.True(t, exists) | ||||
| 			assert.NotEmpty(t, commitURL) | ||||
| 			assert.EqualValues(t, commitID, path.Base(commitURL)) | ||||
|  | ||||
| 			cls, ok := doc.doc.Find("#commits-table tbody tr td.message .commit-status").Last().Attr("class") | ||||
| 			assert.True(t, ok) | ||||
| 			assert.Contains(t, cls, statesIcons[status]) | ||||
| 		} | ||||
| 	}) | ||||
| } | ||||
|  | ||||
| func doAPICreateCommitStatus(ctx APITestContext, commitID string, status api.CommitStatusState) 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", | ||||
| 			}, | ||||
| 		) | ||||
| 		if ctx.ExpectedCode != 0 { | ||||
| 			ctx.Session.MakeRequest(t, req, ctx.ExpectedCode) | ||||
| 			return | ||||
| 		} | ||||
| 		ctx.Session.MakeRequest(t, req, http.StatusCreated) | ||||
| 	} | ||||
| } | ||||
|  | ||||
| func TestPullCreate_EmptyChangesWithDifferentCommits(t *testing.T) { | ||||
| 	// Merge must continue if commits SHA are different, even if content is same | ||||
| 	// Reason: gitflow and merging master back into develop, where is high possiblity, there are no changes | ||||
| 	// but just commit saying "Merge branch". And this meta commit can be also tagged, | ||||
| 	// so we need to have this meta commit also in develop branch. | ||||
| 	onGiteaRun(t, func(t *testing.T, u *url.URL) { | ||||
| 		session := loginUser(t, "user1") | ||||
| 		testRepoFork(t, session, "user2", "repo1", "user1", "repo1") | ||||
| 		testEditFileToNewBranch(t, session, "user1", "repo1", "master", "status1", "README.md", "status1") | ||||
| 		testEditFileToNewBranch(t, session, "user1", "repo1", "status1", "status1", "README.md", "# repo1\n\nDescription for repo1") | ||||
|  | ||||
| 		url := path.Join("user1", "repo1", "compare", "master...status1") | ||||
| 		req := NewRequestWithValues(t, "POST", url, | ||||
| 			map[string]string{ | ||||
| 				"_csrf": GetCSRF(t, session, url), | ||||
| 				"title": "pull request from status1", | ||||
| 			}, | ||||
| 		) | ||||
| 		session.MakeRequest(t, req, http.StatusSeeOther) | ||||
|  | ||||
| 		req = NewRequest(t, "GET", "/user1/repo1/pulls/1") | ||||
| 		resp := session.MakeRequest(t, req, http.StatusOK) | ||||
| 		doc := NewHTMLParser(t, resp.Body) | ||||
|  | ||||
| 		text := strings.TrimSpace(doc.doc.Find(".merge-section").Text()) | ||||
| 		assert.Contains(t, text, "This pull request can be merged automatically.") | ||||
| 	}) | ||||
| } | ||||
|  | ||||
| func TestPullCreate_EmptyChangesWithSameCommits(t *testing.T) { | ||||
| 	onGiteaRun(t, func(t *testing.T, u *url.URL) { | ||||
| 		session := loginUser(t, "user1") | ||||
| 		testRepoFork(t, session, "user2", "repo1", "user1", "repo1") | ||||
| 		testCreateBranch(t, session, "user1", "repo1", "branch/master", "status1", http.StatusSeeOther) | ||||
| 		url := path.Join("user1", "repo1", "compare", "master...status1") | ||||
| 		req := NewRequestWithValues(t, "POST", url, | ||||
| 			map[string]string{ | ||||
| 				"_csrf": GetCSRF(t, session, url), | ||||
| 				"title": "pull request from status1", | ||||
| 			}, | ||||
| 		) | ||||
| 		session.MakeRequest(t, req, http.StatusSeeOther) | ||||
| 		req = NewRequest(t, "GET", "/user1/repo1/pulls/1") | ||||
| 		resp := session.MakeRequest(t, req, http.StatusOK) | ||||
| 		doc := NewHTMLParser(t, resp.Body) | ||||
|  | ||||
| 		text := strings.TrimSpace(doc.doc.Find(".merge-section").Text()) | ||||
| 		assert.Contains(t, text, "This branch is already included in the target branch. There is nothing to merge.") | ||||
| 	}) | ||||
| } | ||||
		Reference in New Issue
	
	Block a user