mirror of
https://github.com/go-gitea/gitea.git
synced 2026-05-22 08:33:07 +02:00
tests/integration: simplify code (#37249)
Co-authored-by: copilot-swe-agent[bot] <198982749+Copilot@users.noreply.github.com> Co-authored-by: wxiaoguang <2114189+wxiaoguang@users.noreply.github.com> Co-authored-by: wxiaoguang <wxiaoguang@gmail.com> Co-authored-by: silverwind <me@silverwind.io> Co-authored-by: Claude (Opus 4.7) <noreply@anthropic.com>
This commit is contained in:
parent
dc974715e9
commit
eb334e3738
@ -5,6 +5,7 @@ package test
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"archive/tar"
|
"archive/tar"
|
||||||
|
"archive/zip"
|
||||||
"bytes"
|
"bytes"
|
||||||
"compress/gzip"
|
"compress/gzip"
|
||||||
"io"
|
"io"
|
||||||
@ -97,6 +98,17 @@ func WriteTarArchive(files map[string]string) *bytes.Buffer {
|
|||||||
return WriteTarCompression(func(w io.Writer) io.WriteCloser { return util.NopCloser{Writer: w} }, files)
|
return WriteTarCompression(func(w io.Writer) io.WriteCloser { return util.NopCloser{Writer: w} }, files)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func WriteZipArchive(files map[string]string) *bytes.Buffer {
|
||||||
|
buf := &bytes.Buffer{}
|
||||||
|
zw := zip.NewWriter(buf)
|
||||||
|
for name, content := range files {
|
||||||
|
w, _ := zw.Create(name)
|
||||||
|
_, _ = w.Write([]byte(content))
|
||||||
|
}
|
||||||
|
_ = zw.Close()
|
||||||
|
return buf
|
||||||
|
}
|
||||||
|
|
||||||
func WriteTarCompression[F func(io.Writer) io.WriteCloser | func(io.Writer) (io.WriteCloser, error)](compression F, files map[string]string) *bytes.Buffer {
|
func WriteTarCompression[F func(io.Writer) io.WriteCloser | func(io.Writer) (io.WriteCloser, error)](compression F, files map[string]string) *bytes.Buffer {
|
||||||
buf := &bytes.Buffer{}
|
buf := &bytes.Buffer{}
|
||||||
var cw io.WriteCloser
|
var cw io.WriteCloser
|
||||||
|
|||||||
@ -40,8 +40,7 @@ func testAPICreateOAuth2Application(t *testing.T) {
|
|||||||
AddBasicAuth(user.Name)
|
AddBasicAuth(user.Name)
|
||||||
resp := MakeRequest(t, req, http.StatusCreated)
|
resp := MakeRequest(t, req, http.StatusCreated)
|
||||||
|
|
||||||
var createdApp *api.OAuth2Application
|
createdApp := DecodeJSON(t, resp, &api.OAuth2Application{})
|
||||||
DecodeJSON(t, resp, &createdApp)
|
|
||||||
|
|
||||||
assert.Equal(t, appBody.Name, createdApp.Name)
|
assert.Equal(t, appBody.Name, createdApp.Name)
|
||||||
assert.Len(t, createdApp.ClientSecret, 56)
|
assert.Len(t, createdApp.ClientSecret, 56)
|
||||||
|
|||||||
@ -4,7 +4,6 @@
|
|||||||
package integration
|
package integration
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"archive/zip"
|
|
||||||
"bytes"
|
"bytes"
|
||||||
"fmt"
|
"fmt"
|
||||||
"net/http"
|
"net/http"
|
||||||
@ -17,6 +16,7 @@ import (
|
|||||||
user_model "code.gitea.io/gitea/models/user"
|
user_model "code.gitea.io/gitea/models/user"
|
||||||
composer_module "code.gitea.io/gitea/modules/packages/composer"
|
composer_module "code.gitea.io/gitea/modules/packages/composer"
|
||||||
"code.gitea.io/gitea/modules/setting"
|
"code.gitea.io/gitea/modules/setting"
|
||||||
|
"code.gitea.io/gitea/modules/test"
|
||||||
"code.gitea.io/gitea/routers/api/packages/composer"
|
"code.gitea.io/gitea/routers/api/packages/composer"
|
||||||
"code.gitea.io/gitea/tests"
|
"code.gitea.io/gitea/tests"
|
||||||
|
|
||||||
@ -38,10 +38,8 @@ func TestPackageComposer(t *testing.T) {
|
|||||||
packageLicense := "MIT"
|
packageLicense := "MIT"
|
||||||
packageBin := "./bin/script"
|
packageBin := "./bin/script"
|
||||||
|
|
||||||
var buf bytes.Buffer
|
content := test.WriteZipArchive(map[string]string{
|
||||||
archive := zip.NewWriter(&buf)
|
"composer.json": `{
|
||||||
w, _ := archive.Create("composer.json")
|
|
||||||
w.Write([]byte(`{
|
|
||||||
"name": "` + packageName + `",
|
"name": "` + packageName + `",
|
||||||
"description": "` + packageDescription + `",
|
"description": "` + packageDescription + `",
|
||||||
"type": "` + packageType + `",
|
"type": "` + packageType + `",
|
||||||
@ -54,9 +52,8 @@ func TestPackageComposer(t *testing.T) {
|
|||||||
"bin": [
|
"bin": [
|
||||||
"` + packageBin + `"
|
"` + packageBin + `"
|
||||||
]
|
]
|
||||||
}`))
|
}`,
|
||||||
archive.Close()
|
}).Bytes()
|
||||||
content := buf.Bytes()
|
|
||||||
|
|
||||||
url := fmt.Sprintf("%sapi/packages/%s/composer", setting.AppURL, user.Name)
|
url := fmt.Sprintf("%sapi/packages/%s/composer", setting.AppURL, user.Name)
|
||||||
|
|
||||||
|
|||||||
@ -158,6 +158,10 @@ func uploadConanPackageV1(t *testing.T, baseURL, token, name, version, user, cha
|
|||||||
}
|
}
|
||||||
|
|
||||||
func uploadConanPackageV2(t *testing.T, baseURL, token, name, version, user, channel, recipeRevision, packageRevision string) {
|
func uploadConanPackageV2(t *testing.T, baseURL, token, name, version, user, channel, recipeRevision, packageRevision string) {
|
||||||
|
type fileList struct {
|
||||||
|
Files map[string]any `json:"files"`
|
||||||
|
}
|
||||||
|
|
||||||
contentConanfile := buildConanfileContent(name, version)
|
contentConanfile := buildConanfileContent(name, version)
|
||||||
|
|
||||||
recipeURL := fmt.Sprintf("%s/v2/conans/%s/%s/%s/%s/revisions/%s", baseURL, name, version, user, channel, recipeRevision)
|
recipeURL := fmt.Sprintf("%s/v2/conans/%s/%s/%s/%s/revisions/%s", baseURL, name, version, user, channel, recipeRevision)
|
||||||
@ -170,10 +174,7 @@ func uploadConanPackageV2(t *testing.T, baseURL, token, name, version, user, cha
|
|||||||
AddTokenAuth(token)
|
AddTokenAuth(token)
|
||||||
resp := MakeRequest(t, req, http.StatusOK)
|
resp := MakeRequest(t, req, http.StatusOK)
|
||||||
|
|
||||||
var list *struct {
|
list := DecodeJSON(t, resp, &fileList{})
|
||||||
Files map[string]any `json:"files"`
|
|
||||||
}
|
|
||||||
DecodeJSON(t, resp, &list)
|
|
||||||
assert.Len(t, list.Files, 1)
|
assert.Len(t, list.Files, 1)
|
||||||
assert.Contains(t, list.Files, conanfileName)
|
assert.Contains(t, list.Files, conanfileName)
|
||||||
|
|
||||||
@ -191,8 +192,7 @@ func uploadConanPackageV2(t *testing.T, baseURL, token, name, version, user, cha
|
|||||||
AddTokenAuth(token)
|
AddTokenAuth(token)
|
||||||
resp = MakeRequest(t, req, http.StatusOK)
|
resp = MakeRequest(t, req, http.StatusOK)
|
||||||
|
|
||||||
list = nil
|
list = DecodeJSON(t, resp, &fileList{})
|
||||||
DecodeJSON(t, resp, &list)
|
|
||||||
assert.Len(t, list.Files, 1)
|
assert.Len(t, list.Files, 1)
|
||||||
assert.Contains(t, list.Files, conaninfoName)
|
assert.Contains(t, list.Files, conaninfoName)
|
||||||
}
|
}
|
||||||
@ -458,8 +458,7 @@ func TestPackageConan(t *testing.T) {
|
|||||||
req := NewRequest(t, "GET", fmt.Sprintf("%s/v1/conans/search?q=%s", url, stdurl.QueryEscape(c.Query)))
|
req := NewRequest(t, "GET", fmt.Sprintf("%s/v1/conans/search?q=%s", url, stdurl.QueryEscape(c.Query)))
|
||||||
resp := MakeRequest(t, req, http.StatusOK)
|
resp := MakeRequest(t, req, http.StatusOK)
|
||||||
|
|
||||||
var result *conan_router.SearchResult
|
result := DecodeJSON(t, resp, &conan_router.SearchResult{})
|
||||||
DecodeJSON(t, resp, &result)
|
|
||||||
|
|
||||||
assert.ElementsMatch(t, c.Expected, result.Results, "case %d: unexpected result", i)
|
assert.ElementsMatch(t, c.Expected, result.Results, "case %d: unexpected result", i)
|
||||||
}
|
}
|
||||||
@ -702,8 +701,7 @@ func TestPackageConan(t *testing.T) {
|
|||||||
Revisions []*RevisionInfo `json:"revisions"`
|
Revisions []*RevisionInfo `json:"revisions"`
|
||||||
}
|
}
|
||||||
|
|
||||||
var list *RevisionList
|
list := DecodeJSON(t, resp, &RevisionList{})
|
||||||
DecodeJSON(t, resp, &list)
|
|
||||||
assert.Len(t, list.Revisions, 2)
|
assert.Len(t, list.Revisions, 2)
|
||||||
revs := make([]string, 0, len(list.Revisions))
|
revs := make([]string, 0, len(list.Revisions))
|
||||||
for _, rev := range list.Revisions {
|
for _, rev := range list.Revisions {
|
||||||
@ -714,7 +712,7 @@ func TestPackageConan(t *testing.T) {
|
|||||||
req = NewRequest(t, "GET", fmt.Sprintf("%s/%s/packages/%s/revisions", recipeURL, revision1, conanPackageReference))
|
req = NewRequest(t, "GET", fmt.Sprintf("%s/%s/packages/%s/revisions", recipeURL, revision1, conanPackageReference))
|
||||||
resp = MakeRequest(t, req, http.StatusOK)
|
resp = MakeRequest(t, req, http.StatusOK)
|
||||||
|
|
||||||
DecodeJSON(t, resp, &list)
|
list = DecodeJSON(t, resp, &RevisionList{})
|
||||||
assert.Len(t, list.Revisions, 2)
|
assert.Len(t, list.Revisions, 2)
|
||||||
revs = make([]string, 0, len(list.Revisions))
|
revs = make([]string, 0, len(list.Revisions))
|
||||||
for _, rev := range list.Revisions {
|
for _, rev := range list.Revisions {
|
||||||
@ -754,8 +752,7 @@ func TestPackageConan(t *testing.T) {
|
|||||||
req := NewRequest(t, "GET", fmt.Sprintf("%s/v2/conans/search?q=%s", url, stdurl.QueryEscape(c.Query)))
|
req := NewRequest(t, "GET", fmt.Sprintf("%s/v2/conans/search?q=%s", url, stdurl.QueryEscape(c.Query)))
|
||||||
resp := MakeRequest(t, req, http.StatusOK)
|
resp := MakeRequest(t, req, http.StatusOK)
|
||||||
|
|
||||||
var result *conan_router.SearchResult
|
result := DecodeJSON(t, resp, &conan_router.SearchResult{})
|
||||||
DecodeJSON(t, resp, &result)
|
|
||||||
|
|
||||||
assert.ElementsMatch(t, c.Expected, result.Results, "case %d: unexpected result", i)
|
assert.ElementsMatch(t, c.Expected, result.Results, "case %d: unexpected result", i)
|
||||||
}
|
}
|
||||||
|
|||||||
@ -5,7 +5,6 @@ package integration
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"archive/tar"
|
"archive/tar"
|
||||||
"archive/zip"
|
|
||||||
"bytes"
|
"bytes"
|
||||||
"fmt"
|
"fmt"
|
||||||
"io"
|
"io"
|
||||||
@ -16,6 +15,7 @@ import (
|
|||||||
"code.gitea.io/gitea/models/unittest"
|
"code.gitea.io/gitea/models/unittest"
|
||||||
user_model "code.gitea.io/gitea/models/user"
|
user_model "code.gitea.io/gitea/models/user"
|
||||||
conda_module "code.gitea.io/gitea/modules/packages/conda"
|
conda_module "code.gitea.io/gitea/modules/packages/conda"
|
||||||
|
"code.gitea.io/gitea/modules/test"
|
||||||
"code.gitea.io/gitea/modules/zstd"
|
"code.gitea.io/gitea/modules/zstd"
|
||||||
"code.gitea.io/gitea/tests"
|
"code.gitea.io/gitea/tests"
|
||||||
|
|
||||||
@ -94,11 +94,9 @@ func TestPackageConda(t *testing.T) {
|
|||||||
io.Copy(zsw, bytes.NewReader(tarContent))
|
io.Copy(zsw, bytes.NewReader(tarContent))
|
||||||
zsw.Close()
|
zsw.Close()
|
||||||
|
|
||||||
var buf bytes.Buffer
|
buf := test.WriteZipArchive(map[string]string{
|
||||||
zpw := zip.NewWriter(&buf)
|
"info-x.tar.zst": infoBuf.String(),
|
||||||
w, _ := zpw.Create("info-x.tar.zst")
|
})
|
||||||
w.Write(infoBuf.Bytes())
|
|
||||||
zpw.Close()
|
|
||||||
|
|
||||||
fullName := channel + "/" + packageName
|
fullName := channel + "/" + packageName
|
||||||
filename := fmt.Sprintf("%s-%s.conda", packageName, packageVersion)
|
filename := fmt.Sprintf("%s-%s.conda", packageName, packageVersion)
|
||||||
|
|||||||
@ -5,7 +5,6 @@ package integration
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"archive/tar"
|
"archive/tar"
|
||||||
"archive/zip"
|
|
||||||
"bytes"
|
"bytes"
|
||||||
"compress/gzip"
|
"compress/gzip"
|
||||||
"fmt"
|
"fmt"
|
||||||
@ -16,6 +15,7 @@ import (
|
|||||||
"code.gitea.io/gitea/models/unittest"
|
"code.gitea.io/gitea/models/unittest"
|
||||||
user_model "code.gitea.io/gitea/models/user"
|
user_model "code.gitea.io/gitea/models/user"
|
||||||
cran_module "code.gitea.io/gitea/modules/packages/cran"
|
cran_module "code.gitea.io/gitea/modules/packages/cran"
|
||||||
|
"code.gitea.io/gitea/modules/test"
|
||||||
"code.gitea.io/gitea/tests"
|
"code.gitea.io/gitea/tests"
|
||||||
|
|
||||||
"github.com/stretchr/testify/assert"
|
"github.com/stretchr/testify/assert"
|
||||||
@ -144,15 +144,6 @@ func TestPackageCran(t *testing.T) {
|
|||||||
})
|
})
|
||||||
|
|
||||||
t.Run("Binary", func(t *testing.T) {
|
t.Run("Binary", func(t *testing.T) {
|
||||||
createArchive := func(filename string, content []byte) *bytes.Buffer {
|
|
||||||
var buf bytes.Buffer
|
|
||||||
archive := zip.NewWriter(&buf)
|
|
||||||
w, _ := archive.Create(filename)
|
|
||||||
w.Write(content)
|
|
||||||
archive.Close()
|
|
||||||
return &buf
|
|
||||||
}
|
|
||||||
|
|
||||||
t.Run("Upload", func(t *testing.T) {
|
t.Run("Upload", func(t *testing.T) {
|
||||||
defer tests.PrintCurrentTest(t)()
|
defer tests.PrintCurrentTest(t)()
|
||||||
|
|
||||||
@ -161,24 +152,21 @@ func TestPackageCran(t *testing.T) {
|
|||||||
req := NewRequestWithBody(t, "PUT", uploadURL, bytes.NewReader([]byte{}))
|
req := NewRequestWithBody(t, "PUT", uploadURL, bytes.NewReader([]byte{}))
|
||||||
MakeRequest(t, req, http.StatusUnauthorized)
|
MakeRequest(t, req, http.StatusUnauthorized)
|
||||||
|
|
||||||
req = NewRequestWithBody(t, "PUT", uploadURL, createArchive(
|
req = NewRequestWithBody(t, "PUT", uploadURL, test.WriteZipArchive(map[string]string{
|
||||||
"dummy.txt",
|
"dummy.txt": "",
|
||||||
[]byte{},
|
})).AddBasicAuth(user.Name)
|
||||||
)).AddBasicAuth(user.Name)
|
|
||||||
MakeRequest(t, req, http.StatusBadRequest)
|
MakeRequest(t, req, http.StatusBadRequest)
|
||||||
|
|
||||||
req = NewRequestWithBody(t, "PUT", uploadURL+"?platform=&rversion=", createArchive(
|
req = NewRequestWithBody(t, "PUT", uploadURL+"?platform=&rversion=", test.WriteZipArchive(map[string]string{
|
||||||
"package/DESCRIPTION",
|
"package/DESCRIPTION": string(createDescription(packageName, packageVersion)),
|
||||||
createDescription(packageName, packageVersion),
|
})).AddBasicAuth(user.Name)
|
||||||
)).AddBasicAuth(user.Name)
|
|
||||||
MakeRequest(t, req, http.StatusBadRequest)
|
MakeRequest(t, req, http.StatusBadRequest)
|
||||||
|
|
||||||
uploadURL += "?platform=windows&rversion=4.2"
|
uploadURL += "?platform=windows&rversion=4.2"
|
||||||
|
|
||||||
req = NewRequestWithBody(t, "PUT", uploadURL, createArchive(
|
req = NewRequestWithBody(t, "PUT", uploadURL, test.WriteZipArchive(map[string]string{
|
||||||
"package/DESCRIPTION",
|
"package/DESCRIPTION": string(createDescription(packageName, packageVersion)),
|
||||||
createDescription(packageName, packageVersion),
|
})).AddBasicAuth(user.Name)
|
||||||
)).AddBasicAuth(user.Name)
|
|
||||||
MakeRequest(t, req, http.StatusCreated)
|
MakeRequest(t, req, http.StatusCreated)
|
||||||
|
|
||||||
pvs, err := packages.GetVersionsByPackageType(t.Context(), user.ID, packages.TypeCran)
|
pvs, err := packages.GetVersionsByPackageType(t.Context(), user.ID, packages.TypeCran)
|
||||||
@ -189,10 +177,9 @@ func TestPackageCran(t *testing.T) {
|
|||||||
assert.NoError(t, err)
|
assert.NoError(t, err)
|
||||||
assert.Len(t, pfs, 2)
|
assert.Len(t, pfs, 2)
|
||||||
|
|
||||||
req = NewRequestWithBody(t, "PUT", uploadURL, createArchive(
|
req = NewRequestWithBody(t, "PUT", uploadURL, test.WriteZipArchive(map[string]string{
|
||||||
"package/DESCRIPTION",
|
"package/DESCRIPTION": string(createDescription(packageName, packageVersion)),
|
||||||
createDescription(packageName, packageVersion),
|
})).AddBasicAuth(user.Name)
|
||||||
)).AddBasicAuth(user.Name)
|
|
||||||
MakeRequest(t, req, http.StatusConflict)
|
MakeRequest(t, req, http.StatusConflict)
|
||||||
})
|
})
|
||||||
|
|
||||||
|
|||||||
@ -4,7 +4,6 @@
|
|||||||
package integration
|
package integration
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"archive/zip"
|
|
||||||
"bytes"
|
"bytes"
|
||||||
"fmt"
|
"fmt"
|
||||||
"net/http"
|
"net/http"
|
||||||
@ -14,6 +13,7 @@ import (
|
|||||||
"code.gitea.io/gitea/models/packages"
|
"code.gitea.io/gitea/models/packages"
|
||||||
"code.gitea.io/gitea/models/unittest"
|
"code.gitea.io/gitea/models/unittest"
|
||||||
user_model "code.gitea.io/gitea/models/user"
|
user_model "code.gitea.io/gitea/models/user"
|
||||||
|
"code.gitea.io/gitea/modules/test"
|
||||||
"code.gitea.io/gitea/tests"
|
"code.gitea.io/gitea/tests"
|
||||||
|
|
||||||
"github.com/stretchr/testify/assert"
|
"github.com/stretchr/testify/assert"
|
||||||
@ -29,23 +29,12 @@ func TestPackageGo(t *testing.T) {
|
|||||||
packageVersion2 := "v0.0.2"
|
packageVersion2 := "v0.0.2"
|
||||||
goModContent := `module "gitea.com/go-gitea/gitea"`
|
goModContent := `module "gitea.com/go-gitea/gitea"`
|
||||||
|
|
||||||
createArchive := func(files map[string][]byte) []byte {
|
|
||||||
var buf bytes.Buffer
|
|
||||||
zw := zip.NewWriter(&buf)
|
|
||||||
for name, content := range files {
|
|
||||||
w, _ := zw.Create(name)
|
|
||||||
w.Write(content)
|
|
||||||
}
|
|
||||||
zw.Close()
|
|
||||||
return buf.Bytes()
|
|
||||||
}
|
|
||||||
|
|
||||||
url := fmt.Sprintf("/api/packages/%s/go", user.Name)
|
url := fmt.Sprintf("/api/packages/%s/go", user.Name)
|
||||||
|
|
||||||
t.Run("Upload", func(t *testing.T) {
|
t.Run("Upload", func(t *testing.T) {
|
||||||
defer tests.PrintCurrentTest(t)()
|
defer tests.PrintCurrentTest(t)()
|
||||||
|
|
||||||
content := createArchive(nil)
|
content := test.WriteZipArchive(nil).Bytes()
|
||||||
|
|
||||||
req := NewRequestWithBody(t, "PUT", url+"/upload", bytes.NewReader(content))
|
req := NewRequestWithBody(t, "PUT", url+"/upload", bytes.NewReader(content))
|
||||||
MakeRequest(t, req, http.StatusUnauthorized)
|
MakeRequest(t, req, http.StatusUnauthorized)
|
||||||
@ -54,9 +43,9 @@ func TestPackageGo(t *testing.T) {
|
|||||||
AddBasicAuth(user.Name)
|
AddBasicAuth(user.Name)
|
||||||
MakeRequest(t, req, http.StatusBadRequest)
|
MakeRequest(t, req, http.StatusBadRequest)
|
||||||
|
|
||||||
content = createArchive(map[string][]byte{
|
content = test.WriteZipArchive(map[string]string{
|
||||||
packageName + "@" + packageVersion + "/go.mod": []byte(goModContent),
|
packageName + "@" + packageVersion + "/go.mod": goModContent,
|
||||||
})
|
}).Bytes()
|
||||||
|
|
||||||
req = NewRequestWithBody(t, "PUT", url+"/upload", bytes.NewReader(content)).
|
req = NewRequestWithBody(t, "PUT", url+"/upload", bytes.NewReader(content)).
|
||||||
AddBasicAuth(user.Name)
|
AddBasicAuth(user.Name)
|
||||||
@ -88,9 +77,9 @@ func TestPackageGo(t *testing.T) {
|
|||||||
|
|
||||||
time.Sleep(time.Second) // Ensure the timestamp is different, then the "list" below can have stable order
|
time.Sleep(time.Second) // Ensure the timestamp is different, then the "list" below can have stable order
|
||||||
|
|
||||||
content = createArchive(map[string][]byte{
|
content = test.WriteZipArchive(map[string]string{
|
||||||
packageName + "@" + packageVersion2 + "/go.mod": []byte(goModContent),
|
packageName + "@" + packageVersion2 + "/go.mod": goModContent,
|
||||||
})
|
}).Bytes()
|
||||||
|
|
||||||
req = NewRequestWithBody(t, "PUT", url+"/upload", bytes.NewReader(content)).
|
req = NewRequestWithBody(t, "PUT", url+"/upload", bytes.NewReader(content)).
|
||||||
AddBasicAuth(user.Name)
|
AddBasicAuth(user.Name)
|
||||||
|
|||||||
@ -4,7 +4,6 @@
|
|||||||
package integration
|
package integration
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"archive/zip"
|
|
||||||
"bytes"
|
"bytes"
|
||||||
"encoding/base64"
|
"encoding/base64"
|
||||||
"encoding/xml"
|
"encoding/xml"
|
||||||
@ -26,6 +25,7 @@ import (
|
|||||||
nuget_module "code.gitea.io/gitea/modules/packages/nuget"
|
nuget_module "code.gitea.io/gitea/modules/packages/nuget"
|
||||||
"code.gitea.io/gitea/modules/setting"
|
"code.gitea.io/gitea/modules/setting"
|
||||||
"code.gitea.io/gitea/modules/structs"
|
"code.gitea.io/gitea/modules/structs"
|
||||||
|
"code.gitea.io/gitea/modules/test"
|
||||||
"code.gitea.io/gitea/routers/api/packages/nuget"
|
"code.gitea.io/gitea/routers/api/packages/nuget"
|
||||||
packageService "code.gitea.io/gitea/services/packages"
|
packageService "code.gitea.io/gitea/services/packages"
|
||||||
"code.gitea.io/gitea/tests"
|
"code.gitea.io/gitea/tests"
|
||||||
@ -155,12 +155,9 @@ func TestPackageNuGet(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
createPackage := func(id, version string) *bytes.Buffer {
|
createPackage := func(id, version string) *bytes.Buffer {
|
||||||
var buf bytes.Buffer
|
return test.WriteZipArchive(map[string]string{
|
||||||
archive := zip.NewWriter(&buf)
|
"package.nuspec": createNuspec(id, version),
|
||||||
w, _ := archive.Create("package.nuspec")
|
})
|
||||||
w.Write([]byte(createNuspec(id, version)))
|
|
||||||
archive.Close()
|
|
||||||
return &buf
|
|
||||||
}
|
}
|
||||||
|
|
||||||
content := createPackage(packageName, packageVersion).Bytes()
|
content := createPackage(packageName, packageVersion).Bytes()
|
||||||
@ -379,11 +376,11 @@ func TestPackageNuGet(t *testing.T) {
|
|||||||
defer tests.PrintCurrentTest(t)()
|
defer tests.PrintCurrentTest(t)()
|
||||||
|
|
||||||
createSymbolPackage := func(id, packageType string) io.Reader {
|
createSymbolPackage := func(id, packageType string) io.Reader {
|
||||||
var buf bytes.Buffer
|
symbolData, _ := base64.StdEncoding.DecodeString(`QlNKQgEAAQAAAAAADAAAAFBEQiB2MS4wAAAAAAAABgB8AAAAWAAAACNQZGIAAAAA1AAAAAgBAAAj
|
||||||
archive := zip.NewWriter(&buf)
|
fgAA3AEAAAQAAAAjU3RyaW5ncwAAAADgAQAABAAAACNVUwDkAQAAMAAAACNHVUlEAAAAFAIAACgB
|
||||||
|
AAAjQmxvYgAAAGm7ENm9SGxMtAFVvPUsPJTF6PbtAAAAAFcVogEJAAAAAQAAAA==`)
|
||||||
w, _ := archive.Create("package.nuspec")
|
return test.WriteZipArchive(map[string]string{
|
||||||
w.Write([]byte(`<?xml version="1.0" encoding="utf-8"?>
|
"package.nuspec": `<?xml version="1.0" encoding="utf-8"?>
|
||||||
<package xmlns="http://schemas.microsoft.com/packaging/2013/05/nuspec.xsd">
|
<package xmlns="http://schemas.microsoft.com/packaging/2013/05/nuspec.xsd">
|
||||||
<metadata>
|
<metadata>
|
||||||
<id>` + id + `</id>
|
<id>` + id + `</id>
|
||||||
@ -392,16 +389,9 @@ func TestPackageNuGet(t *testing.T) {
|
|||||||
<description>` + packageDescription + `</description>
|
<description>` + packageDescription + `</description>
|
||||||
<packageTypes><packageType name="` + packageType + `" /></packageTypes>
|
<packageTypes><packageType name="` + packageType + `" /></packageTypes>
|
||||||
</metadata>
|
</metadata>
|
||||||
</package>`))
|
</package>`,
|
||||||
|
symbolFilename: string(symbolData),
|
||||||
w, _ = archive.Create(symbolFilename)
|
})
|
||||||
b, _ := base64.StdEncoding.DecodeString(`QlNKQgEAAQAAAAAADAAAAFBEQiB2MS4wAAAAAAAABgB8AAAAWAAAACNQZGIAAAAA1AAAAAgBAAAj
|
|
||||||
fgAA3AEAAAQAAAAjU3RyaW5ncwAAAADgAQAABAAAACNVUwDkAQAAMAAAACNHVUlEAAAAFAIAACgB
|
|
||||||
AAAjQmxvYgAAAGm7ENm9SGxMtAFVvPUsPJTF6PbtAAAAAFcVogEJAAAAAQAAAA==`)
|
|
||||||
w.Write(b)
|
|
||||||
|
|
||||||
archive.Close()
|
|
||||||
return &buf
|
|
||||||
}
|
}
|
||||||
|
|
||||||
req := NewRequestWithBody(t, "PUT", url+"/symbolpackage", createSymbolPackage("unknown-package", "SymbolsPackage")).
|
req := NewRequestWithBody(t, "PUT", url+"/symbolpackage", createSymbolPackage("unknown-package", "SymbolsPackage")).
|
||||||
|
|||||||
@ -4,7 +4,6 @@
|
|||||||
package integration
|
package integration
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"archive/zip"
|
|
||||||
"bytes"
|
"bytes"
|
||||||
"fmt"
|
"fmt"
|
||||||
"io"
|
"io"
|
||||||
@ -18,6 +17,7 @@ import (
|
|||||||
user_model "code.gitea.io/gitea/models/user"
|
user_model "code.gitea.io/gitea/models/user"
|
||||||
swift_module "code.gitea.io/gitea/modules/packages/swift"
|
swift_module "code.gitea.io/gitea/modules/packages/swift"
|
||||||
"code.gitea.io/gitea/modules/setting"
|
"code.gitea.io/gitea/modules/setting"
|
||||||
|
"code.gitea.io/gitea/modules/test"
|
||||||
swift_router "code.gitea.io/gitea/routers/api/packages/swift"
|
swift_router "code.gitea.io/gitea/routers/api/packages/swift"
|
||||||
"code.gitea.io/gitea/tests"
|
"code.gitea.io/gitea/tests"
|
||||||
|
|
||||||
@ -113,17 +113,6 @@ func TestPackageSwift(t *testing.T) {
|
|||||||
MakeRequest(t, req, expectedStatus)
|
MakeRequest(t, req, expectedStatus)
|
||||||
}
|
}
|
||||||
|
|
||||||
createArchive := func(files map[string]string) *bytes.Buffer {
|
|
||||||
var buf bytes.Buffer
|
|
||||||
zw := zip.NewWriter(&buf)
|
|
||||||
for filename, content := range files {
|
|
||||||
w, _ := zw.Create(filename)
|
|
||||||
w.Write([]byte(content))
|
|
||||||
}
|
|
||||||
zw.Close()
|
|
||||||
return &buf
|
|
||||||
}
|
|
||||||
|
|
||||||
for _, triple := range []string{"/sc_ope/package/1.0.0", "/scope/pack~age/1.0.0", "/scope/package/1_0.0"} {
|
for _, triple := range []string{"/sc_ope/package/1.0.0", "/scope/pack~age/1.0.0", "/scope/package/1_0.0"} {
|
||||||
req := NewRequestWithBody(t, "PUT", url+triple, bytes.NewReader([]byte{})).
|
req := NewRequestWithBody(t, "PUT", url+triple, bytes.NewReader([]byte{})).
|
||||||
AddBasicAuth(user.Name)
|
AddBasicAuth(user.Name)
|
||||||
@ -142,7 +131,7 @@ func TestPackageSwift(t *testing.T) {
|
|||||||
t,
|
t,
|
||||||
uploadURL,
|
uploadURL,
|
||||||
http.StatusCreated,
|
http.StatusCreated,
|
||||||
createArchive(map[string]string{
|
test.WriteZipArchive(map[string]string{
|
||||||
"Package.swift": contentManifest1,
|
"Package.swift": contentManifest1,
|
||||||
"Package@swift-5.6.swift": contentManifest2,
|
"Package@swift-5.6.swift": contentManifest2,
|
||||||
}),
|
}),
|
||||||
@ -177,7 +166,7 @@ func TestPackageSwift(t *testing.T) {
|
|||||||
t,
|
t,
|
||||||
uploadURL,
|
uploadURL,
|
||||||
http.StatusConflict,
|
http.StatusConflict,
|
||||||
createArchive(map[string]string{
|
test.WriteZipArchive(map[string]string{
|
||||||
"Package.swift": contentManifest1,
|
"Package.swift": contentManifest1,
|
||||||
}),
|
}),
|
||||||
"",
|
"",
|
||||||
@ -209,17 +198,6 @@ func TestPackageSwift(t *testing.T) {
|
|||||||
MakeRequest(t, req, expectedStatus)
|
MakeRequest(t, req, expectedStatus)
|
||||||
}
|
}
|
||||||
|
|
||||||
createArchive := func(files map[string]string) *bytes.Buffer {
|
|
||||||
var buf bytes.Buffer
|
|
||||||
zw := zip.NewWriter(&buf)
|
|
||||||
for filename, content := range files {
|
|
||||||
w, _ := zw.Create(filename)
|
|
||||||
w.Write([]byte(content))
|
|
||||||
}
|
|
||||||
zw.Close()
|
|
||||||
return &buf
|
|
||||||
}
|
|
||||||
|
|
||||||
uploadURL := fmt.Sprintf("%s/%s/%s/%s", url, packageScope, packageName, packageVersion2)
|
uploadURL := fmt.Sprintf("%s/%s/%s/%s", url, packageScope, packageName, packageVersion2)
|
||||||
|
|
||||||
req := NewRequestWithBody(t, "PUT", uploadURL, bytes.NewReader([]byte{}))
|
req := NewRequestWithBody(t, "PUT", uploadURL, bytes.NewReader([]byte{}))
|
||||||
@ -230,7 +208,7 @@ func TestPackageSwift(t *testing.T) {
|
|||||||
t,
|
t,
|
||||||
uploadURL,
|
uploadURL,
|
||||||
http.StatusCreated,
|
http.StatusCreated,
|
||||||
createArchive(map[string]string{
|
test.WriteZipArchive(map[string]string{
|
||||||
"Package.swift": contentManifest1,
|
"Package.swift": contentManifest1,
|
||||||
"Package@swift-5.6.swift": contentManifest2,
|
"Package@swift-5.6.swift": contentManifest2,
|
||||||
}),
|
}),
|
||||||
@ -265,7 +243,7 @@ func TestPackageSwift(t *testing.T) {
|
|||||||
t,
|
t,
|
||||||
uploadURL,
|
uploadURL,
|
||||||
http.StatusConflict,
|
http.StatusConflict,
|
||||||
createArchive(map[string]string{
|
test.WriteZipArchive(map[string]string{
|
||||||
"Package.swift": contentManifest1,
|
"Package.swift": contentManifest1,
|
||||||
}),
|
}),
|
||||||
"",
|
"",
|
||||||
@ -307,8 +285,7 @@ func TestPackageSwift(t *testing.T) {
|
|||||||
|
|
||||||
body := resp.Body.String()
|
body := resp.Body.String()
|
||||||
|
|
||||||
var result *swift_router.EnumeratePackageVersionsResponse
|
result := DecodeJSON(t, resp, &swift_router.EnumeratePackageVersionsResponse{})
|
||||||
DecodeJSON(t, resp, &result)
|
|
||||||
|
|
||||||
assert.Len(t, result.Releases, 2)
|
assert.Len(t, result.Releases, 2)
|
||||||
assert.Contains(t, result.Releases, packageVersion2)
|
assert.Contains(t, result.Releases, packageVersion2)
|
||||||
@ -333,8 +310,7 @@ func TestPackageSwift(t *testing.T) {
|
|||||||
|
|
||||||
body := resp.Body.String()
|
body := resp.Body.String()
|
||||||
|
|
||||||
var result *swift_router.PackageVersionMetadataResponse
|
result := DecodeJSON(t, resp, &swift_router.PackageVersionMetadataResponse{})
|
||||||
DecodeJSON(t, resp, &result)
|
|
||||||
|
|
||||||
pv, err := packages.GetVersionByNameAndVersion(t.Context(), user.ID, packages.TypeSwift, packageID, packageVersion)
|
pv, err := packages.GetVersionByNameAndVersion(t.Context(), user.ID, packages.TypeSwift, packageID, packageVersion)
|
||||||
assert.NotNil(t, pv)
|
assert.NotNil(t, pv)
|
||||||
@ -425,8 +401,7 @@ func TestPackageSwift(t *testing.T) {
|
|||||||
SetHeader("Accept", swift_router.AcceptJSON)
|
SetHeader("Accept", swift_router.AcceptJSON)
|
||||||
resp = MakeRequest(t, req, http.StatusOK)
|
resp = MakeRequest(t, req, http.StatusOK)
|
||||||
|
|
||||||
var result *swift_router.LookupPackageIdentifiersResponse
|
result := DecodeJSON(t, resp, &swift_router.LookupPackageIdentifiersResponse{})
|
||||||
DecodeJSON(t, resp, &result)
|
|
||||||
|
|
||||||
assert.Len(t, result.Identifiers, 1)
|
assert.Len(t, result.Identifiers, 1)
|
||||||
assert.Equal(t, packageID, result.Identifiers[0])
|
assert.Equal(t, packageID, result.Identifiers[0])
|
||||||
|
|||||||
@ -75,8 +75,7 @@ func TestPackageAPI(t *testing.T) {
|
|||||||
AddTokenAuth(tokenReadPackage)
|
AddTokenAuth(tokenReadPackage)
|
||||||
resp := MakeRequest(t, req, http.StatusOK)
|
resp := MakeRequest(t, req, http.StatusOK)
|
||||||
|
|
||||||
var p *api.Package
|
p := DecodeJSON(t, resp, &api.Package{})
|
||||||
DecodeJSON(t, resp, &p)
|
|
||||||
|
|
||||||
assert.Equal(t, string(packages_model.TypeGeneric), p.Type)
|
assert.Equal(t, string(packages_model.TypeGeneric), p.Type)
|
||||||
assert.Equal(t, packageName, p.Name)
|
assert.Equal(t, packageName, p.Name)
|
||||||
@ -152,8 +151,7 @@ func TestPackageAPI(t *testing.T) {
|
|||||||
AddTokenAuth(tokenReadPackage)
|
AddTokenAuth(tokenReadPackage)
|
||||||
resp := MakeRequest(t, req, http.StatusOK)
|
resp := MakeRequest(t, req, http.StatusOK)
|
||||||
|
|
||||||
var apiPackage *api.Package
|
apiPackage := DecodeJSON(t, resp, &api.Package{})
|
||||||
DecodeJSON(t, resp, &apiPackage)
|
|
||||||
|
|
||||||
assert.Equal(t, string(packages_model.TypeGeneric), apiPackage.Type)
|
assert.Equal(t, string(packages_model.TypeGeneric), apiPackage.Type)
|
||||||
assert.Equal(t, packageName, apiPackage.Name)
|
assert.Equal(t, packageName, apiPackage.Name)
|
||||||
@ -171,8 +169,7 @@ func TestPackageAPI(t *testing.T) {
|
|||||||
AddTokenAuth(tokenReadPackage)
|
AddTokenAuth(tokenReadPackage)
|
||||||
resp := MakeRequest(t, req, http.StatusOK)
|
resp := MakeRequest(t, req, http.StatusOK)
|
||||||
|
|
||||||
var ap1 *api.Package
|
ap1 := DecodeJSON(t, resp, &api.Package{})
|
||||||
DecodeJSON(t, resp, &ap1)
|
|
||||||
assert.Nil(t, ap1.Repository)
|
assert.Nil(t, ap1.Repository)
|
||||||
|
|
||||||
// create a repository
|
// create a repository
|
||||||
@ -189,8 +186,7 @@ func TestPackageAPI(t *testing.T) {
|
|||||||
AddTokenAuth(tokenReadPackage)
|
AddTokenAuth(tokenReadPackage)
|
||||||
resp = MakeRequest(t, req, http.StatusOK)
|
resp = MakeRequest(t, req, http.StatusOK)
|
||||||
|
|
||||||
var ap2 *api.Package
|
ap2 := DecodeJSON(t, resp, &api.Package{})
|
||||||
DecodeJSON(t, resp, &ap2)
|
|
||||||
assert.NotNil(t, ap2.Repository)
|
assert.NotNil(t, ap2.Repository)
|
||||||
assert.Equal(t, newRepo.ID, ap2.Repository.ID)
|
assert.Equal(t, newRepo.ID, ap2.Repository.ID)
|
||||||
|
|
||||||
@ -206,8 +202,7 @@ func TestPackageAPI(t *testing.T) {
|
|||||||
AddTokenAuth(tokenReadPackage)
|
AddTokenAuth(tokenReadPackage)
|
||||||
resp = MakeRequest(t, req, http.StatusOK)
|
resp = MakeRequest(t, req, http.StatusOK)
|
||||||
|
|
||||||
var ap3 *api.Package
|
ap3 := DecodeJSON(t, resp, &api.Package{})
|
||||||
DecodeJSON(t, resp, &ap3)
|
|
||||||
assert.Nil(t, ap3.Repository)
|
assert.Nil(t, ap3.Repository)
|
||||||
|
|
||||||
// force link to a repository the currently logged-in user doesn't have access to
|
// force link to a repository the currently logged-in user doesn't have access to
|
||||||
@ -217,8 +212,7 @@ func TestPackageAPI(t *testing.T) {
|
|||||||
req = NewRequest(t, "GET", fmt.Sprintf("/api/v1/packages/%s/generic/%s/%s", user.Name, packageName, packageVersion)).AddTokenAuth(tokenReadPackage)
|
req = NewRequest(t, "GET", fmt.Sprintf("/api/v1/packages/%s/generic/%s/%s", user.Name, packageName, packageVersion)).AddTokenAuth(tokenReadPackage)
|
||||||
resp = MakeRequest(t, req, http.StatusOK)
|
resp = MakeRequest(t, req, http.StatusOK)
|
||||||
|
|
||||||
var ap4 *api.Package
|
ap4 := DecodeJSON(t, resp, &api.Package{})
|
||||||
DecodeJSON(t, resp, &ap4)
|
|
||||||
assert.Nil(t, ap4.Repository)
|
assert.Nil(t, ap4.Repository)
|
||||||
|
|
||||||
assert.NoError(t, packages_model.UnlinkRepositoryFromAllPackages(t.Context(), privateRepoID))
|
assert.NoError(t, packages_model.UnlinkRepositoryFromAllPackages(t.Context(), privateRepoID))
|
||||||
|
|||||||
@ -313,8 +313,7 @@ func testAPIGetLatestRelease(t *testing.T) {
|
|||||||
req := NewRequest(t, "GET", fmt.Sprintf("/api/v1/repos/%s/%s/releases/latest", owner.Name, repo.Name))
|
req := NewRequest(t, "GET", fmt.Sprintf("/api/v1/repos/%s/%s/releases/latest", owner.Name, repo.Name))
|
||||||
resp := MakeRequest(t, req, http.StatusOK)
|
resp := MakeRequest(t, req, http.StatusOK)
|
||||||
|
|
||||||
var release *api.Release
|
release := DecodeJSON(t, resp, &api.Release{})
|
||||||
DecodeJSON(t, resp, &release)
|
|
||||||
|
|
||||||
assert.Equal(t, "testing-release", release.Title)
|
assert.Equal(t, "testing-release", release.Title)
|
||||||
}
|
}
|
||||||
@ -328,8 +327,7 @@ func testAPIGetReleaseByTag(t *testing.T) {
|
|||||||
req := NewRequest(t, "GET", fmt.Sprintf("/api/v1/repos/%s/%s/releases/tags/%s", owner.Name, repo.Name, tag))
|
req := NewRequest(t, "GET", fmt.Sprintf("/api/v1/repos/%s/%s/releases/tags/%s", owner.Name, repo.Name, tag))
|
||||||
resp := MakeRequest(t, req, http.StatusOK)
|
resp := MakeRequest(t, req, http.StatusOK)
|
||||||
|
|
||||||
var release *api.Release
|
release := DecodeJSON(t, resp, &api.Release{})
|
||||||
DecodeJSON(t, resp, &release)
|
|
||||||
|
|
||||||
assert.Equal(t, "testing-release", release.Title)
|
assert.Equal(t, "testing-release", release.Title)
|
||||||
|
|
||||||
@ -338,8 +336,7 @@ func testAPIGetReleaseByTag(t *testing.T) {
|
|||||||
req = NewRequest(t, "GET", fmt.Sprintf("/api/v1/repos/%s/%s/releases/tags/%s", owner.Name, repo.Name, nonexistingtag))
|
req = NewRequest(t, "GET", fmt.Sprintf("/api/v1/repos/%s/%s/releases/tags/%s", owner.Name, repo.Name, nonexistingtag))
|
||||||
resp = MakeRequest(t, req, http.StatusNotFound)
|
resp = MakeRequest(t, req, http.StatusNotFound)
|
||||||
|
|
||||||
var err *api.APIError
|
err := DecodeJSON(t, resp, &api.APIError{})
|
||||||
DecodeJSON(t, resp, &err)
|
|
||||||
assert.NotEmpty(t, err.Message)
|
assert.NotEmpty(t, err.Message)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@ -100,8 +100,7 @@ echo "TestGitHookScript"
|
|||||||
req := NewRequestf(t, "GET", "/api/v1/repos/%s/%s/hooks/git/pre-receive", owner.Name, repo.Name).
|
req := NewRequestf(t, "GET", "/api/v1/repos/%s/%s/hooks/git/pre-receive", owner.Name, repo.Name).
|
||||||
AddTokenAuth(token)
|
AddTokenAuth(token)
|
||||||
resp := MakeRequest(t, req, http.StatusOK)
|
resp := MakeRequest(t, req, http.StatusOK)
|
||||||
var apiGitHook *api.GitHook
|
apiGitHook := DecodeJSON(t, resp, &api.GitHook{})
|
||||||
DecodeJSON(t, resp, &apiGitHook)
|
|
||||||
assert.True(t, apiGitHook.IsActive)
|
assert.True(t, apiGitHook.IsActive)
|
||||||
assert.Equal(t, testHookContent, apiGitHook.Content)
|
assert.Equal(t, testHookContent, apiGitHook.Content)
|
||||||
})
|
})
|
||||||
@ -134,16 +133,14 @@ echo "TestGitHookScript"
|
|||||||
Content: testHookContent,
|
Content: testHookContent,
|
||||||
}).AddTokenAuth(token)
|
}).AddTokenAuth(token)
|
||||||
resp := MakeRequest(t, req, http.StatusOK)
|
resp := MakeRequest(t, req, http.StatusOK)
|
||||||
var apiGitHook *api.GitHook
|
apiGitHook := DecodeJSON(t, resp, &api.GitHook{})
|
||||||
DecodeJSON(t, resp, &apiGitHook)
|
|
||||||
assert.True(t, apiGitHook.IsActive)
|
assert.True(t, apiGitHook.IsActive)
|
||||||
assert.Equal(t, testHookContent, apiGitHook.Content)
|
assert.Equal(t, testHookContent, apiGitHook.Content)
|
||||||
|
|
||||||
req = NewRequestf(t, "GET", "/api/v1/repos/%s/%s/hooks/git/pre-receive", owner.Name, repo.Name).
|
req = NewRequestf(t, "GET", "/api/v1/repos/%s/%s/hooks/git/pre-receive", owner.Name, repo.Name).
|
||||||
AddTokenAuth(token)
|
AddTokenAuth(token)
|
||||||
resp = MakeRequest(t, req, http.StatusOK)
|
resp = MakeRequest(t, req, http.StatusOK)
|
||||||
var apiGitHook2 *api.GitHook
|
apiGitHook2 := DecodeJSON(t, resp, &api.GitHook{})
|
||||||
DecodeJSON(t, resp, &apiGitHook2)
|
|
||||||
assert.True(t, apiGitHook2.IsActive)
|
assert.True(t, apiGitHook2.IsActive)
|
||||||
assert.Equal(t, testHookContent, apiGitHook2.Content)
|
assert.Equal(t, testHookContent, apiGitHook2.Content)
|
||||||
})
|
})
|
||||||
@ -180,8 +177,7 @@ echo "TestGitHookScript"
|
|||||||
req = NewRequestf(t, "GET", "/api/v1/repos/%s/%s/hooks/git/pre-receive", owner.Name, repo.Name).
|
req = NewRequestf(t, "GET", "/api/v1/repos/%s/%s/hooks/git/pre-receive", owner.Name, repo.Name).
|
||||||
AddTokenAuth(token)
|
AddTokenAuth(token)
|
||||||
resp := MakeRequest(t, req, http.StatusOK)
|
resp := MakeRequest(t, req, http.StatusOK)
|
||||||
var apiGitHook2 *api.GitHook
|
apiGitHook2 := DecodeJSON(t, resp, &api.GitHook{})
|
||||||
DecodeJSON(t, resp, &apiGitHook2)
|
|
||||||
assert.False(t, apiGitHook2.IsActive)
|
assert.False(t, apiGitHook2.IsActive)
|
||||||
assert.Empty(t, apiGitHook2.Content)
|
assert.Empty(t, apiGitHook2.Content)
|
||||||
})
|
})
|
||||||
|
|||||||
@ -48,8 +48,7 @@ func TestAPIGitTags(t *testing.T) {
|
|||||||
AddTokenAuth(token)
|
AddTokenAuth(token)
|
||||||
res := MakeRequest(t, req, http.StatusOK)
|
res := MakeRequest(t, req, http.StatusOK)
|
||||||
|
|
||||||
var tag *api.AnnotatedTag
|
tag := DecodeJSON(t, res, &api.AnnotatedTag{})
|
||||||
DecodeJSON(t, res, &tag)
|
|
||||||
|
|
||||||
assert.Equal(t, aTagName, tag.Tag)
|
assert.Equal(t, aTagName, tag.Tag)
|
||||||
assert.Equal(t, aTag.ID.String(), tag.SHA)
|
assert.Equal(t, aTag.ID.String(), tag.SHA)
|
||||||
|
|||||||
@ -38,8 +38,7 @@ func TestAPICreateHook(t *testing.T) {
|
|||||||
}).AddTokenAuth(token)
|
}).AddTokenAuth(token)
|
||||||
resp := MakeRequest(t, req, http.StatusCreated)
|
resp := MakeRequest(t, req, http.StatusCreated)
|
||||||
|
|
||||||
var apiHook *api.Hook
|
apiHook := DecodeJSON(t, resp, &api.Hook{})
|
||||||
DecodeJSON(t, resp, &apiHook)
|
|
||||||
assert.Equal(t, "http://example.com/", apiHook.Config["url"])
|
assert.Equal(t, "http://example.com/", apiHook.Config["url"])
|
||||||
assert.Equal(t, "Bearer s3cr3t", apiHook.AuthorizationHeader)
|
assert.Equal(t, "Bearer s3cr3t", apiHook.AuthorizationHeader)
|
||||||
assert.Equal(t, "CI notifications", apiHook.Name)
|
assert.Equal(t, "CI notifications", apiHook.Name)
|
||||||
@ -49,8 +48,7 @@ func TestAPICreateHook(t *testing.T) {
|
|||||||
Name: &newName,
|
Name: &newName,
|
||||||
}).AddTokenAuth(token)
|
}).AddTokenAuth(token)
|
||||||
patchResp := MakeRequest(t, patchReq, http.StatusOK)
|
patchResp := MakeRequest(t, patchReq, http.StatusOK)
|
||||||
var patched *api.Hook
|
patched := DecodeJSON(t, patchResp, &api.Hook{})
|
||||||
DecodeJSON(t, patchResp, &patched)
|
|
||||||
assert.Equal(t, newName, patched.Name)
|
assert.Equal(t, newName, patched.Name)
|
||||||
|
|
||||||
hooksURL := fmt.Sprintf("/api/v1/repos/%s/%s/hooks", owner.Name, repo.Name)
|
hooksURL := fmt.Sprintf("/api/v1/repos/%s/%s/hooks", owner.Name, repo.Name)
|
||||||
@ -64,8 +62,7 @@ func TestAPICreateHook(t *testing.T) {
|
|||||||
},
|
},
|
||||||
}).AddTokenAuth(token)
|
}).AddTokenAuth(token)
|
||||||
resp2 := MakeRequest(t, req2, http.StatusCreated)
|
resp2 := MakeRequest(t, req2, http.StatusCreated)
|
||||||
var created *api.Hook
|
created := DecodeJSON(t, resp2, &api.Hook{})
|
||||||
DecodeJSON(t, resp2, &created)
|
|
||||||
assert.Empty(t, created.Name)
|
assert.Empty(t, created.Name)
|
||||||
|
|
||||||
hookURL := fmt.Sprintf("/api/v1/repos/%s/%s/hooks/%d", owner.Name, repo.Name, created.ID)
|
hookURL := fmt.Sprintf("/api/v1/repos/%s/%s/hooks/%d", owner.Name, repo.Name, created.ID)
|
||||||
@ -80,8 +77,7 @@ func TestAPICreateHook(t *testing.T) {
|
|||||||
// PATCH without Name field: name must remain "original"
|
// PATCH without Name field: name must remain "original"
|
||||||
patchReq2 := NewRequestWithJSON(t, "PATCH", hookURL, api.EditHookOption{}).AddTokenAuth(token)
|
patchReq2 := NewRequestWithJSON(t, "PATCH", hookURL, api.EditHookOption{}).AddTokenAuth(token)
|
||||||
patchResp2 := MakeRequest(t, patchReq2, http.StatusOK)
|
patchResp2 := MakeRequest(t, patchReq2, http.StatusOK)
|
||||||
var notCleared *api.Hook
|
notCleared := DecodeJSON(t, patchResp2, &api.Hook{})
|
||||||
DecodeJSON(t, patchResp2, ¬Cleared)
|
|
||||||
assert.Equal(t, "original", notCleared.Name)
|
assert.Equal(t, "original", notCleared.Name)
|
||||||
|
|
||||||
// PATCH with Name: "" explicitly: Name should be cleared to ""
|
// PATCH with Name: "" explicitly: Name should be cleared to ""
|
||||||
@ -89,7 +85,6 @@ func TestAPICreateHook(t *testing.T) {
|
|||||||
Name: new(""),
|
Name: new(""),
|
||||||
}).AddTokenAuth(token)
|
}).AddTokenAuth(token)
|
||||||
clearResp := MakeRequest(t, clearReq, http.StatusOK)
|
clearResp := MakeRequest(t, clearReq, http.StatusOK)
|
||||||
var cleared *api.Hook
|
cleared := DecodeJSON(t, clearResp, &api.Hook{})
|
||||||
DecodeJSON(t, clearResp, &cleared)
|
|
||||||
assert.Empty(t, cleared.Name)
|
assert.Empty(t, cleared.Name)
|
||||||
}
|
}
|
||||||
|
|||||||
@ -77,8 +77,7 @@ func TestAPILFSBatch(t *testing.T) {
|
|||||||
|
|
||||||
repo := createLFSTestRepository(t, "lfs-batch-repo")
|
repo := createLFSTestRepository(t, "lfs-batch-repo")
|
||||||
|
|
||||||
content := []byte("dummy1")
|
oid := storeObjectInRepo(t, repo.ID, "dummy1")
|
||||||
oid := storeObjectInRepo(t, repo.ID, &content)
|
|
||||||
defer git_model.RemoveLFSMetaObjectByOid(t.Context(), repo.ID, oid)
|
defer git_model.RemoveLFSMetaObjectByOid(t.Context(), repo.ID, oid)
|
||||||
|
|
||||||
session := loginUser(t, "user2")
|
session := loginUser(t, "user2")
|
||||||
@ -255,8 +254,7 @@ func TestAPILFSBatch(t *testing.T) {
|
|||||||
assert.True(t, exist)
|
assert.True(t, exist)
|
||||||
|
|
||||||
repo2 := createLFSTestRepository(t, "lfs-batch2-repo")
|
repo2 := createLFSTestRepository(t, "lfs-batch2-repo")
|
||||||
content := []byte("dummy0")
|
storeObjectInRepo(t, repo2.ID, "dummy0")
|
||||||
storeObjectInRepo(t, repo2.ID, &content)
|
|
||||||
|
|
||||||
meta, err := git_model.GetLFSMetaObjectByOid(t.Context(), repo.ID, p.Oid)
|
meta, err := git_model.GetLFSMetaObjectByOid(t.Context(), repo.ID, p.Oid)
|
||||||
assert.Nil(t, meta)
|
assert.Nil(t, meta)
|
||||||
@ -332,9 +330,7 @@ func TestAPILFSUpload(t *testing.T) {
|
|||||||
setting.LFS.StartServer = true
|
setting.LFS.StartServer = true
|
||||||
|
|
||||||
repo := createLFSTestRepository(t, "lfs-upload-repo")
|
repo := createLFSTestRepository(t, "lfs-upload-repo")
|
||||||
|
oid := storeObjectInRepo(t, repo.ID, "dummy3")
|
||||||
content := []byte("dummy3")
|
|
||||||
oid := storeObjectInRepo(t, repo.ID, &content)
|
|
||||||
defer git_model.RemoveLFSMetaObjectByOid(t.Context(), repo.ID, oid)
|
defer git_model.RemoveLFSMetaObjectByOid(t.Context(), repo.ID, oid)
|
||||||
|
|
||||||
session := loginUser(t, "user2")
|
session := loginUser(t, "user2")
|
||||||
@ -436,9 +432,7 @@ func TestAPILFSVerify(t *testing.T) {
|
|||||||
setting.LFS.StartServer = true
|
setting.LFS.StartServer = true
|
||||||
|
|
||||||
repo := createLFSTestRepository(t, "lfs-verify-repo")
|
repo := createLFSTestRepository(t, "lfs-verify-repo")
|
||||||
|
oid := storeObjectInRepo(t, repo.ID, "dummy3")
|
||||||
content := []byte("dummy3")
|
|
||||||
oid := storeObjectInRepo(t, repo.ID, &content)
|
|
||||||
defer git_model.RemoveLFSMetaObjectByOid(t.Context(), repo.ID, oid)
|
defer git_model.RemoveLFSMetaObjectByOid(t.Context(), repo.ID, oid)
|
||||||
|
|
||||||
session := loginUser(t, "user2")
|
session := loginUser(t, "user2")
|
||||||
|
|||||||
@ -59,8 +59,7 @@ func TestAPIRepoTags(t *testing.T) {
|
|||||||
req = NewRequestf(t, "GET", "/api/v1/repos/%s/%s/tags/%s", user.Name, repoName, newTag.Name).
|
req = NewRequestf(t, "GET", "/api/v1/repos/%s/%s/tags/%s", user.Name, repoName, newTag.Name).
|
||||||
AddTokenAuth(token)
|
AddTokenAuth(token)
|
||||||
resp = MakeRequest(t, req, http.StatusOK)
|
resp = MakeRequest(t, req, http.StatusOK)
|
||||||
var tag *api.Tag
|
tag := DecodeJSON(t, resp, &api.Tag{})
|
||||||
DecodeJSON(t, resp, &tag)
|
|
||||||
assert.Equal(t, newTag, tag)
|
assert.Equal(t, newTag, tag)
|
||||||
|
|
||||||
// delete tag
|
// delete tag
|
||||||
|
|||||||
@ -52,8 +52,7 @@ func TestAPIRepoTeams(t *testing.T) {
|
|||||||
req = NewRequest(t, "GET", fmt.Sprintf("/api/v1/repos/%s/teams/%s", publicOrgRepo.FullName(), "Test_Team")).
|
req = NewRequest(t, "GET", fmt.Sprintf("/api/v1/repos/%s/teams/%s", publicOrgRepo.FullName(), "Test_Team")).
|
||||||
AddTokenAuth(token)
|
AddTokenAuth(token)
|
||||||
res = MakeRequest(t, req, http.StatusOK)
|
res = MakeRequest(t, req, http.StatusOK)
|
||||||
var team *api.Team
|
team := DecodeJSON(t, res, &api.Team{})
|
||||||
DecodeJSON(t, res, &team)
|
|
||||||
assert.Equal(t, teams[1], team)
|
assert.Equal(t, teams[1], team)
|
||||||
|
|
||||||
req = NewRequest(t, "GET", fmt.Sprintf("/api/v1/repos/%s/teams/%s", publicOrgRepo.FullName(), "NonExistingTeam")).
|
req = NewRequest(t, "GET", fmt.Sprintf("/api/v1/repos/%s/teams/%s", publicOrgRepo.FullName(), "NonExistingTeam")).
|
||||||
|
|||||||
@ -86,8 +86,7 @@ func TestAPIRepoTopic(t *testing.T) {
|
|||||||
req := NewRequest(t, "GET", fmt.Sprintf("/api/v1/repos/%s/%s/topics", user2.Name, repo2.Name)).
|
req := NewRequest(t, "GET", fmt.Sprintf("/api/v1/repos/%s/%s/topics", user2.Name, repo2.Name)).
|
||||||
AddTokenAuth(token2)
|
AddTokenAuth(token2)
|
||||||
res := MakeRequest(t, req, http.StatusOK)
|
res := MakeRequest(t, req, http.StatusOK)
|
||||||
var topics *api.TopicName
|
topics := DecodeJSON(t, res, &api.TopicName{})
|
||||||
DecodeJSON(t, res, &topics)
|
|
||||||
assert.ElementsMatch(t, []string{"topicname1", "topicname2"}, topics.TopicNames)
|
assert.ElementsMatch(t, []string{"topicname1", "topicname2"}, topics.TopicNames)
|
||||||
|
|
||||||
// Test delete a topic
|
// Test delete a topic
|
||||||
|
|||||||
@ -32,8 +32,7 @@ func TestAPITeamUser(t *testing.T) {
|
|||||||
// read self user
|
// read self user
|
||||||
req := NewRequest(t, "GET", "/api/v1/teams/1/members/user2").AddTokenAuth(user2Token)
|
req := NewRequest(t, "GET", "/api/v1/teams/1/members/user2").AddTokenAuth(user2Token)
|
||||||
resp := MakeRequest(t, req, http.StatusOK)
|
resp := MakeRequest(t, req, http.StatusOK)
|
||||||
var user2 *api.User
|
user2 := DecodeJSON(t, resp, &api.User{})
|
||||||
DecodeJSON(t, resp, &user2)
|
|
||||||
user2.Created = user2.Created.In(time.Local)
|
user2.Created = user2.Created.In(time.Local)
|
||||||
user := unittest.AssertExistsAndLoadBean(t, &user_model.User{Name: "user2"})
|
user := unittest.AssertExistsAndLoadBean(t, &user_model.User{Name: "user2"})
|
||||||
|
|
||||||
|
|||||||
@ -25,8 +25,7 @@ func TestAPIGetWikiPage(t *testing.T) {
|
|||||||
|
|
||||||
req := NewRequest(t, "GET", urlStr)
|
req := NewRequest(t, "GET", urlStr)
|
||||||
resp := MakeRequest(t, req, http.StatusOK)
|
resp := MakeRequest(t, req, http.StatusOK)
|
||||||
var page *api.WikiPage
|
page := DecodeJSON(t, resp, &api.WikiPage{})
|
||||||
DecodeJSON(t, resp, &page)
|
|
||||||
|
|
||||||
assert.Equal(t, &api.WikiPage{
|
assert.Equal(t, &api.WikiPage{
|
||||||
WikiPageMetaData: &api.WikiPageMetaData{
|
WikiPageMetaData: &api.WikiPageMetaData{
|
||||||
@ -222,8 +221,7 @@ func TestAPIListPageRevisions(t *testing.T) {
|
|||||||
req := NewRequest(t, "GET", urlStr)
|
req := NewRequest(t, "GET", urlStr)
|
||||||
resp := MakeRequest(t, req, http.StatusOK)
|
resp := MakeRequest(t, req, http.StatusOK)
|
||||||
|
|
||||||
var revisions *api.WikiCommitList
|
revisions := DecodeJSON(t, resp, &api.WikiCommitList{})
|
||||||
DecodeJSON(t, resp, &revisions)
|
|
||||||
|
|
||||||
dummyrevisions := &api.WikiCommitList{
|
dummyrevisions := &api.WikiCommitList{
|
||||||
WikiCommits: []*api.WikiCommit{
|
WikiCommits: []*api.WikiCommit{
|
||||||
|
|||||||
@ -4,11 +4,11 @@
|
|||||||
package integration
|
package integration
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"archive/zip"
|
|
||||||
"bytes"
|
"bytes"
|
||||||
"io"
|
"io"
|
||||||
"net/http"
|
"net/http"
|
||||||
"net/http/httptest"
|
"net/http/httptest"
|
||||||
|
"strings"
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
"code.gitea.io/gitea/models/auth"
|
"code.gitea.io/gitea/models/auth"
|
||||||
@ -17,6 +17,7 @@ import (
|
|||||||
"code.gitea.io/gitea/modules/json"
|
"code.gitea.io/gitea/modules/json"
|
||||||
"code.gitea.io/gitea/modules/lfs"
|
"code.gitea.io/gitea/modules/lfs"
|
||||||
"code.gitea.io/gitea/modules/setting"
|
"code.gitea.io/gitea/modules/setting"
|
||||||
|
"code.gitea.io/gitea/modules/test"
|
||||||
"code.gitea.io/gitea/routers/web"
|
"code.gitea.io/gitea/routers/web"
|
||||||
"code.gitea.io/gitea/tests"
|
"code.gitea.io/gitea/tests"
|
||||||
|
|
||||||
@ -24,8 +25,8 @@ import (
|
|||||||
"github.com/stretchr/testify/assert"
|
"github.com/stretchr/testify/assert"
|
||||||
)
|
)
|
||||||
|
|
||||||
func storeObjectInRepo(t *testing.T, repositoryID int64, content *[]byte) string {
|
func storeObjectInRepo(t *testing.T, repositoryID int64, content string) string {
|
||||||
pointer, err := lfs.GeneratePointer(bytes.NewReader(*content))
|
pointer, err := lfs.GeneratePointer(strings.NewReader(content))
|
||||||
assert.NoError(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
_, err = git_model.NewLFSMetaObject(t.Context(), repositoryID, pointer)
|
_, err = git_model.NewLFSMetaObject(t.Context(), repositoryID, pointer)
|
||||||
@ -34,13 +35,13 @@ func storeObjectInRepo(t *testing.T, repositoryID int64, content *[]byte) string
|
|||||||
exist, err := contentStore.Exists(pointer)
|
exist, err := contentStore.Exists(pointer)
|
||||||
assert.NoError(t, err)
|
assert.NoError(t, err)
|
||||||
if !exist {
|
if !exist {
|
||||||
err := contentStore.Put(pointer, bytes.NewReader(*content))
|
err := contentStore.Put(pointer, strings.NewReader(content))
|
||||||
assert.NoError(t, err)
|
assert.NoError(t, err)
|
||||||
}
|
}
|
||||||
return pointer.Oid
|
return pointer.Oid
|
||||||
}
|
}
|
||||||
|
|
||||||
func storeAndGetLfsToken(t *testing.T, content *[]byte, extraHeader *http.Header, expectedStatus int, ts ...auth.AccessTokenScope) *httptest.ResponseRecorder {
|
func storeAndGetLfsToken(t *testing.T, content string, extraHeader *http.Header, expectedStatus int, ts ...auth.AccessTokenScope) *httptest.ResponseRecorder {
|
||||||
repo, err := repo_model.GetRepositoryByOwnerAndName(t.Context(), "user2", "repo1")
|
repo, err := repo_model.GetRepositoryByOwnerAndName(t.Context(), "user2", "repo1")
|
||||||
assert.NoError(t, err)
|
assert.NoError(t, err)
|
||||||
oid := storeObjectInRepo(t, repo.ID, content)
|
oid := storeObjectInRepo(t, repo.ID, content)
|
||||||
@ -65,7 +66,7 @@ func storeAndGetLfsToken(t *testing.T, content *[]byte, extraHeader *http.Header
|
|||||||
return resp
|
return resp
|
||||||
}
|
}
|
||||||
|
|
||||||
func storeAndGetLfs(t *testing.T, content *[]byte, extraHeader *http.Header, expectedStatus int) *httptest.ResponseRecorder {
|
func storeAndGetLfs(t *testing.T, content string, extraHeader *http.Header, expectedStatus int) *httptest.ResponseRecorder {
|
||||||
repo, err := repo_model.GetRepositoryByOwnerAndName(t.Context(), "user2", "repo1")
|
repo, err := repo_model.GetRepositoryByOwnerAndName(t.Context(), "user2", "repo1")
|
||||||
assert.NoError(t, err)
|
assert.NoError(t, err)
|
||||||
oid := storeObjectInRepo(t, repo.ID, content)
|
oid := storeObjectInRepo(t, repo.ID, content)
|
||||||
@ -89,104 +90,84 @@ func storeAndGetLfs(t *testing.T, content *[]byte, extraHeader *http.Header, exp
|
|||||||
return resp
|
return resp
|
||||||
}
|
}
|
||||||
|
|
||||||
func checkResponseTestContentEncoding(t *testing.T, content *[]byte, resp *httptest.ResponseRecorder, expectGzip bool) {
|
func checkResponseTestContentEncoding(t *testing.T, content string, resp *httptest.ResponseRecorder, expectGzip bool) {
|
||||||
contentEncoding := resp.Header().Get("Content-Encoding")
|
contentEncoding := resp.Header().Get("Content-Encoding")
|
||||||
if !expectGzip || !setting.EnableGzip {
|
if !expectGzip || !setting.EnableGzip {
|
||||||
assert.NotContains(t, contentEncoding, "gzip")
|
assert.NotContains(t, contentEncoding, "gzip")
|
||||||
|
assert.Equal(t, content, resp.Body.String())
|
||||||
result := resp.Body.Bytes()
|
|
||||||
assert.Equal(t, *content, result)
|
|
||||||
} else {
|
} else {
|
||||||
assert.Contains(t, contentEncoding, "gzip")
|
assert.Contains(t, contentEncoding, "gzip")
|
||||||
gzippReader, err := gzipp.NewReader(resp.Body)
|
gzipReader, err := gzipp.NewReader(resp.Body)
|
||||||
assert.NoError(t, err)
|
assert.NoError(t, err)
|
||||||
result, err := io.ReadAll(gzippReader)
|
result, err := io.ReadAll(gzipReader)
|
||||||
assert.NoError(t, err)
|
assert.NoError(t, err)
|
||||||
assert.Equal(t, *content, result)
|
assert.Equal(t, content, string(result))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestGetLFSSmall(t *testing.T) {
|
func TestLFSGetObject(t *testing.T) {
|
||||||
defer tests.PrepareTestEnv(t)()
|
defer tests.PrepareTestEnv(t)()
|
||||||
content := []byte("A very small file\n")
|
t.Run("GetLFSSmall", testGetLFSSmall)
|
||||||
|
t.Run("GetLFSSmallToken", testGetLFSSmallToken)
|
||||||
resp := storeAndGetLfs(t, &content, nil, http.StatusOK)
|
t.Run("GetLFSSmallTokenFail", testGetLFSSmallTokenFail)
|
||||||
checkResponseTestContentEncoding(t, &content, resp, false)
|
t.Run("GetLFSLarge", testGetLFSLarge)
|
||||||
|
t.Run("GetLFSGzip", testGetLFSGzip)
|
||||||
|
t.Run("GetLFSZip", testGetLFSZip)
|
||||||
|
t.Run("GetLFSRangeNo", testGetLFSRangeNo)
|
||||||
|
t.Run("GetLFSRange", testGetLFSRange)
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestGetLFSSmallToken(t *testing.T) {
|
func testGetLFSSmall(t *testing.T) {
|
||||||
defer tests.PrepareTestEnv(t)()
|
content := "A very small file\n"
|
||||||
content := []byte("A very small file\n")
|
resp := storeAndGetLfs(t, content, nil, http.StatusOK)
|
||||||
|
checkResponseTestContentEncoding(t, content, resp, false)
|
||||||
resp := storeAndGetLfsToken(t, &content, nil, http.StatusOK, auth.AccessTokenScopePublicOnly, auth.AccessTokenScopeReadRepository)
|
|
||||||
checkResponseTestContentEncoding(t, &content, resp, false)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestGetLFSSmallTokenFail(t *testing.T) {
|
func testGetLFSSmallToken(t *testing.T) {
|
||||||
defer tests.PrepareTestEnv(t)()
|
content := "A very small file\n"
|
||||||
content := []byte("A very small file\n")
|
resp := storeAndGetLfsToken(t, content, nil, http.StatusOK, auth.AccessTokenScopePublicOnly, auth.AccessTokenScopeReadRepository)
|
||||||
|
checkResponseTestContentEncoding(t, content, resp, false)
|
||||||
storeAndGetLfsToken(t, &content, nil, http.StatusForbidden, auth.AccessTokenScopeReadNotification)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestGetLFSLarge(t *testing.T) {
|
func testGetLFSSmallTokenFail(t *testing.T) {
|
||||||
defer tests.PrepareTestEnv(t)()
|
content := "A very small file\n"
|
||||||
content := make([]byte, web.GzipMinSize*10)
|
storeAndGetLfsToken(t, content, nil, http.StatusForbidden, auth.AccessTokenScopeReadNotification)
|
||||||
for i := range content {
|
|
||||||
content[i] = byte(i % 256)
|
|
||||||
}
|
|
||||||
|
|
||||||
resp := storeAndGetLfs(t, &content, nil, http.StatusOK)
|
|
||||||
checkResponseTestContentEncoding(t, &content, resp, true)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestGetLFSGzip(t *testing.T) {
|
func testGetLFSLarge(t *testing.T) {
|
||||||
defer tests.PrepareTestEnv(t)()
|
content := strings.Repeat("a", web.GzipMinSize*10)
|
||||||
b := make([]byte, web.GzipMinSize*10)
|
resp := storeAndGetLfs(t, content, nil, http.StatusOK)
|
||||||
for i := range b {
|
checkResponseTestContentEncoding(t, content, resp, true)
|
||||||
b[i] = byte(i % 256)
|
|
||||||
}
|
|
||||||
outputBuffer := bytes.NewBuffer([]byte{})
|
|
||||||
gzippWriter := gzipp.NewWriter(outputBuffer)
|
|
||||||
gzippWriter.Write(b)
|
|
||||||
gzippWriter.Close()
|
|
||||||
content := outputBuffer.Bytes()
|
|
||||||
|
|
||||||
resp := storeAndGetLfs(t, &content, nil, http.StatusOK)
|
|
||||||
checkResponseTestContentEncoding(t, &content, resp, false)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestGetLFSZip(t *testing.T) {
|
func testGetLFSGzip(t *testing.T) {
|
||||||
defer tests.PrepareTestEnv(t)()
|
s := strings.Repeat("a", web.GzipMinSize*10)
|
||||||
b := make([]byte, web.GzipMinSize*10)
|
outputBuffer := &bytes.Buffer{}
|
||||||
for i := range b {
|
gzipWriter := gzipp.NewWriter(outputBuffer)
|
||||||
b[i] = byte(i % 256)
|
_, _ = gzipWriter.Write([]byte(s))
|
||||||
}
|
_ = gzipWriter.Close()
|
||||||
outputBuffer := bytes.NewBuffer([]byte{})
|
content := outputBuffer.String()
|
||||||
zipWriter := zip.NewWriter(outputBuffer)
|
resp := storeAndGetLfs(t, content, nil, http.StatusOK)
|
||||||
fileWriter, err := zipWriter.Create("default")
|
checkResponseTestContentEncoding(t, content, resp, false)
|
||||||
assert.NoError(t, err)
|
|
||||||
fileWriter.Write(b)
|
|
||||||
zipWriter.Close()
|
|
||||||
content := outputBuffer.Bytes()
|
|
||||||
|
|
||||||
resp := storeAndGetLfs(t, &content, nil, http.StatusOK)
|
|
||||||
checkResponseTestContentEncoding(t, &content, resp, false)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestGetLFSRangeNo(t *testing.T) {
|
func testGetLFSZip(t *testing.T) {
|
||||||
defer tests.PrepareTestEnv(t)()
|
b := strings.Repeat("a", web.GzipMinSize*10)
|
||||||
content := []byte("123456789\n")
|
content := test.WriteZipArchive(map[string]string{"default": b}).String()
|
||||||
|
resp := storeAndGetLfs(t, content, nil, http.StatusOK)
|
||||||
resp := storeAndGetLfs(t, &content, nil, http.StatusOK)
|
checkResponseTestContentEncoding(t, content, resp, false)
|
||||||
assert.Equal(t, content, resp.Body.Bytes())
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestGetLFSRange(t *testing.T) {
|
func testGetLFSRangeNo(t *testing.T) {
|
||||||
defer tests.PrepareTestEnv(t)()
|
content := "123456789\n"
|
||||||
content := []byte("123456789\n")
|
resp := storeAndGetLfs(t, content, nil, http.StatusOK)
|
||||||
|
assert.Equal(t, content, resp.Body.String())
|
||||||
|
}
|
||||||
|
|
||||||
tests := []struct {
|
func testGetLFSRange(t *testing.T) {
|
||||||
|
content := "123456789\n"
|
||||||
|
|
||||||
|
cases := []struct {
|
||||||
in string
|
in string
|
||||||
out string
|
out string
|
||||||
status int
|
status int
|
||||||
@ -207,12 +188,12 @@ func TestGetLFSRange(t *testing.T) {
|
|||||||
{"foobar", "123456789\n", http.StatusOK},
|
{"foobar", "123456789\n", http.StatusOK},
|
||||||
}
|
}
|
||||||
|
|
||||||
for _, tt := range tests {
|
for _, tt := range cases {
|
||||||
t.Run(tt.in, func(t *testing.T) {
|
t.Run(tt.in, func(t *testing.T) {
|
||||||
h := http.Header{
|
h := http.Header{
|
||||||
"Range": []string{tt.in},
|
"Range": []string{tt.in},
|
||||||
}
|
}
|
||||||
resp := storeAndGetLfs(t, &content, &h, tt.status)
|
resp := storeAndGetLfs(t, content, &h, tt.status)
|
||||||
if tt.status == http.StatusPartialContent || tt.status == http.StatusOK {
|
if tt.status == http.StatusPartialContent || tt.status == http.StatusOK {
|
||||||
assert.Equal(t, tt.out, resp.Body.String())
|
assert.Equal(t, tt.out, resp.Body.String())
|
||||||
} else {
|
} else {
|
||||||
|
|||||||
@ -555,8 +555,7 @@ func TestOAuth_GrantScopesReadUserFailRepos(t *testing.T) {
|
|||||||
AddBasicAuth(user.Name)
|
AddBasicAuth(user.Name)
|
||||||
resp := MakeRequest(t, req, http.StatusCreated)
|
resp := MakeRequest(t, req, http.StatusCreated)
|
||||||
|
|
||||||
var app *api.OAuth2Application
|
app := DecodeJSON(t, resp, &api.OAuth2Application{})
|
||||||
DecodeJSON(t, resp, &app)
|
|
||||||
|
|
||||||
grant := &auth_model.OAuth2Grant{
|
grant := &auth_model.OAuth2Grant{
|
||||||
ApplicationID: app.ID,
|
ApplicationID: app.ID,
|
||||||
@ -636,8 +635,7 @@ func TestOAuth_GrantScopesReadRepositoryFailOrganization(t *testing.T) {
|
|||||||
AddBasicAuth(user.Name)
|
AddBasicAuth(user.Name)
|
||||||
resp := MakeRequest(t, req, http.StatusCreated)
|
resp := MakeRequest(t, req, http.StatusCreated)
|
||||||
|
|
||||||
var app *api.OAuth2Application
|
app := DecodeJSON(t, resp, &api.OAuth2Application{})
|
||||||
DecodeJSON(t, resp, &app)
|
|
||||||
|
|
||||||
grant := &auth_model.OAuth2Grant{
|
grant := &auth_model.OAuth2Grant{
|
||||||
ApplicationID: app.ID,
|
ApplicationID: app.ID,
|
||||||
@ -776,8 +774,7 @@ func TestOAuth_GrantScopesClaimPublicOnlyGroups(t *testing.T) {
|
|||||||
AddBasicAuth(user.Name)
|
AddBasicAuth(user.Name)
|
||||||
appResp := MakeRequest(t, appReq, http.StatusCreated)
|
appResp := MakeRequest(t, appReq, http.StatusCreated)
|
||||||
|
|
||||||
var app *api.OAuth2Application
|
app := DecodeJSON(t, appResp, &api.OAuth2Application{})
|
||||||
DecodeJSON(t, appResp, &app)
|
|
||||||
|
|
||||||
grant := &auth_model.OAuth2Grant{
|
grant := &auth_model.OAuth2Grant{
|
||||||
ApplicationID: app.ID,
|
ApplicationID: app.ID,
|
||||||
@ -877,8 +874,7 @@ func TestOAuth_GrantScopesClaimAllGroups(t *testing.T) {
|
|||||||
AddBasicAuth(user.Name)
|
AddBasicAuth(user.Name)
|
||||||
appResp := MakeRequest(t, appReq, http.StatusCreated)
|
appResp := MakeRequest(t, appReq, http.StatusCreated)
|
||||||
|
|
||||||
var app *api.OAuth2Application
|
app := DecodeJSON(t, appResp, &api.OAuth2Application{})
|
||||||
DecodeJSON(t, appResp, &app)
|
|
||||||
|
|
||||||
grant := &auth_model.OAuth2Grant{
|
grant := &auth_model.OAuth2Grant{
|
||||||
ApplicationID: app.ID,
|
ApplicationID: app.ID,
|
||||||
|
|||||||
@ -157,8 +157,7 @@ func TestRepushTag(t *testing.T) {
|
|||||||
// query the release by API and it should be a draft
|
// query the release by API and it should be a draft
|
||||||
req = NewRequest(t, "GET", fmt.Sprintf("/api/v1/repos/%s/%s/releases/tags/%s", owner.Name, repo.Name, "v2.0")).AddTokenAuth(token)
|
req = NewRequest(t, "GET", fmt.Sprintf("/api/v1/repos/%s/%s/releases/tags/%s", owner.Name, repo.Name, "v2.0")).AddTokenAuth(token)
|
||||||
resp := MakeRequest(t, req, http.StatusOK)
|
resp := MakeRequest(t, req, http.StatusOK)
|
||||||
var respRelease *api.Release
|
respRelease := DecodeJSON(t, resp, &api.Release{})
|
||||||
DecodeJSON(t, resp, &respRelease)
|
|
||||||
assert.True(t, respRelease.IsDraft)
|
assert.True(t, respRelease.IsDraft)
|
||||||
|
|
||||||
// re-push the tag
|
// re-push the tag
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user