aboutsummaryrefslogtreecommitdiffstats
path: root/services/repository/files/content_test.go
diff options
context:
space:
mode:
Diffstat (limited to 'services/repository/files/content_test.go')
-rw-r--r--services/repository/files/content_test.go74
1 files changed, 1 insertions, 73 deletions
diff --git a/services/repository/files/content_test.go b/services/repository/files/content_test.go
index 9357c52ea8..d72f918074 100644
--- a/services/repository/files/content_test.go
+++ b/services/repository/files/content_test.go
@@ -5,56 +5,21 @@ package files
import (
"testing"
- "time"
"code.gitea.io/gitea/models/unittest"
api "code.gitea.io/gitea/modules/structs"
"code.gitea.io/gitea/modules/util"
- "code.gitea.io/gitea/routers/api/v1/utils"
"code.gitea.io/gitea/services/contexttest"
_ "code.gitea.io/gitea/models/actions"
"github.com/stretchr/testify/assert"
- "github.com/stretchr/testify/require"
)
func TestMain(m *testing.M) {
unittest.MainTest(m)
}
-func getExpectedReadmeContentsResponse() *api.ContentsResponse {
- treePath := "README.md"
- sha := "4b4851ad51df6a7d9f25c979345979eaeb5b349f"
- encoding := "base64"
- content := "IyByZXBvMQoKRGVzY3JpcHRpb24gZm9yIHJlcG8x"
- selfURL := "https://try.gitea.io/api/v1/repos/user2/repo1/contents/" + treePath + "?ref=master"
- htmlURL := "https://try.gitea.io/user2/repo1/src/branch/master/" + treePath
- gitURL := "https://try.gitea.io/api/v1/repos/user2/repo1/git/blobs/" + sha
- downloadURL := "https://try.gitea.io/user2/repo1/raw/branch/master/" + treePath
- return &api.ContentsResponse{
- Name: treePath,
- Path: treePath,
- SHA: "4b4851ad51df6a7d9f25c979345979eaeb5b349f",
- LastCommitSHA: "65f1bf27bc3bf70f64657658635e66094edbcb4d",
- LastCommitterDate: time.Date(2017, time.March, 19, 16, 47, 59, 0, time.FixedZone("", -14400)),
- LastAuthorDate: time.Date(2017, time.March, 19, 16, 47, 59, 0, time.FixedZone("", -14400)),
- Type: "file",
- Size: 30,
- Encoding: &encoding,
- Content: &content,
- URL: &selfURL,
- HTMLURL: &htmlURL,
- GitURL: &gitURL,
- DownloadURL: &downloadURL,
- Links: &api.FileLinksResponse{
- Self: &selfURL,
- GitURL: &gitURL,
- HTMLURL: &htmlURL,
- },
- }
-}
-
func TestGetContents(t *testing.T) {
unittest.PrepareTestEnv(t)
ctx, _ := contexttest.MockContext(t, "user2/repo1")
@@ -63,45 +28,8 @@ func TestGetContents(t *testing.T) {
contexttest.LoadRepoCommit(t, ctx)
contexttest.LoadUser(t, ctx, 2)
contexttest.LoadGitRepo(t, ctx)
- defer ctx.Repo.GitRepo.Close()
- repo, gitRepo := ctx.Repo.Repository, ctx.Repo.GitRepo
- refCommit, err := utils.ResolveRefCommit(ctx, ctx.Repo.Repository, ctx.Repo.Repository.DefaultBranch)
- require.NoError(t, err)
-
- t.Run("GetContentsOrList(README.md)-MetaOnly", func(t *testing.T) {
- expectedContentsResponse := getExpectedReadmeContentsResponse()
- expectedContentsResponse.Encoding = nil // because will be in a list, doesn't have encoding and content
- expectedContentsResponse.Content = nil
- extResp, err := GetContentsOrList(ctx, repo, gitRepo, refCommit, GetContentsOrListOptions{TreePath: "README.md", IncludeSingleFileContent: false})
- assert.Equal(t, expectedContentsResponse, extResp.FileContents)
- assert.NoError(t, err)
- })
-
- t.Run("GetContentsOrList(README.md)", func(t *testing.T) {
- expectedContentsResponse := getExpectedReadmeContentsResponse()
- extResp, err := GetContentsOrList(ctx, repo, gitRepo, refCommit, GetContentsOrListOptions{TreePath: "README.md", IncludeSingleFileContent: true})
- assert.Equal(t, expectedContentsResponse, extResp.FileContents)
- assert.NoError(t, err)
- })
-
- t.Run("GetContentsOrList(RootDir)", func(t *testing.T) {
- readmeContentsResponse := getExpectedReadmeContentsResponse()
- readmeContentsResponse.Encoding = nil // because will be in a list, doesn't have encoding and content
- readmeContentsResponse.Content = nil
- expectedContentsListResponse := []*api.ContentsResponse{readmeContentsResponse}
- // even if IncludeFileContent is true, it has no effect for directory listing
- extResp, err := GetContentsOrList(ctx, repo, gitRepo, refCommit, GetContentsOrListOptions{TreePath: "", IncludeSingleFileContent: true})
- assert.Equal(t, expectedContentsListResponse, extResp.DirContents)
- assert.NoError(t, err)
- })
- t.Run("GetContentsOrList(NoSuchTreePath)", func(t *testing.T) {
- extResp, err := GetContentsOrList(ctx, repo, gitRepo, refCommit, GetContentsOrListOptions{TreePath: "no-such/file.md"})
- assert.Error(t, err)
- assert.EqualError(t, err, "object does not exist [id: , rel_path: no-such]")
- assert.Nil(t, extResp.DirContents)
- assert.Nil(t, extResp.FileContents)
- })
+ // GetContentsOrList's behavior is fully tested in integration tests, so we don't need to test it here.
t.Run("GetBlobBySHA", func(t *testing.T) {
sha := "65f1bf27bc3bf70f64657658635e66094edbcb4d"