mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-10-27 00:23:41 +09:00 
			
		
		
		
	Use test context in tests and new loop system in benchmarks (#33648)
Replace all contexts in tests with go1.24 t.Context() --------- Co-authored-by: Giteabot <teabot@gitea.io> Co-authored-by: wxiaoguang <wxiaoguang@gmail.com>
This commit is contained in:
		| @@ -11,7 +11,7 @@ import ( | ||||
| ) | ||||
|  | ||||
| func TestReadingBlameOutputSha256(t *testing.T) { | ||||
| 	ctx, cancel := context.WithCancel(context.Background()) | ||||
| 	ctx, cancel := context.WithCancel(t.Context()) | ||||
| 	defer cancel() | ||||
|  | ||||
| 	if isGogit { | ||||
|   | ||||
| @@ -11,7 +11,7 @@ import ( | ||||
| ) | ||||
|  | ||||
| func TestReadingBlameOutput(t *testing.T) { | ||||
| 	ctx, cancel := context.WithCancel(context.Background()) | ||||
| 	ctx, cancel := context.WithCancel(t.Context()) | ||||
| 	defer cancel() | ||||
|  | ||||
| 	t.Run("Without .git-blame-ignore-revs", func(t *testing.T) { | ||||
|   | ||||
| @@ -47,7 +47,7 @@ func Benchmark_Blob_Data(b *testing.B) { | ||||
| 		b.Fatal(err) | ||||
| 	} | ||||
|  | ||||
| 	for i := 0; i < b.N; i++ { | ||||
| 	for b.Loop() { | ||||
| 		r, err := testBlob.DataAsync() | ||||
| 		if err != nil { | ||||
| 			b.Fatal(err) | ||||
|   | ||||
| @@ -15,7 +15,7 @@ func TestRunWithContextNoTimeout(t *testing.T) { | ||||
| 	maxLoops := 10 | ||||
|  | ||||
| 	// 'git --version' does not block so it must be finished before the timeout triggered. | ||||
| 	cmd := NewCommand(context.Background(), "--version") | ||||
| 	cmd := NewCommand(t.Context(), "--version") | ||||
| 	for i := 0; i < maxLoops; i++ { | ||||
| 		if err := cmd.Run(&RunOpts{}); err != nil { | ||||
| 			t.Fatal(err) | ||||
| @@ -27,7 +27,7 @@ func TestRunWithContextTimeout(t *testing.T) { | ||||
| 	maxLoops := 10 | ||||
|  | ||||
| 	// 'git hash-object --stdin' blocks on stdin so we can have the timeout triggered. | ||||
| 	cmd := NewCommand(context.Background(), "hash-object", "--stdin") | ||||
| 	cmd := NewCommand(t.Context(), "hash-object", "--stdin") | ||||
| 	for i := 0; i < maxLoops; i++ { | ||||
| 		if err := cmd.Run(&RunOpts{Timeout: 1 * time.Millisecond}); err != nil { | ||||
| 			if err != context.DeadlineExceeded { | ||||
|   | ||||
| @@ -4,20 +4,19 @@ | ||||
| package git | ||||
|  | ||||
| import ( | ||||
| 	"context" | ||||
| 	"testing" | ||||
|  | ||||
| 	"github.com/stretchr/testify/assert" | ||||
| ) | ||||
|  | ||||
| func TestRunWithContextStd(t *testing.T) { | ||||
| 	cmd := NewCommand(context.Background(), "--version") | ||||
| 	cmd := NewCommand(t.Context(), "--version") | ||||
| 	stdout, stderr, err := cmd.RunStdString(&RunOpts{}) | ||||
| 	assert.NoError(t, err) | ||||
| 	assert.Empty(t, stderr) | ||||
| 	assert.Contains(t, stdout, "git version") | ||||
|  | ||||
| 	cmd = NewCommand(context.Background(), "--no-such-arg") | ||||
| 	cmd = NewCommand(t.Context(), "--no-such-arg") | ||||
| 	stdout, stderr, err = cmd.RunStdString(&RunOpts{}) | ||||
| 	if assert.Error(t, err) { | ||||
| 		assert.Equal(t, stderr, err.Stderr()) | ||||
| @@ -26,16 +25,16 @@ func TestRunWithContextStd(t *testing.T) { | ||||
| 		assert.Empty(t, stdout) | ||||
| 	} | ||||
|  | ||||
| 	cmd = NewCommand(context.Background()) | ||||
| 	cmd = NewCommand(t.Context()) | ||||
| 	cmd.AddDynamicArguments("-test") | ||||
| 	assert.ErrorIs(t, cmd.Run(&RunOpts{}), ErrBrokenCommand) | ||||
|  | ||||
| 	cmd = NewCommand(context.Background()) | ||||
| 	cmd = NewCommand(t.Context()) | ||||
| 	cmd.AddDynamicArguments("--test") | ||||
| 	assert.ErrorIs(t, cmd.Run(&RunOpts{}), ErrBrokenCommand) | ||||
|  | ||||
| 	subCmd := "version" | ||||
| 	cmd = NewCommand(context.Background()).AddDynamicArguments(subCmd) // for test purpose only, the sub-command should never be dynamic for production | ||||
| 	cmd = NewCommand(t.Context()).AddDynamicArguments(subCmd) // for test purpose only, the sub-command should never be dynamic for production | ||||
| 	stdout, stderr, err = cmd.RunStdString(&RunOpts{}) | ||||
| 	assert.NoError(t, err) | ||||
| 	assert.Empty(t, stderr) | ||||
| @@ -54,9 +53,9 @@ func TestGitArgument(t *testing.T) { | ||||
| } | ||||
|  | ||||
| func TestCommandString(t *testing.T) { | ||||
| 	cmd := NewCommandContextNoGlobals(context.Background(), "a", "-m msg", "it's a test", `say "hello"`) | ||||
| 	cmd := NewCommandContextNoGlobals(t.Context(), "a", "-m msg", "it's a test", `say "hello"`) | ||||
| 	assert.EqualValues(t, cmd.prog+` a "-m msg" "it's a test" "say \"hello\""`, cmd.LogString()) | ||||
|  | ||||
| 	cmd = NewCommandContextNoGlobals(context.Background(), "url: https://a:b@c/", "/root/dir-a/dir-b") | ||||
| 	cmd = NewCommandContextNoGlobals(t.Context(), "url: https://a:b@c/", "/root/dir-a/dir-b") | ||||
| 	assert.EqualValues(t, cmd.prog+` "url: https://sanitized-credential@c/" .../dir-a/dir-b`, cmd.LogString()) | ||||
| } | ||||
|   | ||||
| @@ -4,7 +4,6 @@ | ||||
| package git | ||||
|  | ||||
| import ( | ||||
| 	"context" | ||||
| 	"path/filepath" | ||||
| 	"testing" | ||||
| 	"time" | ||||
| @@ -83,7 +82,7 @@ func testGetCommitsInfo(t *testing.T, repo1 *Repository) { | ||||
| 		} | ||||
|  | ||||
| 		// FIXME: Context.TODO() - if graceful has started we should use its Shutdown context otherwise use install signals in TestMain. | ||||
| 		commitsInfo, treeCommit, err := entries.GetCommitsInfo(context.TODO(), commit, testCase.Path) | ||||
| 		commitsInfo, treeCommit, err := entries.GetCommitsInfo(t.Context(), commit, testCase.Path) | ||||
| 		assert.NoError(t, err, "Unable to get commit information for entries of subtree: %s in commit: %s from testcase due to error: %v", testCase.Path, testCase.CommitID, err) | ||||
| 		if err != nil { | ||||
| 			t.FailNow() | ||||
| @@ -159,8 +158,8 @@ func BenchmarkEntries_GetCommitsInfo(b *testing.B) { | ||||
| 		entries.Sort() | ||||
| 		b.ResetTimer() | ||||
| 		b.Run(benchmark.name, func(b *testing.B) { | ||||
| 			for i := 0; i < b.N; i++ { | ||||
| 				_, _, err := entries.GetCommitsInfo(context.Background(), commit, "") | ||||
| 			for b.Loop() { | ||||
| 				_, _, err := entries.GetCommitsInfo(b.Context(), commit, "") | ||||
| 				if err != nil { | ||||
| 					b.Fatal(err) | ||||
| 				} | ||||
|   | ||||
| @@ -4,7 +4,6 @@ | ||||
| package git | ||||
|  | ||||
| import ( | ||||
| 	"context" | ||||
| 	"testing" | ||||
|  | ||||
| 	"github.com/stretchr/testify/assert" | ||||
| @@ -13,18 +12,18 @@ import ( | ||||
| func TestCommitSubmoduleLink(t *testing.T) { | ||||
| 	sf := NewCommitSubmoduleFile("git@github.com:user/repo.git", "aaaa") | ||||
|  | ||||
| 	wl := sf.SubmoduleWebLink(context.Background()) | ||||
| 	wl := sf.SubmoduleWebLink(t.Context()) | ||||
| 	assert.Equal(t, "https://github.com/user/repo", wl.RepoWebLink) | ||||
| 	assert.Equal(t, "https://github.com/user/repo/tree/aaaa", wl.CommitWebLink) | ||||
|  | ||||
| 	wl = sf.SubmoduleWebLink(context.Background(), "1111") | ||||
| 	wl = sf.SubmoduleWebLink(t.Context(), "1111") | ||||
| 	assert.Equal(t, "https://github.com/user/repo", wl.RepoWebLink) | ||||
| 	assert.Equal(t, "https://github.com/user/repo/tree/1111", wl.CommitWebLink) | ||||
|  | ||||
| 	wl = sf.SubmoduleWebLink(context.Background(), "1111", "2222") | ||||
| 	wl = sf.SubmoduleWebLink(t.Context(), "1111", "2222") | ||||
| 	assert.Equal(t, "https://github.com/user/repo", wl.RepoWebLink) | ||||
| 	assert.Equal(t, "https://github.com/user/repo/compare/1111...2222", wl.CommitWebLink) | ||||
|  | ||||
| 	wl = (*CommitSubmoduleFile)(nil).SubmoduleWebLink(context.Background()) | ||||
| 	wl = (*CommitSubmoduleFile)(nil).SubmoduleWebLink(t.Context()) | ||||
| 	assert.Nil(t, wl) | ||||
| } | ||||
|   | ||||
| @@ -4,7 +4,6 @@ | ||||
| package git | ||||
|  | ||||
| import ( | ||||
| 	"context" | ||||
| 	"os" | ||||
| 	"path/filepath" | ||||
| 	"strings" | ||||
| @@ -347,7 +346,7 @@ func TestGetCommitFileStatusMerges(t *testing.T) { | ||||
|  | ||||
| func Test_GetCommitBranchStart(t *testing.T) { | ||||
| 	bareRepo1Path := filepath.Join(testReposDir, "repo1_bare") | ||||
| 	repo, err := OpenRepository(context.Background(), bareRepo1Path) | ||||
| 	repo, err := OpenRepository(t.Context(), bareRepo1Path) | ||||
| 	assert.NoError(t, err) | ||||
| 	defer repo.Close() | ||||
| 	commit, err := repo.GetBranchCommit("branch1") | ||||
|   | ||||
| @@ -4,7 +4,6 @@ | ||||
| package git | ||||
|  | ||||
| import ( | ||||
| 	"context" | ||||
| 	"path/filepath" | ||||
| 	"testing" | ||||
|  | ||||
| @@ -16,7 +15,7 @@ func TestGrepSearch(t *testing.T) { | ||||
| 	assert.NoError(t, err) | ||||
| 	defer repo.Close() | ||||
|  | ||||
| 	res, err := GrepSearch(context.Background(), repo, "void", GrepOptions{}) | ||||
| 	res, err := GrepSearch(t.Context(), repo, "void", GrepOptions{}) | ||||
| 	assert.NoError(t, err) | ||||
| 	assert.Equal(t, []*GrepResult{ | ||||
| 		{ | ||||
| @@ -31,7 +30,7 @@ func TestGrepSearch(t *testing.T) { | ||||
| 		}, | ||||
| 	}, res) | ||||
|  | ||||
| 	res, err = GrepSearch(context.Background(), repo, "void", GrepOptions{PathspecList: []string{":(glob)java-hello/*"}}) | ||||
| 	res, err = GrepSearch(t.Context(), repo, "void", GrepOptions{PathspecList: []string{":(glob)java-hello/*"}}) | ||||
| 	assert.NoError(t, err) | ||||
| 	assert.Equal(t, []*GrepResult{ | ||||
| 		{ | ||||
| @@ -41,7 +40,7 @@ func TestGrepSearch(t *testing.T) { | ||||
| 		}, | ||||
| 	}, res) | ||||
|  | ||||
| 	res, err = GrepSearch(context.Background(), repo, "void", GrepOptions{PathspecList: []string{":(glob,exclude)java-hello/*"}}) | ||||
| 	res, err = GrepSearch(t.Context(), repo, "void", GrepOptions{PathspecList: []string{":(glob,exclude)java-hello/*"}}) | ||||
| 	assert.NoError(t, err) | ||||
| 	assert.Equal(t, []*GrepResult{ | ||||
| 		{ | ||||
| @@ -51,7 +50,7 @@ func TestGrepSearch(t *testing.T) { | ||||
| 		}, | ||||
| 	}, res) | ||||
|  | ||||
| 	res, err = GrepSearch(context.Background(), repo, "void", GrepOptions{MaxResultLimit: 1}) | ||||
| 	res, err = GrepSearch(t.Context(), repo, "void", GrepOptions{MaxResultLimit: 1}) | ||||
| 	assert.NoError(t, err) | ||||
| 	assert.Equal(t, []*GrepResult{ | ||||
| 		{ | ||||
| @@ -61,7 +60,7 @@ func TestGrepSearch(t *testing.T) { | ||||
| 		}, | ||||
| 	}, res) | ||||
|  | ||||
| 	res, err = GrepSearch(context.Background(), repo, "void", GrepOptions{MaxResultLimit: 1, MaxLineLength: 39}) | ||||
| 	res, err = GrepSearch(t.Context(), repo, "void", GrepOptions{MaxResultLimit: 1, MaxLineLength: 39}) | ||||
| 	assert.NoError(t, err) | ||||
| 	assert.Equal(t, []*GrepResult{ | ||||
| 		{ | ||||
| @@ -71,11 +70,11 @@ func TestGrepSearch(t *testing.T) { | ||||
| 		}, | ||||
| 	}, res) | ||||
|  | ||||
| 	res, err = GrepSearch(context.Background(), repo, "no-such-content", GrepOptions{}) | ||||
| 	res, err = GrepSearch(t.Context(), repo, "no-such-content", GrepOptions{}) | ||||
| 	assert.NoError(t, err) | ||||
| 	assert.Empty(t, res) | ||||
|  | ||||
| 	res, err = GrepSearch(context.Background(), &Repository{Path: "no-such-git-repo"}, "no-such-content", GrepOptions{}) | ||||
| 	res, err = GrepSearch(t.Context(), &Repository{Path: "no-such-git-repo"}, "no-such-content", GrepOptions{}) | ||||
| 	assert.Error(t, err) | ||||
| 	assert.Empty(t, res) | ||||
| } | ||||
|   | ||||
| @@ -4,7 +4,6 @@ | ||||
| package git | ||||
|  | ||||
| import ( | ||||
| 	"context" | ||||
| 	"path/filepath" | ||||
| 	"testing" | ||||
|  | ||||
| @@ -18,7 +17,7 @@ func TestGetNotes(t *testing.T) { | ||||
| 	defer bareRepo1.Close() | ||||
|  | ||||
| 	note := Note{} | ||||
| 	err = GetNote(context.Background(), bareRepo1, "95bb4d39648ee7e325106df01a621c530863a653", ¬e) | ||||
| 	err = GetNote(t.Context(), bareRepo1, "95bb4d39648ee7e325106df01a621c530863a653", ¬e) | ||||
| 	assert.NoError(t, err) | ||||
| 	assert.Equal(t, []byte("Note contents\n"), note.Message) | ||||
| 	assert.Equal(t, "Vladimir Panteleev", note.Commit.Author.Name) | ||||
| @@ -31,10 +30,10 @@ func TestGetNestedNotes(t *testing.T) { | ||||
| 	defer repo.Close() | ||||
|  | ||||
| 	note := Note{} | ||||
| 	err = GetNote(context.Background(), repo, "3e668dbfac39cbc80a9ff9c61eb565d944453ba4", ¬e) | ||||
| 	err = GetNote(t.Context(), repo, "3e668dbfac39cbc80a9ff9c61eb565d944453ba4", ¬e) | ||||
| 	assert.NoError(t, err) | ||||
| 	assert.Equal(t, []byte("Note 2"), note.Message) | ||||
| 	err = GetNote(context.Background(), repo, "ba0a96fa63532d6c5087ecef070b0250ed72fa47", ¬e) | ||||
| 	err = GetNote(t.Context(), repo, "ba0a96fa63532d6c5087ecef070b0250ed72fa47", ¬e) | ||||
| 	assert.NoError(t, err) | ||||
| 	assert.Equal(t, []byte("Note 1"), note.Message) | ||||
| } | ||||
| @@ -46,7 +45,7 @@ func TestGetNonExistentNotes(t *testing.T) { | ||||
| 	defer bareRepo1.Close() | ||||
|  | ||||
| 	note := Note{} | ||||
| 	err = GetNote(context.Background(), bareRepo1, "non_existent_sha", ¬e) | ||||
| 	err = GetNote(t.Context(), bareRepo1, "non_existent_sha", ¬e) | ||||
| 	assert.Error(t, err) | ||||
| 	assert.IsType(t, ErrNotExist{}, err) | ||||
| } | ||||
|   | ||||
| @@ -47,7 +47,7 @@ func BenchmarkRepository_GetBranches(b *testing.B) { | ||||
| 	} | ||||
| 	defer bareRepo1.Close() | ||||
|  | ||||
| 	for i := 0; i < b.N; i++ { | ||||
| 	for b.Loop() { | ||||
| 		_, _, err := bareRepo1.GetBranchNames(0, 0) | ||||
| 		if err != nil { | ||||
| 			b.Fatal(err) | ||||
|   | ||||
| @@ -4,7 +4,6 @@ | ||||
| package git | ||||
|  | ||||
| import ( | ||||
| 	"context" | ||||
| 	"path/filepath" | ||||
| 	"testing" | ||||
|  | ||||
| @@ -33,21 +32,21 @@ func TestRepoIsEmpty(t *testing.T) { | ||||
|  | ||||
| func TestRepoGetDivergingCommits(t *testing.T) { | ||||
| 	bareRepo1Path := filepath.Join(testReposDir, "repo1_bare") | ||||
| 	do, err := GetDivergingCommits(context.Background(), bareRepo1Path, "master", "branch2") | ||||
| 	do, err := GetDivergingCommits(t.Context(), bareRepo1Path, "master", "branch2") | ||||
| 	assert.NoError(t, err) | ||||
| 	assert.Equal(t, DivergeObject{ | ||||
| 		Ahead:  1, | ||||
| 		Behind: 5, | ||||
| 	}, do) | ||||
|  | ||||
| 	do, err = GetDivergingCommits(context.Background(), bareRepo1Path, "master", "master") | ||||
| 	do, err = GetDivergingCommits(t.Context(), bareRepo1Path, "master", "master") | ||||
| 	assert.NoError(t, err) | ||||
| 	assert.Equal(t, DivergeObject{ | ||||
| 		Ahead:  0, | ||||
| 		Behind: 0, | ||||
| 	}, do) | ||||
|  | ||||
| 	do, err = GetDivergingCommits(context.Background(), bareRepo1Path, "master", "test") | ||||
| 	do, err = GetDivergingCommits(t.Context(), bareRepo1Path, "master", "test") | ||||
| 	assert.NoError(t, err) | ||||
| 	assert.Equal(t, DivergeObject{ | ||||
| 		Ahead:  0, | ||||
|   | ||||
| @@ -4,7 +4,6 @@ | ||||
| package git | ||||
|  | ||||
| import ( | ||||
| 	"context" | ||||
| 	"os" | ||||
| 	"path/filepath" | ||||
| 	"testing" | ||||
| @@ -28,7 +27,7 @@ func TestGetTemplateSubmoduleCommits(t *testing.T) { | ||||
| } | ||||
|  | ||||
| func TestAddTemplateSubmoduleIndexes(t *testing.T) { | ||||
| 	ctx := context.Background() | ||||
| 	ctx := t.Context() | ||||
| 	tmpDir := t.TempDir() | ||||
| 	var err error | ||||
| 	_, _, err = NewCommand(ctx, "init").RunStdString(&RunOpts{Dir: tmpDir}) | ||||
|   | ||||
| @@ -179,7 +179,7 @@ func TestParseRepositoryURL(t *testing.T) { | ||||
| 	ctxReq := &http.Request{URL: ctxURL, Header: http.Header{}} | ||||
| 	ctxReq.Host = ctxURL.Host | ||||
| 	ctxReq.Header.Add("X-Forwarded-Proto", ctxURL.Scheme) | ||||
| 	ctx := context.WithValue(context.Background(), httplib.RequestContextKey, ctxReq) | ||||
| 	ctx := context.WithValue(t.Context(), httplib.RequestContextKey, ctxReq) | ||||
| 	cases := []struct { | ||||
| 		input                          string | ||||
| 		ownerName, repoName, remaining string | ||||
| @@ -249,19 +249,19 @@ func TestMakeRepositoryBaseLink(t *testing.T) { | ||||
| 	defer test.MockVariableValue(&setting.AppURL, "https://localhost:3000/subpath")() | ||||
| 	defer test.MockVariableValue(&setting.AppSubURL, "/subpath")() | ||||
|  | ||||
| 	u, err := ParseRepositoryURL(context.Background(), "https://localhost:3000/subpath/user/repo.git") | ||||
| 	u, err := ParseRepositoryURL(t.Context(), "https://localhost:3000/subpath/user/repo.git") | ||||
| 	assert.NoError(t, err) | ||||
| 	assert.Equal(t, "/subpath/user/repo", MakeRepositoryWebLink(u)) | ||||
|  | ||||
| 	u, err = ParseRepositoryURL(context.Background(), "https://github.com/owner/repo.git") | ||||
| 	u, err = ParseRepositoryURL(t.Context(), "https://github.com/owner/repo.git") | ||||
| 	assert.NoError(t, err) | ||||
| 	assert.Equal(t, "https://github.com/owner/repo", MakeRepositoryWebLink(u)) | ||||
|  | ||||
| 	u, err = ParseRepositoryURL(context.Background(), "git@github.com:owner/repo.git") | ||||
| 	u, err = ParseRepositoryURL(t.Context(), "git@github.com:owner/repo.git") | ||||
| 	assert.NoError(t, err) | ||||
| 	assert.Equal(t, "https://github.com/owner/repo", MakeRepositoryWebLink(u)) | ||||
|  | ||||
| 	u, err = ParseRepositoryURL(context.Background(), "git+ssh://other:123/owner/repo.git") | ||||
| 	u, err = ParseRepositoryURL(t.Context(), "git+ssh://other:123/owner/repo.git") | ||||
| 	assert.NoError(t, err) | ||||
| 	assert.Equal(t, "https://other/owner/repo", MakeRepositoryWebLink(u)) | ||||
| } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user