mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-11-04 15:04:30 +00: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)
 | 
						|
}
 |