|
|
@ -0,0 +1,171 @@ |
|
|
|
// 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 repo |
|
|
|
|
|
|
|
import ( |
|
|
|
"io/ioutil" |
|
|
|
"net/http" |
|
|
|
"path/filepath" |
|
|
|
"testing" |
|
|
|
|
|
|
|
"code.gitea.io/gitea/models" |
|
|
|
"code.gitea.io/gitea/modules/auth" |
|
|
|
"code.gitea.io/gitea/modules/test" |
|
|
|
|
|
|
|
"github.com/Unknwon/com" |
|
|
|
"github.com/stretchr/testify/assert" |
|
|
|
) |
|
|
|
|
|
|
|
const content = "Wiki contents for unit tests" |
|
|
|
const message = "Wiki commit message for unit tests" |
|
|
|
|
|
|
|
func wikiPath(repo *models.Repository, wikiName string) string { |
|
|
|
return filepath.Join(repo.LocalWikiPath(), models.WikiNameToFilename(wikiName)) |
|
|
|
} |
|
|
|
|
|
|
|
func wikiContent(t *testing.T, repo *models.Repository, wikiName string) string { |
|
|
|
bytes, err := ioutil.ReadFile(wikiPath(repo, wikiName)) |
|
|
|
assert.NoError(t, err) |
|
|
|
return string(bytes) |
|
|
|
} |
|
|
|
|
|
|
|
func assertWikiExists(t *testing.T, repo *models.Repository, wikiName string) { |
|
|
|
assert.True(t, com.IsExist(wikiPath(repo, wikiName))) |
|
|
|
} |
|
|
|
|
|
|
|
func assertWikiNotExists(t *testing.T, repo *models.Repository, wikiName string) { |
|
|
|
assert.False(t, com.IsExist(wikiPath(repo, wikiName))) |
|
|
|
} |
|
|
|
|
|
|
|
func assertPagesMetas(t *testing.T, expectedNames []string, metas interface{}) { |
|
|
|
pageMetas, ok := metas.([]PageMeta) |
|
|
|
if !assert.True(t, ok) { |
|
|
|
return |
|
|
|
} |
|
|
|
if !assert.EqualValues(t, len(expectedNames), len(pageMetas)) { |
|
|
|
return |
|
|
|
} |
|
|
|
for i, pageMeta := range pageMetas { |
|
|
|
assert.EqualValues(t, expectedNames[i], pageMeta.Name) |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
func TestWiki(t *testing.T) { |
|
|
|
models.PrepareTestEnv(t) |
|
|
|
|
|
|
|
ctx := test.MockContext(t, "user2/repo1/wiki/_pages") |
|
|
|
ctx.SetParams(":page", "Home") |
|
|
|
test.LoadRepo(t, ctx, 1) |
|
|
|
Wiki(ctx) |
|
|
|
assert.EqualValues(t, http.StatusOK, ctx.Resp.Status()) |
|
|
|
assert.EqualValues(t, "Home", ctx.Data["Title"]) |
|
|
|
assertPagesMetas(t, []string{"Home"}, ctx.Data["Pages"]) |
|
|
|
} |
|
|
|
|
|
|
|
func TestWikiPages(t *testing.T) { |
|
|
|
models.PrepareTestEnv(t) |
|
|
|
|
|
|
|
ctx := test.MockContext(t, "user2/repo1/wiki/_pages") |
|
|
|
test.LoadRepo(t, ctx, 1) |
|
|
|
WikiPages(ctx) |
|
|
|
assert.EqualValues(t, http.StatusOK, ctx.Resp.Status()) |
|
|
|
assertPagesMetas(t, []string{"Home"}, ctx.Data["Pages"]) |
|
|
|
} |
|
|
|
|
|
|
|
func TestNewWiki(t *testing.T) { |
|
|
|
models.PrepareTestEnv(t) |
|
|
|
|
|
|
|
ctx := test.MockContext(t, "user2/repo1/wiki/_new") |
|
|
|
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", |
|
|
|
"&&&&", |
|
|
|
} { |
|
|
|
models.PrepareTestEnv(t) |
|
|
|
|
|
|
|
ctx := test.MockContext(t, "user2/repo1/wiki/_new") |
|
|
|
test.LoadUser(t, ctx, 2) |
|
|
|
test.LoadRepo(t, ctx, 1) |
|
|
|
NewWikiPost(ctx, auth.NewWikiForm{ |
|
|
|
Title: title, |
|
|
|
Content: content, |
|
|
|
Message: message, |
|
|
|
}) |
|
|
|
assert.EqualValues(t, http.StatusFound, ctx.Resp.Status()) |
|
|
|
assertWikiExists(t, ctx.Repo.Repository, title) |
|
|
|
assert.Equal(t, wikiContent(t, ctx.Repo.Repository, title), content) |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
func TestNewWikiPost_ReservedName(t *testing.T) { |
|
|
|
models.PrepareTestEnv(t) |
|
|
|
|
|
|
|
ctx := test.MockContext(t, "user2/repo1/wiki/_new") |
|
|
|
test.LoadUser(t, ctx, 2) |
|
|
|
test.LoadRepo(t, ctx, 1) |
|
|
|
NewWikiPost(ctx, auth.NewWikiForm{ |
|
|
|
Title: "_edit", |
|
|
|
Content: content, |
|
|
|
Message: message, |
|
|
|
}) |
|
|
|
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) { |
|
|
|
models.PrepareTestEnv(t) |
|
|
|
|
|
|
|
ctx := test.MockContext(t, "user2/repo1/wiki/_edit/Home") |
|
|
|
ctx.SetParams(":page", "Home") |
|
|
|
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>", |
|
|
|
} { |
|
|
|
models.PrepareTestEnv(t) |
|
|
|
ctx := test.MockContext(t, "user2/repo1/wiki/_new/Home") |
|
|
|
ctx.SetParams(":page", "Home") |
|
|
|
test.LoadUser(t, ctx, 2) |
|
|
|
test.LoadRepo(t, ctx, 1) |
|
|
|
EditWikiPost(ctx, auth.NewWikiForm{ |
|
|
|
Title: title, |
|
|
|
Content: content, |
|
|
|
Message: message, |
|
|
|
}) |
|
|
|
assert.EqualValues(t, http.StatusFound, ctx.Resp.Status()) |
|
|
|
assertWikiExists(t, ctx.Repo.Repository, title) |
|
|
|
assert.Equal(t, wikiContent(t, ctx.Repo.Repository, title), content) |
|
|
|
if title != "Home" { |
|
|
|
assertWikiNotExists(t, ctx.Repo.Repository, "Home") |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
func TestDeleteWikiPagePost(t *testing.T) { |
|
|
|
models.PrepareTestEnv(t) |
|
|
|
|
|
|
|
ctx := test.MockContext(t, "user2/repo1/wiki/Home/delete") |
|
|
|
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") |
|
|
|
} |