mirror of
				https://github.com/go-gitea/gitea
				synced 2025-10-26 00:48:29 +00:00 
			
		
		
		
	By some CI fine tunes (`run tests`), SQLite & MSSQL could complete in about 12~13 minutes (before > 14), MySQL could complete in 18 minutes (before: about 23 or even > 30) Major changes: 1. use tmpfs for MySQL storage 1. run `make test-mysql` instead of `make integration-test-coverage` because the code coverage is not really used at the moment. 1. refactor testlogger to make it more reliable and be able to report stuck stacktrace 1. do not requeue failed items when a queue is being flushed (failed items would keep failing and make flush uncompleted) 1. reduce the file sizes for testing 1. use math ChaCha20 random data instead of crypot/rand (for testing purpose only) 1. no need to `DeleteRepository` in `TestLinguist` 1. other related refactoring to make code easier to maintain
		
			
				
	
	
		
			139 lines
		
	
	
		
			4.3 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			139 lines
		
	
	
		
			4.3 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| // Copyright 2024 The Gitea Authors. All rights reserved.
 | |
| // SPDX-License-Identifier: MIT
 | |
| 
 | |
| package integration
 | |
| 
 | |
| import (
 | |
| 	"bytes"
 | |
| 	"context"
 | |
| 	"io"
 | |
| 	"net/url"
 | |
| 	"sync"
 | |
| 	"testing"
 | |
| 
 | |
| 	auth_model "code.gitea.io/gitea/models/auth"
 | |
| 	"code.gitea.io/gitea/models/db"
 | |
| 	issues_model "code.gitea.io/gitea/models/issues"
 | |
| 	repo_model "code.gitea.io/gitea/models/repo"
 | |
| 	"code.gitea.io/gitea/models/unittest"
 | |
| 	user_model "code.gitea.io/gitea/models/user"
 | |
| 	"code.gitea.io/gitea/modules/git"
 | |
| 	"code.gitea.io/gitea/modules/gitrepo"
 | |
| 	files_service "code.gitea.io/gitea/services/repository/files"
 | |
| 
 | |
| 	"github.com/stretchr/testify/assert"
 | |
| )
 | |
| 
 | |
| func TestDataAsyncDoubleRead_Issue29101(t *testing.T) {
 | |
| 	onGiteaRun(t, func(t *testing.T, u *url.URL) {
 | |
| 		user := unittest.AssertExistsAndLoadBean(t, &user_model.User{ID: 2})
 | |
| 		repo := unittest.AssertExistsAndLoadBean(t, &repo_model.Repository{ID: 1})
 | |
| 
 | |
| 		testContent := bytes.Repeat([]byte{'a'}, 10000)
 | |
| 		resp, err := files_service.ChangeRepoFiles(db.DefaultContext, repo, user, &files_service.ChangeRepoFilesOptions{
 | |
| 			Files: []*files_service.ChangeRepoFile{
 | |
| 				{
 | |
| 					Operation:     "create",
 | |
| 					TreePath:      "test.txt",
 | |
| 					ContentReader: bytes.NewReader(testContent),
 | |
| 				},
 | |
| 			},
 | |
| 			OldBranch: repo.DefaultBranch,
 | |
| 			NewBranch: repo.DefaultBranch,
 | |
| 		})
 | |
| 		assert.NoError(t, err)
 | |
| 
 | |
| 		sha := resp.Commit.SHA
 | |
| 
 | |
| 		gitRepo, err := gitrepo.OpenRepository(db.DefaultContext, repo)
 | |
| 		assert.NoError(t, err)
 | |
| 
 | |
| 		commit, err := gitRepo.GetCommit(sha)
 | |
| 		assert.NoError(t, err)
 | |
| 
 | |
| 		entry, err := commit.GetTreeEntryByPath("test.txt")
 | |
| 		assert.NoError(t, err)
 | |
| 
 | |
| 		b := entry.Blob()
 | |
| 		r1, err := b.DataAsync()
 | |
| 		assert.NoError(t, err)
 | |
| 		defer r1.Close()
 | |
| 		r2, err := b.DataAsync()
 | |
| 		assert.NoError(t, err)
 | |
| 		defer r2.Close()
 | |
| 
 | |
| 		var data1, data2 []byte
 | |
| 		wg := sync.WaitGroup{}
 | |
| 		wg.Add(2)
 | |
| 		go func() {
 | |
| 			data1, _ = io.ReadAll(r1)
 | |
| 			assert.NoError(t, err)
 | |
| 			wg.Done()
 | |
| 		}()
 | |
| 		go func() {
 | |
| 			data2, _ = io.ReadAll(r2)
 | |
| 			assert.NoError(t, err)
 | |
| 			wg.Done()
 | |
| 		}()
 | |
| 		wg.Wait()
 | |
| 		assert.Equal(t, testContent, data1)
 | |
| 		assert.Equal(t, testContent, data2)
 | |
| 	})
 | |
| }
 | |
| 
 | |
| func TestAgitPullPush(t *testing.T) {
 | |
| 	onGiteaRun(t, func(t *testing.T, u *url.URL) {
 | |
| 		baseAPITestContext := NewAPITestContext(t, "user2", "repo1", auth_model.AccessTokenScopeWriteRepository, auth_model.AccessTokenScopeWriteUser)
 | |
| 
 | |
| 		u.Path = baseAPITestContext.GitPath()
 | |
| 		u.User = url.UserPassword("user2", userPassword)
 | |
| 
 | |
| 		dstPath := t.TempDir()
 | |
| 		doGitClone(dstPath, u)(t)
 | |
| 
 | |
| 		gitRepo, err := git.OpenRepository(context.Background(), dstPath)
 | |
| 		assert.NoError(t, err)
 | |
| 		defer gitRepo.Close()
 | |
| 
 | |
| 		doGitCreateBranch(dstPath, "test-agit-push")
 | |
| 
 | |
| 		// commit 1
 | |
| 		_, err = generateCommitWithNewData(testFileSizeSmall, dstPath, "user2@example.com", "User Two", "branch-data-file-")
 | |
| 		assert.NoError(t, err)
 | |
| 
 | |
| 		// push to create an agit pull request
 | |
| 		err = git.NewCommand(git.DefaultContext, "push", "origin",
 | |
| 			"-o", "title=test-title", "-o", "description=test-description",
 | |
| 			"HEAD:refs/for/master/test-agit-push",
 | |
| 		).Run(&git.RunOpts{Dir: dstPath})
 | |
| 		assert.NoError(t, err)
 | |
| 
 | |
| 		// check pull request exist
 | |
| 		pr := unittest.AssertExistsAndLoadBean(t, &issues_model.PullRequest{BaseRepoID: 1, Flow: issues_model.PullRequestFlowAGit, HeadBranch: "user2/test-agit-push"})
 | |
| 		assert.NoError(t, pr.LoadIssue(db.DefaultContext))
 | |
| 		assert.Equal(t, "test-title", pr.Issue.Title)
 | |
| 		assert.Equal(t, "test-description", pr.Issue.Content)
 | |
| 
 | |
| 		// commit 2
 | |
| 		_, err = generateCommitWithNewData(testFileSizeSmall, dstPath, "user2@example.com", "User Two", "branch-data-file-2-")
 | |
| 		assert.NoError(t, err)
 | |
| 
 | |
| 		// push 2
 | |
| 		err = git.NewCommand(git.DefaultContext, "push", "origin", "HEAD:refs/for/master/test-agit-push").Run(&git.RunOpts{Dir: dstPath})
 | |
| 		assert.NoError(t, err)
 | |
| 
 | |
| 		// reset to first commit
 | |
| 		err = git.NewCommand(git.DefaultContext, "reset", "--hard", "HEAD~1").Run(&git.RunOpts{Dir: dstPath})
 | |
| 		assert.NoError(t, err)
 | |
| 
 | |
| 		// test force push without confirm
 | |
| 		_, stderr, err := git.NewCommand(git.DefaultContext, "push", "origin", "HEAD:refs/for/master/test-agit-push").RunStdString(&git.RunOpts{Dir: dstPath})
 | |
| 		assert.Error(t, err)
 | |
| 		assert.Contains(t, stderr, "[remote rejected] HEAD -> refs/for/master/test-agit-push (request `force-push` push option)")
 | |
| 
 | |
| 		// test force push with confirm
 | |
| 		err = git.NewCommand(git.DefaultContext, "push", "origin", "HEAD:refs/for/master/test-agit-push", "-o", "force-push").Run(&git.RunOpts{Dir: dstPath})
 | |
| 		assert.NoError(t, err)
 | |
| 	})
 | |
| }
 |