mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-10-26 09:24:34 -04:00 
			
		
		
		
	1. `StatDir` was not right, fix the FIXME 2. Clarify the test cases for `IsUsableRepoName` 3. Fix regression bug in `repo-new.ts` Fix #33060
		
			
				
	
	
		
			233 lines
		
	
	
		
			5.1 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			233 lines
		
	
	
		
			5.1 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| // Copyright 2021 The Gitea Authors. All rights reserved.
 | |
| // SPDX-License-Identifier: MIT
 | |
| 
 | |
| package util
 | |
| 
 | |
| import (
 | |
| 	"net/url"
 | |
| 	"os"
 | |
| 	"runtime"
 | |
| 	"testing"
 | |
| 
 | |
| 	"github.com/stretchr/testify/assert"
 | |
| 	"github.com/stretchr/testify/require"
 | |
| )
 | |
| 
 | |
| func TestFileURLToPath(t *testing.T) {
 | |
| 	cases := []struct {
 | |
| 		url      string
 | |
| 		expected string
 | |
| 		haserror bool
 | |
| 		windows  bool
 | |
| 	}{
 | |
| 		// case 0
 | |
| 		{
 | |
| 			url:      "",
 | |
| 			haserror: true,
 | |
| 		},
 | |
| 		// case 1
 | |
| 		{
 | |
| 			url:      "http://test.io",
 | |
| 			haserror: true,
 | |
| 		},
 | |
| 		// case 2
 | |
| 		{
 | |
| 			url:      "file:///path",
 | |
| 			expected: "/path",
 | |
| 		},
 | |
| 		// case 3
 | |
| 		{
 | |
| 			url:      "file:///C:/path",
 | |
| 			expected: "C:/path",
 | |
| 			windows:  true,
 | |
| 		},
 | |
| 	}
 | |
| 
 | |
| 	for n, c := range cases {
 | |
| 		if c.windows && runtime.GOOS != "windows" {
 | |
| 			continue
 | |
| 		}
 | |
| 		u, _ := url.Parse(c.url)
 | |
| 		p, err := FileURLToPath(u)
 | |
| 		if c.haserror {
 | |
| 			assert.Error(t, err, "case %d: should return error", n)
 | |
| 		} else {
 | |
| 			assert.NoError(t, err, "case %d: should not return error", n)
 | |
| 			assert.Equal(t, c.expected, p, "case %d: should be equal", n)
 | |
| 		}
 | |
| 	}
 | |
| }
 | |
| 
 | |
| func TestMisc_IsReadmeFileName(t *testing.T) {
 | |
| 	trueTestCases := []string{
 | |
| 		"readme",
 | |
| 		"README",
 | |
| 		"readME.mdown",
 | |
| 		"README.md",
 | |
| 		"readme.i18n.md",
 | |
| 	}
 | |
| 	falseTestCases := []string{
 | |
| 		"test.md",
 | |
| 		"wow.MARKDOWN",
 | |
| 		"LOL.mDoWn",
 | |
| 		"test",
 | |
| 		"abcdefg",
 | |
| 		"abcdefghijklmnopqrstuvwxyz",
 | |
| 		"test.md.test",
 | |
| 		"readmf",
 | |
| 	}
 | |
| 
 | |
| 	for _, testCase := range trueTestCases {
 | |
| 		assert.True(t, IsReadmeFileName(testCase))
 | |
| 	}
 | |
| 	for _, testCase := range falseTestCases {
 | |
| 		assert.False(t, IsReadmeFileName(testCase))
 | |
| 	}
 | |
| 
 | |
| 	type extensionTestcase struct {
 | |
| 		name     string
 | |
| 		expected bool
 | |
| 		idx      int
 | |
| 	}
 | |
| 
 | |
| 	exts := []string{".md", ".txt", ""}
 | |
| 	testCasesExtensions := []extensionTestcase{
 | |
| 		{
 | |
| 			name:     "readme",
 | |
| 			expected: true,
 | |
| 			idx:      2,
 | |
| 		},
 | |
| 		{
 | |
| 			name:     "readme.md",
 | |
| 			expected: true,
 | |
| 			idx:      0,
 | |
| 		},
 | |
| 		{
 | |
| 			name:     "README.md",
 | |
| 			expected: true,
 | |
| 			idx:      0,
 | |
| 		},
 | |
| 		{
 | |
| 			name:     "ReAdMe.Md",
 | |
| 			expected: true,
 | |
| 			idx:      0,
 | |
| 		},
 | |
| 		{
 | |
| 			name:     "readme.txt",
 | |
| 			expected: true,
 | |
| 			idx:      1,
 | |
| 		},
 | |
| 		{
 | |
| 			name:     "readme.doc",
 | |
| 			expected: true,
 | |
| 			idx:      3,
 | |
| 		},
 | |
| 		{
 | |
| 			name: "readmee.md",
 | |
| 		},
 | |
| 		{
 | |
| 			name:     "readme..",
 | |
| 			expected: true,
 | |
| 			idx:      3,
 | |
| 		},
 | |
| 	}
 | |
| 
 | |
| 	for _, testCase := range testCasesExtensions {
 | |
| 		idx, ok := IsReadmeFileExtension(testCase.name, exts...)
 | |
| 		assert.Equal(t, testCase.expected, ok)
 | |
| 		assert.Equal(t, testCase.idx, idx)
 | |
| 	}
 | |
| }
 | |
| 
 | |
| func TestCleanPath(t *testing.T) {
 | |
| 	cases := []struct {
 | |
| 		elems    []string
 | |
| 		expected string
 | |
| 	}{
 | |
| 		{[]string{}, ``},
 | |
| 		{[]string{``}, ``},
 | |
| 		{[]string{`..`}, `.`},
 | |
| 		{[]string{`a`}, `a`},
 | |
| 		{[]string{`/a/`}, `a`},
 | |
| 		{[]string{`../a/`, `../b`, `c/..`, `d`}, `a/b/d`},
 | |
| 		{[]string{`a\..\b`}, `a\..\b`},
 | |
| 		{[]string{`a`, ``, `b`}, `a/b`},
 | |
| 		{[]string{`a`, `..`, `b`}, `a/b`},
 | |
| 		{[]string{`lfs`, `repo/..`, `user/../path`}, `lfs/path`},
 | |
| 	}
 | |
| 	for _, c := range cases {
 | |
| 		assert.Equal(t, c.expected, PathJoinRel(c.elems...), "case: %v", c.elems)
 | |
| 	}
 | |
| 
 | |
| 	cases = []struct {
 | |
| 		elems    []string
 | |
| 		expected string
 | |
| 	}{
 | |
| 		{[]string{}, ``},
 | |
| 		{[]string{``}, ``},
 | |
| 		{[]string{`..`}, `.`},
 | |
| 		{[]string{`a`}, `a`},
 | |
| 		{[]string{`/a/`}, `a`},
 | |
| 		{[]string{`../a/`, `../b`, `c/..`, `d`}, `a/b/d`},
 | |
| 		{[]string{`a\..\b`}, `b`},
 | |
| 		{[]string{`a`, ``, `b`}, `a/b`},
 | |
| 		{[]string{`a`, `..`, `b`}, `a/b`},
 | |
| 		{[]string{`lfs`, `repo/..`, `user/../path`}, `lfs/path`},
 | |
| 	}
 | |
| 	for _, c := range cases {
 | |
| 		assert.Equal(t, c.expected, PathJoinRelX(c.elems...), "case: %v", c.elems)
 | |
| 	}
 | |
| 
 | |
| 	// for POSIX only, but the result is similar on Windows, because the first element must be an absolute path
 | |
| 	if isOSWindows() {
 | |
| 		cases = []struct {
 | |
| 			elems    []string
 | |
| 			expected string
 | |
| 		}{
 | |
| 			{[]string{`C:\..`}, `C:\`},
 | |
| 			{[]string{`C:\a`}, `C:\a`},
 | |
| 			{[]string{`C:\a/`}, `C:\a`},
 | |
| 			{[]string{`C:\..\a\`, `../b`, `c\..`, `d`}, `C:\a\b\d`},
 | |
| 			{[]string{`C:\a/..\b`}, `C:\b`},
 | |
| 			{[]string{`C:\a`, ``, `b`}, `C:\a\b`},
 | |
| 			{[]string{`C:\a`, `..`, `b`}, `C:\a\b`},
 | |
| 			{[]string{`C:\lfs`, `repo/..`, `user/../path`}, `C:\lfs\path`},
 | |
| 		}
 | |
| 	} else {
 | |
| 		cases = []struct {
 | |
| 			elems    []string
 | |
| 			expected string
 | |
| 		}{
 | |
| 			{[]string{`/..`}, `/`},
 | |
| 			{[]string{`/a`}, `/a`},
 | |
| 			{[]string{`/a/`}, `/a`},
 | |
| 			{[]string{`/../a/`, `../b`, `c/..`, `d`}, `/a/b/d`},
 | |
| 			{[]string{`/a\..\b`}, `/b`},
 | |
| 			{[]string{`/a`, ``, `b`}, `/a/b`},
 | |
| 			{[]string{`/a`, `..`, `b`}, `/a/b`},
 | |
| 			{[]string{`/lfs`, `repo/..`, `user/../path`}, `/lfs/path`},
 | |
| 		}
 | |
| 	}
 | |
| 	for _, c := range cases {
 | |
| 		assert.Equal(t, c.expected, FilePathJoinAbs(c.elems[0], c.elems[1:]...), "case: %v", c.elems)
 | |
| 	}
 | |
| }
 | |
| 
 | |
| func TestListDirRecursively(t *testing.T) {
 | |
| 	tmpDir := t.TempDir()
 | |
| 	_ = os.WriteFile(tmpDir+"/.config", nil, 0o644)
 | |
| 	_ = os.Mkdir(tmpDir+"/d1", 0o755)
 | |
| 	_ = os.WriteFile(tmpDir+"/d1/f-d1", nil, 0o644)
 | |
| 	_ = os.Mkdir(tmpDir+"/d1/s1", 0o755)
 | |
| 	_ = os.WriteFile(tmpDir+"/d1/s1/f-d1s1", nil, 0o644)
 | |
| 	_ = os.Mkdir(tmpDir+"/d2", 0o755)
 | |
| 
 | |
| 	res, err := ListDirRecursively(tmpDir, &ListDirOptions{IncludeDir: true})
 | |
| 	require.NoError(t, err)
 | |
| 	assert.ElementsMatch(t, []string{".config", "d1/", "d1/f-d1", "d1/s1/", "d1/s1/f-d1s1", "d2/"}, res)
 | |
| 
 | |
| 	res, err = ListDirRecursively(tmpDir, &ListDirOptions{SkipCommonHiddenNames: true})
 | |
| 	require.NoError(t, err)
 | |
| 	assert.ElementsMatch(t, []string{"d1/f-d1", "d1/s1/f-d1s1"}, res)
 | |
| }
 |