mirror of
				https://codeberg.org/forgejo/forgejo.git
				synced 2025-10-26 12:01:08 +00: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:
		
					parent
					
						
							
								5710ff343c
							
						
					
				
			
			
				commit
				
					
						c8ded77680
					
				
			
		
					 644 changed files with 1857 additions and 1027 deletions
				
			
		
							
								
								
									
										202
									
								
								tests/integration/repofiles_delete_test.go
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										202
									
								
								tests/integration/repofiles_delete_test.go
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,202 @@ | |||
| // 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 ( | ||||
| 	"net/url" | ||||
| 	"testing" | ||||
| 
 | ||||
| 	repo_model "code.gitea.io/gitea/models/repo" | ||||
| 	"code.gitea.io/gitea/models/unittest" | ||||
| 	"code.gitea.io/gitea/modules/git" | ||||
| 	api "code.gitea.io/gitea/modules/structs" | ||||
| 	"code.gitea.io/gitea/modules/test" | ||||
| 	files_service "code.gitea.io/gitea/services/repository/files" | ||||
| 
 | ||||
| 	"github.com/stretchr/testify/assert" | ||||
| ) | ||||
| 
 | ||||
| func getDeleteRepoFileOptions(repo *repo_model.Repository) *files_service.DeleteRepoFileOptions { | ||||
| 	return &files_service.DeleteRepoFileOptions{ | ||||
| 		LastCommitID: "", | ||||
| 		OldBranch:    repo.DefaultBranch, | ||||
| 		NewBranch:    repo.DefaultBranch, | ||||
| 		TreePath:     "README.md", | ||||
| 		Message:      "Deletes README.md", | ||||
| 		SHA:          "4b4851ad51df6a7d9f25c979345979eaeb5b349f", | ||||
| 		Author: &files_service.IdentityOptions{ | ||||
| 			Name:  "Bob Smith", | ||||
| 			Email: "bob@smith.com", | ||||
| 		}, | ||||
| 		Committer: nil, | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
| func getExpectedDeleteFileResponse(u *url.URL) *api.FileResponse { | ||||
| 	// Just returns fields that don't change, i.e. fields with commit SHAs and dates can't be determined | ||||
| 	return &api.FileResponse{ | ||||
| 		Content: nil, | ||||
| 		Commit: &api.FileCommitResponse{ | ||||
| 			Author: &api.CommitUser{ | ||||
| 				Identity: api.Identity{ | ||||
| 					Name:  "Bob Smith", | ||||
| 					Email: "bob@smith.com", | ||||
| 				}, | ||||
| 			}, | ||||
| 			Committer: &api.CommitUser{ | ||||
| 				Identity: api.Identity{ | ||||
| 					Name:  "Bob Smith", | ||||
| 					Email: "bob@smith.com", | ||||
| 				}, | ||||
| 			}, | ||||
| 			Message: "Deletes README.md\n", | ||||
| 		}, | ||||
| 		Verification: &api.PayloadCommitVerification{ | ||||
| 			Verified:  false, | ||||
| 			Reason:    "gpg.error.not_signed_commit", | ||||
| 			Signature: "", | ||||
| 			Payload:   "", | ||||
| 		}, | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
| func TestDeleteRepoFile(t *testing.T) { | ||||
| 	onGiteaRun(t, testDeleteRepoFile) | ||||
| } | ||||
| 
 | ||||
| func testDeleteRepoFile(t *testing.T, u *url.URL) { | ||||
| 	// setup | ||||
| 	unittest.PrepareTestEnv(t) | ||||
| 	ctx := test.MockContext(t, "user2/repo1") | ||||
| 	ctx.SetParams(":id", "1") | ||||
| 	test.LoadRepo(t, ctx, 1) | ||||
| 	test.LoadRepoCommit(t, ctx) | ||||
| 	test.LoadUser(t, ctx, 2) | ||||
| 	test.LoadGitRepo(t, ctx) | ||||
| 	defer ctx.Repo.GitRepo.Close() | ||||
| 	repo := ctx.Repo.Repository | ||||
| 	doer := ctx.Doer | ||||
| 	opts := getDeleteRepoFileOptions(repo) | ||||
| 
 | ||||
| 	t.Run("Delete README.md file", func(t *testing.T) { | ||||
| 		fileResponse, err := files_service.DeleteRepoFile(git.DefaultContext, repo, doer, opts) | ||||
| 		assert.NoError(t, err) | ||||
| 		expectedFileResponse := getExpectedDeleteFileResponse(u) | ||||
| 		assert.NotNil(t, fileResponse) | ||||
| 		assert.Nil(t, fileResponse.Content) | ||||
| 		assert.EqualValues(t, expectedFileResponse.Commit.Message, fileResponse.Commit.Message) | ||||
| 		assert.EqualValues(t, expectedFileResponse.Commit.Author.Identity, fileResponse.Commit.Author.Identity) | ||||
| 		assert.EqualValues(t, expectedFileResponse.Commit.Committer.Identity, fileResponse.Commit.Committer.Identity) | ||||
| 		assert.EqualValues(t, expectedFileResponse.Verification, fileResponse.Verification) | ||||
| 	}) | ||||
| 
 | ||||
| 	t.Run("Verify README.md has been deleted", func(t *testing.T) { | ||||
| 		fileResponse, err := files_service.DeleteRepoFile(git.DefaultContext, repo, doer, opts) | ||||
| 		assert.Nil(t, fileResponse) | ||||
| 		expectedError := "repository file does not exist [path: " + opts.TreePath + "]" | ||||
| 		assert.EqualError(t, err, expectedError) | ||||
| 	}) | ||||
| } | ||||
| 
 | ||||
| // Test opts with branch names removed, same results | ||||
| func TestDeleteRepoFileWithoutBranchNames(t *testing.T) { | ||||
| 	onGiteaRun(t, testDeleteRepoFileWithoutBranchNames) | ||||
| } | ||||
| 
 | ||||
| func testDeleteRepoFileWithoutBranchNames(t *testing.T, u *url.URL) { | ||||
| 	// setup | ||||
| 	unittest.PrepareTestEnv(t) | ||||
| 	ctx := test.MockContext(t, "user2/repo1") | ||||
| 	ctx.SetParams(":id", "1") | ||||
| 	test.LoadRepo(t, ctx, 1) | ||||
| 	test.LoadRepoCommit(t, ctx) | ||||
| 	test.LoadUser(t, ctx, 2) | ||||
| 	test.LoadGitRepo(t, ctx) | ||||
| 	defer ctx.Repo.GitRepo.Close() | ||||
| 
 | ||||
| 	repo := ctx.Repo.Repository | ||||
| 	doer := ctx.Doer | ||||
| 	opts := getDeleteRepoFileOptions(repo) | ||||
| 	opts.OldBranch = "" | ||||
| 	opts.NewBranch = "" | ||||
| 
 | ||||
| 	t.Run("Delete README.md without Branch Name", func(t *testing.T) { | ||||
| 		fileResponse, err := files_service.DeleteRepoFile(git.DefaultContext, repo, doer, opts) | ||||
| 		assert.NoError(t, err) | ||||
| 		expectedFileResponse := getExpectedDeleteFileResponse(u) | ||||
| 		assert.NotNil(t, fileResponse) | ||||
| 		assert.Nil(t, fileResponse.Content) | ||||
| 		assert.EqualValues(t, expectedFileResponse.Commit.Message, fileResponse.Commit.Message) | ||||
| 		assert.EqualValues(t, expectedFileResponse.Commit.Author.Identity, fileResponse.Commit.Author.Identity) | ||||
| 		assert.EqualValues(t, expectedFileResponse.Commit.Committer.Identity, fileResponse.Commit.Committer.Identity) | ||||
| 		assert.EqualValues(t, expectedFileResponse.Verification, fileResponse.Verification) | ||||
| 	}) | ||||
| } | ||||
| 
 | ||||
| func TestDeleteRepoFileErrors(t *testing.T) { | ||||
| 	// setup | ||||
| 	unittest.PrepareTestEnv(t) | ||||
| 	ctx := test.MockContext(t, "user2/repo1") | ||||
| 	ctx.SetParams(":id", "1") | ||||
| 	test.LoadRepo(t, ctx, 1) | ||||
| 	test.LoadRepoCommit(t, ctx) | ||||
| 	test.LoadUser(t, ctx, 2) | ||||
| 	test.LoadGitRepo(t, ctx) | ||||
| 	defer ctx.Repo.GitRepo.Close() | ||||
| 
 | ||||
| 	repo := ctx.Repo.Repository | ||||
| 	doer := ctx.Doer | ||||
| 
 | ||||
| 	t.Run("Bad branch", func(t *testing.T) { | ||||
| 		opts := getDeleteRepoFileOptions(repo) | ||||
| 		opts.OldBranch = "bad_branch" | ||||
| 		fileResponse, err := files_service.DeleteRepoFile(git.DefaultContext, repo, doer, opts) | ||||
| 		assert.Error(t, err) | ||||
| 		assert.Nil(t, fileResponse) | ||||
| 		expectedError := "branch does not exist [name: " + opts.OldBranch + "]" | ||||
| 		assert.EqualError(t, err, expectedError) | ||||
| 	}) | ||||
| 
 | ||||
| 	t.Run("Bad SHA", func(t *testing.T) { | ||||
| 		opts := getDeleteRepoFileOptions(repo) | ||||
| 		origSHA := opts.SHA | ||||
| 		opts.SHA = "bad_sha" | ||||
| 		fileResponse, err := files_service.DeleteRepoFile(git.DefaultContext, repo, doer, opts) | ||||
| 		assert.Nil(t, fileResponse) | ||||
| 		assert.Error(t, err) | ||||
| 		expectedError := "sha does not match [given: " + opts.SHA + ", expected: " + origSHA + "]" | ||||
| 		assert.EqualError(t, err, expectedError) | ||||
| 	}) | ||||
| 
 | ||||
| 	t.Run("New branch already exists", func(t *testing.T) { | ||||
| 		opts := getDeleteRepoFileOptions(repo) | ||||
| 		opts.NewBranch = "develop" | ||||
| 		fileResponse, err := files_service.DeleteRepoFile(git.DefaultContext, repo, doer, opts) | ||||
| 		assert.Nil(t, fileResponse) | ||||
| 		assert.Error(t, err) | ||||
| 		expectedError := "branch already exists [name: " + opts.NewBranch + "]" | ||||
| 		assert.EqualError(t, err, expectedError) | ||||
| 	}) | ||||
| 
 | ||||
| 	t.Run("TreePath is empty:", func(t *testing.T) { | ||||
| 		opts := getDeleteRepoFileOptions(repo) | ||||
| 		opts.TreePath = "" | ||||
| 		fileResponse, err := files_service.DeleteRepoFile(git.DefaultContext, repo, doer, opts) | ||||
| 		assert.Nil(t, fileResponse) | ||||
| 		assert.Error(t, err) | ||||
| 		expectedError := "path contains a malformed path component [path: ]" | ||||
| 		assert.EqualError(t, err, expectedError) | ||||
| 	}) | ||||
| 
 | ||||
| 	t.Run("TreePath is a git directory:", func(t *testing.T) { | ||||
| 		opts := getDeleteRepoFileOptions(repo) | ||||
| 		opts.TreePath = ".git" | ||||
| 		fileResponse, err := files_service.DeleteRepoFile(git.DefaultContext, repo, doer, opts) | ||||
| 		assert.Nil(t, fileResponse) | ||||
| 		assert.Error(t, err) | ||||
| 		expectedError := "path contains a malformed path component [path: " + opts.TreePath + "]" | ||||
| 		assert.EqualError(t, err, expectedError) | ||||
| 	}) | ||||
| } | ||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue