mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-10-24 13:53:42 +09:00 
			
		
		
		
	Fix git commit committer parsing and add some tests (#35007)
* Fix #34991 * Fix #34882 --------- Co-authored-by: wxiaoguang <wxiaoguang@gmail.com>
This commit is contained in:
		| @@ -24,39 +24,59 @@ import ( | ||||
|  | ||||
| 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) | ||||
| 	t.Run("CommitList", func(t *testing.T) { | ||||
| 		req := NewRequest(t, "GET", "/user2/repo16/commits/branch/master") | ||||
| 		resp := session.MakeRequest(t, req, http.StatusOK) | ||||
|  | ||||
| 	doc := NewHTMLParser(t, resp.Body) | ||||
| 	commitURL, exists := doc.doc.Find("#commits-table .commit-id-short").Attr("href") | ||||
| 	assert.True(t, exists) | ||||
| 	assert.NotEmpty(t, commitURL) | ||||
| } | ||||
|  | ||||
| func Test_ReposGitCommitListNotMaster(t *testing.T) { | ||||
| 	defer tests.PrepareTestEnv(t)() | ||||
| 	session := loginUser(t, "user2") | ||||
| 	req := NewRequest(t, "GET", "/user2/repo16/commits/branch/master") | ||||
| 	resp := session.MakeRequest(t, req, http.StatusOK) | ||||
|  | ||||
| 	doc := NewHTMLParser(t, resp.Body) | ||||
| 	var commits []string | ||||
| 	doc.doc.Find("#commits-table .commit-id-short").Each(func(i int, s *goquery.Selection) { | ||||
| 		commitURL, _ := s.Attr("href") | ||||
| 		commits = append(commits, path.Base(commitURL)) | ||||
| 		var commits, userHrefs []string | ||||
| 		doc := NewHTMLParser(t, resp.Body) | ||||
| 		doc.doc.Find("#commits-table .commit-id-short").Each(func(i int, s *goquery.Selection) { | ||||
| 			commits = append(commits, path.Base(s.AttrOr("href", ""))) | ||||
| 		}) | ||||
| 		doc.doc.Find("#commits-table .author-wrapper").Each(func(i int, s *goquery.Selection) { | ||||
| 			userHrefs = append(userHrefs, s.AttrOr("href", "")) | ||||
| 		}) | ||||
| 		assert.Equal(t, []string{"69554a64c1e6030f051e5c3f94bfbd773cd6a324", "27566bd5738fc8b4e3fef3c5e72cce608537bd95", "5099b81332712fe655e34e8dd63574f503f61811"}, commits) | ||||
| 		assert.Equal(t, []string{"/user2", "/user21", "/user2"}, userHrefs) | ||||
| 	}) | ||||
| 	assert.Equal(t, []string{"69554a64c1e6030f051e5c3f94bfbd773cd6a324", "27566bd5738fc8b4e3fef3c5e72cce608537bd95", "5099b81332712fe655e34e8dd63574f503f61811"}, commits) | ||||
|  | ||||
| 	var userHrefs []string | ||||
| 	doc.doc.Find("#commits-table .author-wrapper").Each(func(i int, s *goquery.Selection) { | ||||
| 		userHref, _ := s.Attr("href") | ||||
| 		userHrefs = append(userHrefs, userHref) | ||||
| 	t.Run("LastCommit", func(t *testing.T) { | ||||
| 		req := NewRequest(t, "GET", "/user2/repo16") | ||||
| 		resp := session.MakeRequest(t, req, http.StatusOK) | ||||
| 		doc := NewHTMLParser(t, resp.Body) | ||||
| 		commitHref := doc.doc.Find(".latest-commit .commit-id-short").AttrOr("href", "") | ||||
| 		authorHref := doc.doc.Find(".latest-commit .author-wrapper").AttrOr("href", "") | ||||
| 		assert.Equal(t, "/user2/repo16/commit/69554a64c1e6030f051e5c3f94bfbd773cd6a324", commitHref) | ||||
| 		assert.Equal(t, "/user2", authorHref) | ||||
| 	}) | ||||
|  | ||||
| 	t.Run("CommitListNonExistingCommiter", func(t *testing.T) { | ||||
| 		// check the commit list for a repository with no gitea user | ||||
| 		// * commit 985f0301dba5e7b34be866819cd15ad3d8f508ee (branch2) | ||||
| 		// * Author: 6543 <6543@obermui.de> | ||||
| 		req := NewRequest(t, "GET", "/user2/repo1/commits/branch/branch2") | ||||
| 		resp := session.MakeRequest(t, req, http.StatusOK) | ||||
|  | ||||
| 		doc := NewHTMLParser(t, resp.Body) | ||||
| 		commitHref := doc.doc.Find("#commits-table tr:first-child .commit-id-short").AttrOr("href", "") | ||||
| 		assert.Equal(t, "/user2/repo1/commit/985f0301dba5e7b34be866819cd15ad3d8f508ee", commitHref) | ||||
| 		authorElem := doc.doc.Find("#commits-table tr:first-child .author-wrapper") | ||||
| 		assert.Equal(t, "6543", authorElem.Text()) | ||||
| 		assert.Equal(t, "span", authorElem.Nodes[0].Data) | ||||
| 	}) | ||||
|  | ||||
| 	t.Run("LastCommitNonExistingCommiter", func(t *testing.T) { | ||||
| 		req := NewRequest(t, "GET", "/user2/repo1/src/branch/branch2") | ||||
| 		resp := session.MakeRequest(t, req, http.StatusOK) | ||||
| 		doc := NewHTMLParser(t, resp.Body) | ||||
| 		commitHref := doc.doc.Find(".latest-commit .commit-id-short").AttrOr("href", "") | ||||
| 		assert.Equal(t, "/user2/repo1/commit/985f0301dba5e7b34be866819cd15ad3d8f508ee", commitHref) | ||||
| 		authorElem := doc.doc.Find(".latest-commit .author-wrapper") | ||||
| 		assert.Equal(t, "6543", authorElem.Text()) | ||||
| 		assert.Equal(t, "span", authorElem.Nodes[0].Data) | ||||
| 	}) | ||||
| 	assert.Equal(t, []string{"/user2", "/user21", "/user2"}, userHrefs) | ||||
| } | ||||
|  | ||||
| func doTestRepoCommitWithStatus(t *testing.T, state string, classes ...string) { | ||||
|   | ||||
		Reference in New Issue
	
	Block a user