mirror of
				https://codeberg.org/forgejo/forgejo.git
				synced 2025-10-25 11:33:11 +00:00 
			
		
		
		
	Since `modules/context` has to depend on `models` and many other packages, it should be moved from `modules/context` to `services/context` according to design principles. There is no logic code change on this PR, only move packages. - Move `code.gitea.io/gitea/modules/context` to `code.gitea.io/gitea/services/context` - Move `code.gitea.io/gitea/modules/contexttest` to `code.gitea.io/gitea/services/contexttest` because of depending on context - Move `code.gitea.io/gitea/modules/upload` to `code.gitea.io/gitea/services/context/upload` because of depending on context (cherry picked from commit 29f149bd9f517225a3c9f1ca3fb0a7b5325af696) Conflicts: routers/api/packages/alpine/alpine.go routers/api/v1/repo/issue_reaction.go routers/install/install.go routers/web/admin/config.go routers/web/passkey.go routers/web/repo/search.go routers/web/repo/setting/default_branch.go routers/web/user/home.go routers/web/user/profile.go tests/integration/editor_test.go tests/integration/integration_test.go tests/integration/mirror_push_test.go trivial context conflicts also modified all other occurrences in Forgejo specific files
		
			
				
	
	
		
			120 lines
		
	
	
	
		
			3.6 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			120 lines
		
	
	
	
		
			3.6 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| // Copyright 2019 The Gitea Authors. All rights reserved.
 | |
| // SPDX-License-Identifier: MIT
 | |
| 
 | |
| package files
 | |
| 
 | |
| import (
 | |
| 	"testing"
 | |
| 
 | |
| 	"code.gitea.io/gitea/models/unittest"
 | |
| 	"code.gitea.io/gitea/modules/gitrepo"
 | |
| 	"code.gitea.io/gitea/modules/setting"
 | |
| 	api "code.gitea.io/gitea/modules/structs"
 | |
| 	"code.gitea.io/gitea/services/contexttest"
 | |
| 
 | |
| 	"github.com/stretchr/testify/assert"
 | |
| )
 | |
| 
 | |
| func TestCleanUploadFileName(t *testing.T) {
 | |
| 	t.Run("Clean regular file", func(t *testing.T) {
 | |
| 		name := "this/is/test"
 | |
| 		cleanName := CleanUploadFileName(name)
 | |
| 		expectedCleanName := name
 | |
| 		assert.EqualValues(t, expectedCleanName, cleanName)
 | |
| 	})
 | |
| 
 | |
| 	t.Run("Clean a .git path", func(t *testing.T) {
 | |
| 		name := "this/is/test/.git"
 | |
| 		cleanName := CleanUploadFileName(name)
 | |
| 		expectedCleanName := ""
 | |
| 		assert.EqualValues(t, expectedCleanName, cleanName)
 | |
| 	})
 | |
| }
 | |
| 
 | |
| func getExpectedFileResponse() *api.FileResponse {
 | |
| 	treePath := "README.md"
 | |
| 	sha := "4b4851ad51df6a7d9f25c979345979eaeb5b349f"
 | |
| 	encoding := "base64"
 | |
| 	content := "IyByZXBvMQoKRGVzY3JpcHRpb24gZm9yIHJlcG8x"
 | |
| 	selfURL := setting.AppURL + "api/v1/repos/user2/repo1/contents/" + treePath + "?ref=master"
 | |
| 	htmlURL := setting.AppURL + "user2/repo1/src/branch/master/" + treePath
 | |
| 	gitURL := setting.AppURL + "api/v1/repos/user2/repo1/git/blobs/" + sha
 | |
| 	downloadURL := setting.AppURL + "user2/repo1/raw/branch/master/" + treePath
 | |
| 	return &api.FileResponse{
 | |
| 		Content: &api.ContentsResponse{
 | |
| 			Name:          treePath,
 | |
| 			Path:          treePath,
 | |
| 			SHA:           sha,
 | |
| 			LastCommitSHA: "65f1bf27bc3bf70f64657658635e66094edbcb4d",
 | |
| 			Type:          "file",
 | |
| 			Size:          30,
 | |
| 			Encoding:      &encoding,
 | |
| 			Content:       &content,
 | |
| 			URL:           &selfURL,
 | |
| 			HTMLURL:       &htmlURL,
 | |
| 			GitURL:        &gitURL,
 | |
| 			DownloadURL:   &downloadURL,
 | |
| 			Links: &api.FileLinksResponse{
 | |
| 				Self:    &selfURL,
 | |
| 				GitURL:  &gitURL,
 | |
| 				HTMLURL: &htmlURL,
 | |
| 			},
 | |
| 		},
 | |
| 		Commit: &api.FileCommitResponse{
 | |
| 			CommitMeta: api.CommitMeta{
 | |
| 				URL: "https://try.gitea.io/api/v1/repos/user2/repo1/git/commits/65f1bf27bc3bf70f64657658635e66094edbcb4d",
 | |
| 				SHA: "65f1bf27bc3bf70f64657658635e66094edbcb4d",
 | |
| 			},
 | |
| 			HTMLURL: "https://try.gitea.io/user2/repo1/commit/65f1bf27bc3bf70f64657658635e66094edbcb4d",
 | |
| 			Author: &api.CommitUser{
 | |
| 				Identity: api.Identity{
 | |
| 					Name:  "user1",
 | |
| 					Email: "address1@example.com",
 | |
| 				},
 | |
| 				Date: "2017-03-19T20:47:59Z",
 | |
| 			},
 | |
| 			Committer: &api.CommitUser{
 | |
| 				Identity: api.Identity{
 | |
| 					Name:  "Ethan Koenig",
 | |
| 					Email: "ethantkoenig@gmail.com",
 | |
| 				},
 | |
| 				Date: "2017-03-19T20:47:59Z",
 | |
| 			},
 | |
| 			Parents: []*api.CommitMeta{},
 | |
| 			Message: "Initial commit\n",
 | |
| 			Tree: &api.CommitMeta{
 | |
| 				URL: "https://try.gitea.io/api/v1/repos/user2/repo1/git/trees/2a2f1d4670728a2e10049e345bd7a276468beab6",
 | |
| 				SHA: "2a2f1d4670728a2e10049e345bd7a276468beab6",
 | |
| 			},
 | |
| 		},
 | |
| 		Verification: &api.PayloadCommitVerification{
 | |
| 			Verified:  false,
 | |
| 			Reason:    "gpg.error.not_signed_commit",
 | |
| 			Signature: "",
 | |
| 			Payload:   "",
 | |
| 		},
 | |
| 	}
 | |
| }
 | |
| 
 | |
| func TestGetFileResponseFromCommit(t *testing.T) {
 | |
| 	unittest.PrepareTestEnv(t)
 | |
| 	ctx, _ := contexttest.MockContext(t, "user2/repo1")
 | |
| 	ctx.SetParams(":id", "1")
 | |
| 	contexttest.LoadRepo(t, ctx, 1)
 | |
| 	contexttest.LoadRepoCommit(t, ctx)
 | |
| 	contexttest.LoadUser(t, ctx, 2)
 | |
| 	contexttest.LoadGitRepo(t, ctx)
 | |
| 	defer ctx.Repo.GitRepo.Close()
 | |
| 
 | |
| 	repo := ctx.Repo.Repository
 | |
| 	branch := repo.DefaultBranch
 | |
| 	treePath := "README.md"
 | |
| 	gitRepo, _ := gitrepo.OpenRepository(ctx, repo)
 | |
| 	defer gitRepo.Close()
 | |
| 	commit, _ := gitRepo.GetBranchCommit(branch)
 | |
| 	expectedFileResponse := getExpectedFileResponse()
 | |
| 
 | |
| 	fileResponse, err := GetFileResponseFromCommit(ctx, repo, commit, branch, treePath)
 | |
| 	assert.NoError(t, err)
 | |
| 	assert.EqualValues(t, expectedFileResponse, fileResponse)
 | |
| }
 |