- // 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)
- }
|