2017-12-01 00:52:15 +09:00
|
|
|
// Copyright 2017 The Gitea Authors. All rights reserved.
|
2022-11-28 03:20:29 +09:00
|
|
|
// SPDX-License-Identifier: MIT
|
2017-12-01 00:52:15 +09:00
|
|
|
|
|
|
|
package repo
|
|
|
|
|
|
|
|
import (
|
2021-09-22 14:38:34 +09:00
|
|
|
"io"
|
2017-12-01 00:52:15 +09:00
|
|
|
"net/http"
|
2023-04-20 02:50:10 +09:00
|
|
|
"net/url"
|
2017-12-01 00:52:15 +09:00
|
|
|
"testing"
|
|
|
|
|
2021-12-10 10:27:50 +09:00
|
|
|
repo_model "code.gitea.io/gitea/models/repo"
|
2021-11-12 23:36:47 +09:00
|
|
|
"code.gitea.io/gitea/models/unittest"
|
2019-03-27 18:33:00 +09:00
|
|
|
"code.gitea.io/gitea/modules/git"
|
2017-12-01 00:52:15 +09:00
|
|
|
"code.gitea.io/gitea/modules/test"
|
2021-01-27 00:36:53 +09:00
|
|
|
"code.gitea.io/gitea/modules/web"
|
2021-04-07 04:44:05 +09:00
|
|
|
"code.gitea.io/gitea/services/forms"
|
2020-01-08 03:27:36 +09:00
|
|
|
wiki_service "code.gitea.io/gitea/services/wiki"
|
2017-12-01 00:52:15 +09:00
|
|
|
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
|
|
)
|
|
|
|
|
2022-01-21 02:46:10 +09:00
|
|
|
const (
|
|
|
|
content = "Wiki contents for unit tests"
|
|
|
|
message = "Wiki commit message for unit tests"
|
|
|
|
)
|
2017-12-01 00:52:15 +09:00
|
|
|
|
2023-04-20 02:50:10 +09:00
|
|
|
func wikiEntry(t *testing.T, repo *repo_model.Repository, wikiName wiki_service.WebPath) *git.TreeEntry {
|
2022-03-30 04:13:41 +09:00
|
|
|
wikiRepo, err := git.OpenRepository(git.DefaultContext, repo.WikiPath())
|
2018-02-13 18:19:49 +09:00
|
|
|
assert.NoError(t, err)
|
2019-11-13 16:01:19 +09:00
|
|
|
defer wikiRepo.Close()
|
2018-02-13 18:19:49 +09:00
|
|
|
commit, err := wikiRepo.GetBranchCommit("master")
|
|
|
|
assert.NoError(t, err)
|
|
|
|
entries, err := commit.ListEntries()
|
|
|
|
assert.NoError(t, err)
|
|
|
|
for _, entry := range entries {
|
2023-04-20 02:50:10 +09:00
|
|
|
if entry.Name() == wiki_service.WebPathToGitPath(wikiName) {
|
2018-02-13 18:19:49 +09:00
|
|
|
return entry
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return nil
|
2017-12-01 00:52:15 +09:00
|
|
|
}
|
|
|
|
|
2023-04-20 02:50:10 +09:00
|
|
|
func wikiContent(t *testing.T, repo *repo_model.Repository, wikiName wiki_service.WebPath) string {
|
2018-02-13 18:19:49 +09:00
|
|
|
entry := wikiEntry(t, repo, wikiName)
|
|
|
|
if !assert.NotNil(t, entry) {
|
|
|
|
return ""
|
|
|
|
}
|
2019-04-19 21:17:27 +09:00
|
|
|
reader, err := entry.Blob().DataAsync()
|
2018-02-13 18:19:49 +09:00
|
|
|
assert.NoError(t, err)
|
2019-04-19 21:17:27 +09:00
|
|
|
defer reader.Close()
|
2021-09-22 14:38:34 +09:00
|
|
|
bytes, err := io.ReadAll(reader)
|
2017-12-01 00:52:15 +09:00
|
|
|
assert.NoError(t, err)
|
|
|
|
return string(bytes)
|
|
|
|
}
|
|
|
|
|
2023-04-20 02:50:10 +09:00
|
|
|
func assertWikiExists(t *testing.T, repo *repo_model.Repository, wikiName wiki_service.WebPath) {
|
2018-02-13 18:19:49 +09:00
|
|
|
assert.NotNil(t, wikiEntry(t, repo, wikiName))
|
2017-12-01 00:52:15 +09:00
|
|
|
}
|
|
|
|
|
2023-04-20 02:50:10 +09:00
|
|
|
func assertWikiNotExists(t *testing.T, repo *repo_model.Repository, wikiName wiki_service.WebPath) {
|
2018-02-13 18:19:49 +09:00
|
|
|
assert.Nil(t, wikiEntry(t, repo, wikiName))
|
2017-12-01 00:52:15 +09:00
|
|
|
}
|
|
|
|
|
2023-07-05 03:36:08 +09:00
|
|
|
func assertPagesMetas(t *testing.T, expectedNames []string, metas any) {
|
2017-12-01 00:52:15 +09:00
|
|
|
pageMetas, ok := metas.([]PageMeta)
|
|
|
|
if !assert.True(t, ok) {
|
|
|
|
return
|
|
|
|
}
|
2021-06-07 14:27:09 +09:00
|
|
|
if !assert.Len(t, pageMetas, len(expectedNames)) {
|
2017-12-01 00:52:15 +09:00
|
|
|
return
|
|
|
|
}
|
|
|
|
for i, pageMeta := range pageMetas {
|
|
|
|
assert.EqualValues(t, expectedNames[i], pageMeta.Name)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestWiki(t *testing.T) {
|
2021-11-12 23:36:47 +09:00
|
|
|
unittest.PrepareTestEnv(t)
|
2017-12-01 00:52:15 +09:00
|
|
|
|
2023-06-18 16:59:09 +09:00
|
|
|
ctx, _ := test.MockContext(t, "user2/repo1/wiki/?action=_pages")
|
2021-11-17 03:18:25 +09:00
|
|
|
ctx.SetParams("*", "Home")
|
2017-12-01 00:52:15 +09:00
|
|
|
test.LoadRepo(t, ctx, 1)
|
|
|
|
Wiki(ctx)
|
|
|
|
assert.EqualValues(t, http.StatusOK, ctx.Resp.Status())
|
|
|
|
assert.EqualValues(t, "Home", ctx.Data["Title"])
|
2021-07-20 22:16:20 +09:00
|
|
|
assertPagesMetas(t, []string{"Home", "Page With Image", "Page With Spaced Name", "Unescaped File"}, ctx.Data["Pages"])
|
2017-12-01 00:52:15 +09:00
|
|
|
}
|
|
|
|
|
|
|
|
func TestWikiPages(t *testing.T) {
|
2021-11-12 23:36:47 +09:00
|
|
|
unittest.PrepareTestEnv(t)
|
2017-12-01 00:52:15 +09:00
|
|
|
|
2023-06-18 16:59:09 +09:00
|
|
|
ctx, _ := test.MockContext(t, "user2/repo1/wiki/?action=_pages")
|
2017-12-01 00:52:15 +09:00
|
|
|
test.LoadRepo(t, ctx, 1)
|
|
|
|
WikiPages(ctx)
|
|
|
|
assert.EqualValues(t, http.StatusOK, ctx.Resp.Status())
|
2021-07-20 22:16:20 +09:00
|
|
|
assertPagesMetas(t, []string{"Home", "Page With Image", "Page With Spaced Name", "Unescaped File"}, ctx.Data["Pages"])
|
2017-12-01 00:52:15 +09:00
|
|
|
}
|
|
|
|
|
|
|
|
func TestNewWiki(t *testing.T) {
|
2021-11-12 23:36:47 +09:00
|
|
|
unittest.PrepareTestEnv(t)
|
2017-12-01 00:52:15 +09:00
|
|
|
|
2023-06-18 16:59:09 +09:00
|
|
|
ctx, _ := test.MockContext(t, "user2/repo1/wiki/?action=_new")
|
2017-12-01 00:52:15 +09:00
|
|
|
test.LoadUser(t, ctx, 2)
|
|
|
|
test.LoadRepo(t, ctx, 1)
|
|
|
|
NewWiki(ctx)
|
|
|
|
assert.EqualValues(t, http.StatusOK, ctx.Resp.Status())
|
|
|
|
assert.EqualValues(t, ctx.Tr("repo.wiki.new_page"), ctx.Data["Title"])
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestNewWikiPost(t *testing.T) {
|
|
|
|
for _, title := range []string{
|
|
|
|
"New page",
|
|
|
|
"&&&&",
|
|
|
|
} {
|
2021-11-12 23:36:47 +09:00
|
|
|
unittest.PrepareTestEnv(t)
|
2017-12-01 00:52:15 +09:00
|
|
|
|
2023-06-18 16:59:09 +09:00
|
|
|
ctx, _ := test.MockContext(t, "user2/repo1/wiki/?action=_new")
|
2017-12-01 00:52:15 +09:00
|
|
|
test.LoadUser(t, ctx, 2)
|
|
|
|
test.LoadRepo(t, ctx, 1)
|
2021-04-07 04:44:05 +09:00
|
|
|
web.SetForm(ctx, &forms.NewWikiForm{
|
2017-12-01 00:52:15 +09:00
|
|
|
Title: title,
|
|
|
|
Content: content,
|
|
|
|
Message: message,
|
|
|
|
})
|
2021-01-27 00:36:53 +09:00
|
|
|
NewWikiPost(ctx)
|
2022-03-23 13:54:07 +09:00
|
|
|
assert.EqualValues(t, http.StatusSeeOther, ctx.Resp.Status())
|
2023-04-20 02:50:10 +09:00
|
|
|
assertWikiExists(t, ctx.Repo.Repository, wiki_service.UserTitleToWebPath("", title))
|
|
|
|
assert.Equal(t, wikiContent(t, ctx.Repo.Repository, wiki_service.UserTitleToWebPath("", title)), content)
|
2017-12-01 00:52:15 +09:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestNewWikiPost_ReservedName(t *testing.T) {
|
2021-11-12 23:36:47 +09:00
|
|
|
unittest.PrepareTestEnv(t)
|
2017-12-01 00:52:15 +09:00
|
|
|
|
2023-06-18 16:59:09 +09:00
|
|
|
ctx, _ := test.MockContext(t, "user2/repo1/wiki/?action=_new")
|
2017-12-01 00:52:15 +09:00
|
|
|
test.LoadUser(t, ctx, 2)
|
|
|
|
test.LoadRepo(t, ctx, 1)
|
2021-04-07 04:44:05 +09:00
|
|
|
web.SetForm(ctx, &forms.NewWikiForm{
|
2017-12-01 00:52:15 +09:00
|
|
|
Title: "_edit",
|
|
|
|
Content: content,
|
|
|
|
Message: message,
|
|
|
|
})
|
2021-01-27 00:36:53 +09:00
|
|
|
NewWikiPost(ctx)
|
2017-12-01 00:52:15 +09:00
|
|
|
assert.EqualValues(t, http.StatusOK, ctx.Resp.Status())
|
|
|
|
assert.EqualValues(t, ctx.Tr("repo.wiki.reserved_page"), ctx.Flash.ErrorMsg)
|
|
|
|
assertWikiNotExists(t, ctx.Repo.Repository, "_edit")
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestEditWiki(t *testing.T) {
|
2021-11-12 23:36:47 +09:00
|
|
|
unittest.PrepareTestEnv(t)
|
2017-12-01 00:52:15 +09:00
|
|
|
|
2023-06-18 16:59:09 +09:00
|
|
|
ctx, _ := test.MockContext(t, "user2/repo1/wiki/Home?action=_edit")
|
2021-11-17 03:18:25 +09:00
|
|
|
ctx.SetParams("*", "Home")
|
2017-12-01 00:52:15 +09:00
|
|
|
test.LoadUser(t, ctx, 2)
|
|
|
|
test.LoadRepo(t, ctx, 1)
|
|
|
|
EditWiki(ctx)
|
|
|
|
assert.EqualValues(t, http.StatusOK, ctx.Resp.Status())
|
|
|
|
assert.EqualValues(t, "Home", ctx.Data["Title"])
|
|
|
|
assert.Equal(t, wikiContent(t, ctx.Repo.Repository, "Home"), ctx.Data["content"])
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestEditWikiPost(t *testing.T) {
|
|
|
|
for _, title := range []string{
|
|
|
|
"Home",
|
|
|
|
"New/<page>",
|
|
|
|
} {
|
2021-11-12 23:36:47 +09:00
|
|
|
unittest.PrepareTestEnv(t)
|
2023-06-18 16:59:09 +09:00
|
|
|
ctx, _ := test.MockContext(t, "user2/repo1/wiki/Home?action=_new")
|
2021-11-17 03:18:25 +09:00
|
|
|
ctx.SetParams("*", "Home")
|
2017-12-01 00:52:15 +09:00
|
|
|
test.LoadUser(t, ctx, 2)
|
|
|
|
test.LoadRepo(t, ctx, 1)
|
2021-04-07 04:44:05 +09:00
|
|
|
web.SetForm(ctx, &forms.NewWikiForm{
|
2017-12-01 00:52:15 +09:00
|
|
|
Title: title,
|
|
|
|
Content: content,
|
|
|
|
Message: message,
|
|
|
|
})
|
2021-01-27 00:36:53 +09:00
|
|
|
EditWikiPost(ctx)
|
2022-03-23 13:54:07 +09:00
|
|
|
assert.EqualValues(t, http.StatusSeeOther, ctx.Resp.Status())
|
2023-04-20 02:50:10 +09:00
|
|
|
assertWikiExists(t, ctx.Repo.Repository, wiki_service.UserTitleToWebPath("", title))
|
|
|
|
assert.Equal(t, wikiContent(t, ctx.Repo.Repository, wiki_service.UserTitleToWebPath("", title)), content)
|
2017-12-01 00:52:15 +09:00
|
|
|
if title != "Home" {
|
|
|
|
assertWikiNotExists(t, ctx.Repo.Repository, "Home")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestDeleteWikiPagePost(t *testing.T) {
|
2021-11-12 23:36:47 +09:00
|
|
|
unittest.PrepareTestEnv(t)
|
2017-12-01 00:52:15 +09:00
|
|
|
|
2023-06-18 16:59:09 +09:00
|
|
|
ctx, _ := test.MockContext(t, "user2/repo1/wiki/Home?action=_delete")
|
2017-12-01 00:52:15 +09:00
|
|
|
test.LoadUser(t, ctx, 2)
|
|
|
|
test.LoadRepo(t, ctx, 1)
|
|
|
|
DeleteWikiPagePost(ctx)
|
|
|
|
assert.EqualValues(t, http.StatusOK, ctx.Resp.Status())
|
|
|
|
assertWikiNotExists(t, ctx.Repo.Repository, "Home")
|
|
|
|
}
|
2019-02-06 10:58:55 +09:00
|
|
|
|
|
|
|
func TestWikiRaw(t *testing.T) {
|
|
|
|
for filepath, filetype := range map[string]string{
|
|
|
|
"jpeg.jpg": "image/jpeg",
|
2020-01-28 18:44:08 +09:00
|
|
|
"images/jpeg.jpg": "image/jpeg",
|
2019-02-06 10:58:55 +09:00
|
|
|
"Page With Spaced Name": "text/plain; charset=utf-8",
|
|
|
|
"Page-With-Spaced-Name": "text/plain; charset=utf-8",
|
2023-04-20 02:50:10 +09:00
|
|
|
"Page With Spaced Name.md": "", // there is no "Page With Spaced Name.md" in repo
|
2019-02-06 10:58:55 +09:00
|
|
|
"Page-With-Spaced-Name.md": "text/plain; charset=utf-8",
|
|
|
|
} {
|
2021-11-12 23:36:47 +09:00
|
|
|
unittest.PrepareTestEnv(t)
|
2019-02-06 10:58:55 +09:00
|
|
|
|
2023-06-18 16:59:09 +09:00
|
|
|
ctx, _ := test.MockContext(t, "user2/repo1/wiki/raw/"+url.PathEscape(filepath))
|
2019-02-06 10:58:55 +09:00
|
|
|
ctx.SetParams("*", filepath)
|
|
|
|
test.LoadUser(t, ctx, 2)
|
|
|
|
test.LoadRepo(t, ctx, 1)
|
|
|
|
WikiRaw(ctx)
|
2023-04-20 02:50:10 +09:00
|
|
|
if filetype == "" {
|
|
|
|
assert.EqualValues(t, http.StatusNotFound, ctx.Resp.Status(), "filepath: %s", filepath)
|
|
|
|
} else {
|
|
|
|
assert.EqualValues(t, http.StatusOK, ctx.Resp.Status(), "filepath: %s", filepath)
|
|
|
|
assert.EqualValues(t, filetype, ctx.Resp.Header().Get("Content-Type"), "filepath: %s", filepath)
|
|
|
|
}
|
2019-02-06 10:58:55 +09:00
|
|
|
}
|
|
|
|
}
|