mirror of
				https://github.com/go-gitea/gitea
				synced 2025-10-26 00:48:29 +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
		
			
				
	
	
		
			82 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			82 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| // Copyright 2018 The Gitea Authors. All rights reserved.
 | |
| // SPDX-License-Identifier: MIT
 | |
| 
 | |
| package repo
 | |
| 
 | |
| import (
 | |
| 	"testing"
 | |
| 
 | |
| 	"code.gitea.io/gitea/models/unittest"
 | |
| 	"code.gitea.io/gitea/modules/git"
 | |
| 	"code.gitea.io/gitea/modules/gitrepo"
 | |
| 	"code.gitea.io/gitea/services/contexttest"
 | |
| 
 | |
| 	"github.com/stretchr/testify/assert"
 | |
| )
 | |
| 
 | |
| func TestCleanUploadName(t *testing.T) {
 | |
| 	unittest.PrepareTestEnv(t)
 | |
| 
 | |
| 	kases := map[string]string{
 | |
| 		".git/refs/master":               "",
 | |
| 		"/root/abc":                      "root/abc",
 | |
| 		"./../../abc":                    "abc",
 | |
| 		"a/../.git":                      "",
 | |
| 		"a/../../../abc":                 "abc",
 | |
| 		"../../../acd":                   "acd",
 | |
| 		"../../.git/abc":                 "",
 | |
| 		"..\\..\\.git/abc":               "..\\..\\.git/abc",
 | |
| 		"..\\../.git/abc":                "",
 | |
| 		"..\\../.git":                    "",
 | |
| 		"abc/../def":                     "def",
 | |
| 		".drone.yml":                     ".drone.yml",
 | |
| 		".abc/def/.drone.yml":            ".abc/def/.drone.yml",
 | |
| 		"..drone.yml.":                   "..drone.yml.",
 | |
| 		"..a.dotty...name...":            "..a.dotty...name...",
 | |
| 		"..a.dotty../.folder../.name...": "..a.dotty../.folder../.name...",
 | |
| 	}
 | |
| 	for k, v := range kases {
 | |
| 		assert.EqualValues(t, cleanUploadFileName(k), v)
 | |
| 	}
 | |
| }
 | |
| 
 | |
| func TestGetUniquePatchBranchName(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()
 | |
| 
 | |
| 	expectedBranchName := "user2-patch-1"
 | |
| 	branchName := GetUniquePatchBranchName(ctx)
 | |
| 	assert.Equal(t, expectedBranchName, branchName)
 | |
| }
 | |
| 
 | |
| func TestGetClosestParentWithFiles(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
 | |
| 	gitRepo, _ := gitrepo.OpenRepository(git.DefaultContext, repo)
 | |
| 	defer gitRepo.Close()
 | |
| 	commit, _ := gitRepo.GetBranchCommit(branch)
 | |
| 	var expectedTreePath string // Should return the root dir, empty string, since there are no subdirs in this repo
 | |
| 	for _, deletedFile := range []string{
 | |
| 		"dir1/dir2/dir3/file.txt",
 | |
| 		"file.txt",
 | |
| 	} {
 | |
| 		treePath := GetClosestParentWithFiles(deletedFile, commit)
 | |
| 		assert.Equal(t, expectedTreePath, treePath)
 | |
| 	}
 | |
| }
 |