mirror of
				https://gitee.com/gitea/gitea
				synced 2025-11-04 08:30:25 +08:00 
			
		
		
		
	* Add options to git.Clone to make it more capable * Begin the process of removing the local copy and tidy up * Remove Wiki LocalCopy Checkouts * Remove the last LocalRepo helpers * Remove WithTemporaryFile * Enable push-hooks for these routes * Ensure tests cope with hooks Signed-off-by: Andrew Thornton <art27@cantab.net> * Remove Repository.LocalCopyPath() * Move temporary repo to use the standard temporary path * Fix the tests Signed-off-by: Andrew Thornton <art27@cantab.net> * Remove LocalWikiPath * Fix missing remove Signed-off-by: Andrew Thornton <art27@cantab.net> * Use AppURL for Oauth user link (#6894) * Use AppURL for Oauth user link Fix #6843 * Update oauth.go * Update oauth.go * internal/ssh: ignore env command totally (#6825) * ssh: ignore env command totally * Remove commented code Needed fix described in issue #6889 * Escape the commit message on issues update and title in telegram hook (#6901) * update sdk to latest (#6903) * improve description of branch protection (fix #6886) (#6906) The branch protection description text were not quite accurate. * Fix logging documentation (#6904) * ENABLE_MACARON_REDIRECT should be REDIRECT_MACARON_LOG * Allow DISABLE_ROUTER_LOG to be set in the [log] section * [skip ci] Updated translations via Crowdin * Move sdk structs to modules/structs (#6905) * move sdk structs to moduels/structs * fix tests * fix fmt * fix swagger * fix vendor
		
			
				
	
	
		
			235 lines
		
	
	
		
			7.0 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			235 lines
		
	
	
		
			7.0 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
// Copyright 2017 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 models
 | 
						|
 | 
						|
import (
 | 
						|
	"path/filepath"
 | 
						|
	"testing"
 | 
						|
 | 
						|
	"code.gitea.io/gitea/modules/git"
 | 
						|
	"code.gitea.io/gitea/modules/setting"
 | 
						|
 | 
						|
	"github.com/stretchr/testify/assert"
 | 
						|
)
 | 
						|
 | 
						|
func TestNormalizeWikiName(t *testing.T) {
 | 
						|
	type test struct {
 | 
						|
		Expected string
 | 
						|
		WikiName string
 | 
						|
	}
 | 
						|
	for _, test := range []test{
 | 
						|
		{"wiki name", "wiki name"},
 | 
						|
		{"wiki name", "wiki-name"},
 | 
						|
		{"name with/slash", "name with/slash"},
 | 
						|
		{"name with%percent", "name-with%percent"},
 | 
						|
		{"%2F", "%2F"},
 | 
						|
	} {
 | 
						|
		assert.Equal(t, test.Expected, NormalizeWikiName(test.WikiName))
 | 
						|
	}
 | 
						|
}
 | 
						|
 | 
						|
func TestWikiNameToFilename(t *testing.T) {
 | 
						|
	type test struct {
 | 
						|
		Expected string
 | 
						|
		WikiName string
 | 
						|
	}
 | 
						|
	for _, test := range []test{
 | 
						|
		{"wiki-name.md", "wiki name"},
 | 
						|
		{"wiki-name.md", "wiki-name"},
 | 
						|
		{"name-with%2Fslash.md", "name with/slash"},
 | 
						|
		{"name-with%25percent.md", "name with%percent"},
 | 
						|
	} {
 | 
						|
		assert.Equal(t, test.Expected, WikiNameToFilename(test.WikiName))
 | 
						|
	}
 | 
						|
}
 | 
						|
 | 
						|
func TestWikiNameToSubURL(t *testing.T) {
 | 
						|
	type test struct {
 | 
						|
		Expected string
 | 
						|
		WikiName string
 | 
						|
	}
 | 
						|
	for _, test := range []test{
 | 
						|
		{"wiki-name", "wiki name"},
 | 
						|
		{"wiki-name", "wiki-name"},
 | 
						|
		{"name-with%2Fslash", "name with/slash"},
 | 
						|
		{"name-with%25percent", "name with%percent"},
 | 
						|
	} {
 | 
						|
		assert.Equal(t, test.Expected, WikiNameToSubURL(test.WikiName))
 | 
						|
	}
 | 
						|
}
 | 
						|
 | 
						|
func TestWikiFilenameToName(t *testing.T) {
 | 
						|
	type test struct {
 | 
						|
		Expected string
 | 
						|
		Filename string
 | 
						|
	}
 | 
						|
	for _, test := range []test{
 | 
						|
		{"hello world", "hello-world.md"},
 | 
						|
		{"symbols/?*", "symbols%2F%3F%2A.md"},
 | 
						|
	} {
 | 
						|
		name, err := WikiFilenameToName(test.Filename)
 | 
						|
		assert.NoError(t, err)
 | 
						|
		assert.Equal(t, test.Expected, name)
 | 
						|
	}
 | 
						|
	for _, badFilename := range []string{
 | 
						|
		"nofileextension",
 | 
						|
		"wrongfileextension.txt",
 | 
						|
	} {
 | 
						|
		_, err := WikiFilenameToName(badFilename)
 | 
						|
		assert.Error(t, err)
 | 
						|
		assert.True(t, IsErrWikiInvalidFileName(err))
 | 
						|
	}
 | 
						|
	_, err := WikiFilenameToName("badescaping%%.md")
 | 
						|
	assert.Error(t, err)
 | 
						|
	assert.False(t, IsErrWikiInvalidFileName(err))
 | 
						|
}
 | 
						|
 | 
						|
func TestWikiNameToFilenameToName(t *testing.T) {
 | 
						|
	// converting from wiki name to filename, then back to wiki name should
 | 
						|
	// return the original (normalized) name
 | 
						|
	for _, name := range []string{
 | 
						|
		"wiki-name",
 | 
						|
		"wiki name",
 | 
						|
		"wiki name with/slash",
 | 
						|
		"$$$%%%^^&&!@#$(),.<>",
 | 
						|
	} {
 | 
						|
		filename := WikiNameToFilename(name)
 | 
						|
		resultName, err := WikiFilenameToName(filename)
 | 
						|
		assert.NoError(t, err)
 | 
						|
		assert.Equal(t, NormalizeWikiName(name), resultName)
 | 
						|
	}
 | 
						|
}
 | 
						|
 | 
						|
func TestRepository_WikiCloneLink(t *testing.T) {
 | 
						|
	assert.NoError(t, PrepareTestDatabase())
 | 
						|
 | 
						|
	repo := AssertExistsAndLoadBean(t, &Repository{ID: 1}).(*Repository)
 | 
						|
	cloneLink := repo.WikiCloneLink()
 | 
						|
	assert.Equal(t, "ssh://runuser@try.gitea.io:3000/user2/repo1.wiki.git", cloneLink.SSH)
 | 
						|
	assert.Equal(t, "https://try.gitea.io/user2/repo1.wiki.git", cloneLink.HTTPS)
 | 
						|
}
 | 
						|
 | 
						|
func TestWikiPath(t *testing.T) {
 | 
						|
	assert.NoError(t, PrepareTestDatabase())
 | 
						|
	expected := filepath.Join(setting.RepoRootPath, "user2/repo1.wiki.git")
 | 
						|
	assert.Equal(t, expected, WikiPath("user2", "repo1"))
 | 
						|
}
 | 
						|
 | 
						|
func TestRepository_WikiPath(t *testing.T) {
 | 
						|
	assert.NoError(t, PrepareTestDatabase())
 | 
						|
	repo := AssertExistsAndLoadBean(t, &Repository{ID: 1}).(*Repository)
 | 
						|
	expected := filepath.Join(setting.RepoRootPath, "user2/repo1.wiki.git")
 | 
						|
	assert.Equal(t, expected, repo.WikiPath())
 | 
						|
}
 | 
						|
 | 
						|
func TestRepository_HasWiki(t *testing.T) {
 | 
						|
	PrepareTestEnv(t)
 | 
						|
	repo1 := AssertExistsAndLoadBean(t, &Repository{ID: 1}).(*Repository)
 | 
						|
	assert.True(t, repo1.HasWiki())
 | 
						|
	repo2 := AssertExistsAndLoadBean(t, &Repository{ID: 2}).(*Repository)
 | 
						|
	assert.False(t, repo2.HasWiki())
 | 
						|
}
 | 
						|
 | 
						|
func TestRepository_InitWiki(t *testing.T) {
 | 
						|
	PrepareTestEnv(t)
 | 
						|
	// repo1 already has a wiki
 | 
						|
	repo1 := AssertExistsAndLoadBean(t, &Repository{ID: 1}).(*Repository)
 | 
						|
	assert.NoError(t, repo1.InitWiki())
 | 
						|
 | 
						|
	// repo2 does not already have a wiki
 | 
						|
	repo2 := AssertExistsAndLoadBean(t, &Repository{ID: 2}).(*Repository)
 | 
						|
	assert.NoError(t, repo2.InitWiki())
 | 
						|
	assert.True(t, repo2.HasWiki())
 | 
						|
}
 | 
						|
 | 
						|
func TestRepository_AddWikiPage(t *testing.T) {
 | 
						|
	assert.NoError(t, PrepareTestDatabase())
 | 
						|
	const wikiContent = "This is the wiki content"
 | 
						|
	const commitMsg = "Commit message"
 | 
						|
	repo := AssertExistsAndLoadBean(t, &Repository{ID: 1}).(*Repository)
 | 
						|
	doer := AssertExistsAndLoadBean(t, &User{ID: 2}).(*User)
 | 
						|
	for _, wikiName := range []string{
 | 
						|
		"Another page",
 | 
						|
		"Here's a <tag> and a/slash",
 | 
						|
	} {
 | 
						|
		wikiName := wikiName
 | 
						|
		t.Run("test wiki exist: "+wikiName, func(t *testing.T) {
 | 
						|
			t.Parallel()
 | 
						|
			assert.NoError(t, repo.AddWikiPage(doer, wikiName, wikiContent, commitMsg))
 | 
						|
			// Now need to show that the page has been added:
 | 
						|
			gitRepo, err := git.OpenRepository(repo.WikiPath())
 | 
						|
			assert.NoError(t, err)
 | 
						|
			masterTree, err := gitRepo.GetTree("master")
 | 
						|
			assert.NoError(t, err)
 | 
						|
			wikiPath := WikiNameToFilename(wikiName)
 | 
						|
			entry, err := masterTree.GetTreeEntryByPath(wikiPath)
 | 
						|
			assert.NoError(t, err)
 | 
						|
			assert.Equal(t, wikiPath, entry.Name(), "%s not addded correctly", wikiName)
 | 
						|
		})
 | 
						|
	}
 | 
						|
 | 
						|
	t.Run("check wiki already exist", func(t *testing.T) {
 | 
						|
		t.Parallel()
 | 
						|
		// test for already-existing wiki name
 | 
						|
		err := repo.AddWikiPage(doer, "Home", wikiContent, commitMsg)
 | 
						|
		assert.Error(t, err)
 | 
						|
		assert.True(t, IsErrWikiAlreadyExist(err))
 | 
						|
	})
 | 
						|
 | 
						|
	t.Run("check wiki reserved name", func(t *testing.T) {
 | 
						|
		t.Parallel()
 | 
						|
		// test for reserved wiki name
 | 
						|
		err := repo.AddWikiPage(doer, "_edit", wikiContent, commitMsg)
 | 
						|
		assert.Error(t, err)
 | 
						|
		assert.True(t, IsErrWikiReservedName(err))
 | 
						|
	})
 | 
						|
}
 | 
						|
 | 
						|
func TestRepository_EditWikiPage(t *testing.T) {
 | 
						|
	const newWikiContent = "This is the new content"
 | 
						|
	const commitMsg = "Commit message"
 | 
						|
	repo := AssertExistsAndLoadBean(t, &Repository{ID: 1}).(*Repository)
 | 
						|
	doer := AssertExistsAndLoadBean(t, &User{ID: 2}).(*User)
 | 
						|
	for _, newWikiName := range []string{
 | 
						|
		"Home", // same name as before
 | 
						|
		"New home",
 | 
						|
		"New/name/with/slashes",
 | 
						|
	} {
 | 
						|
		PrepareTestEnv(t)
 | 
						|
		assert.NoError(t, repo.EditWikiPage(doer, "Home", newWikiName, newWikiContent, commitMsg))
 | 
						|
 | 
						|
		// Now need to show that the page has been added:
 | 
						|
		gitRepo, err := git.OpenRepository(repo.WikiPath())
 | 
						|
		assert.NoError(t, err)
 | 
						|
		masterTree, err := gitRepo.GetTree("master")
 | 
						|
		assert.NoError(t, err)
 | 
						|
		wikiPath := WikiNameToFilename(newWikiName)
 | 
						|
		entry, err := masterTree.GetTreeEntryByPath(wikiPath)
 | 
						|
		assert.NoError(t, err)
 | 
						|
		assert.Equal(t, wikiPath, entry.Name(), "%s not editted correctly", newWikiName)
 | 
						|
 | 
						|
		if newWikiName != "Home" {
 | 
						|
			_, err := masterTree.GetTreeEntryByPath("Home.md")
 | 
						|
			assert.Error(t, err)
 | 
						|
		}
 | 
						|
	}
 | 
						|
}
 | 
						|
 | 
						|
func TestRepository_DeleteWikiPage(t *testing.T) {
 | 
						|
	PrepareTestEnv(t)
 | 
						|
	repo := AssertExistsAndLoadBean(t, &Repository{ID: 1}).(*Repository)
 | 
						|
	doer := AssertExistsAndLoadBean(t, &User{ID: 2}).(*User)
 | 
						|
	assert.NoError(t, repo.DeleteWikiPage(doer, "Home"))
 | 
						|
 | 
						|
	// Now need to show that the page has been added:
 | 
						|
	gitRepo, err := git.OpenRepository(repo.WikiPath())
 | 
						|
	assert.NoError(t, err)
 | 
						|
	masterTree, err := gitRepo.GetTree("master")
 | 
						|
	assert.NoError(t, err)
 | 
						|
	wikiPath := WikiNameToFilename("Home")
 | 
						|
	_, err = masterTree.GetTreeEntryByPath(wikiPath)
 | 
						|
	assert.Error(t, err)
 | 
						|
}
 |