mirror of
https://codeberg.org/Codeberg/pages-server.git
synced 2024-11-23 06:18:59 +00:00
9076bc3f75
So we can access branch that contain slash like `branch/name` with `username.codeberg.page/repo/@branch~name/`. Branch name cannot contain `~` character but it can be in a HTTP URL, so replace the `~` from URL to `/` could be a valid solution to me. Resolve #101 Co-authored-by: Gary Wang <wzc782970009@gmail.com> Reviewed-on: https://codeberg.org/Codeberg/pages-server/pulls/102 Reviewed-by: 6543 <6543@noreply.codeberg.org> Co-authored-by: Gary Wang <blumia@noreply.codeberg.org> Co-committed-by: Gary Wang <blumia@noreply.codeberg.org>
107 lines
3.4 KiB
Go
107 lines
3.4 KiB
Go
//go:build integration
|
|
// +build integration
|
|
|
|
package integration
|
|
|
|
import (
|
|
"bytes"
|
|
"crypto/tls"
|
|
"io"
|
|
"net/http"
|
|
"net/http/cookiejar"
|
|
"testing"
|
|
|
|
"github.com/rs/zerolog/log"
|
|
"github.com/stretchr/testify/assert"
|
|
)
|
|
|
|
func TestGetRedirect(t *testing.T) {
|
|
log.Printf("=== TestGetRedirect ===\n")
|
|
// test custom domain redirect
|
|
resp, err := getTestHTTPSClient().Get("https://calciumdibromid.localhost.mock.directory:4430")
|
|
assert.NoError(t, err)
|
|
if !assert.EqualValues(t, http.StatusTemporaryRedirect, resp.StatusCode) {
|
|
t.FailNow()
|
|
}
|
|
assert.EqualValues(t, "https://www.cabr2.de/", resp.Header.Get("Location"))
|
|
assert.EqualValues(t, 0, getSize(resp.Body))
|
|
}
|
|
|
|
func TestGetContent(t *testing.T) {
|
|
log.Printf("=== TestGetContent ===\n")
|
|
// test get image
|
|
resp, err := getTestHTTPSClient().Get("https://magiclike.localhost.mock.directory:4430/images/827679288a.jpg")
|
|
assert.NoError(t, err)
|
|
if !assert.EqualValues(t, http.StatusOK, resp.StatusCode) {
|
|
t.FailNow()
|
|
}
|
|
assert.EqualValues(t, "image/jpeg", resp.Header.Get("Content-Type"))
|
|
assert.EqualValues(t, "124635", resp.Header.Get("Content-Length"))
|
|
assert.EqualValues(t, 124635, getSize(resp.Body))
|
|
assert.Len(t, resp.Header.Get("ETag"), 42)
|
|
|
|
// specify branch
|
|
resp, err = getTestHTTPSClient().Get("https://momar.localhost.mock.directory:4430/pag/@master/")
|
|
assert.NoError(t, err)
|
|
if !assert.EqualValues(t, http.StatusOK, resp.StatusCode) {
|
|
t.FailNow()
|
|
}
|
|
assert.EqualValues(t, "text/html; charset=utf-8", resp.Header.Get("Content-Type"))
|
|
assert.True(t, getSize(resp.Body) > 1000)
|
|
assert.Len(t, resp.Header.Get("ETag"), 42)
|
|
|
|
// access branch name contains '/'
|
|
resp, err = getTestHTTPSClient().Get("https://blumia.localhost.mock.directory:4430/pages-server-integration-tests/@docs~main/")
|
|
assert.NoError(t, err)
|
|
if !assert.EqualValues(t, http.StatusOK, resp.StatusCode) {
|
|
t.FailNow()
|
|
}
|
|
assert.EqualValues(t, "text/html; charset=utf-8", resp.Header.Get("Content-Type"))
|
|
assert.True(t, getSize(resp.Body) > 100)
|
|
assert.Len(t, resp.Header.Get("ETag"), 42)
|
|
}
|
|
|
|
func TestCustomDomain(t *testing.T) {
|
|
log.Printf("=== TestCustomDomain ===\n")
|
|
resp, err := getTestHTTPSClient().Get("https://mock-pages.codeberg-test.org:4430/README.md")
|
|
assert.NoError(t, err)
|
|
if !assert.EqualValues(t, http.StatusOK, resp.StatusCode) {
|
|
t.FailNow()
|
|
}
|
|
assert.EqualValues(t, "text/markdown; charset=utf-8", resp.Header.Get("Content-Type"))
|
|
assert.EqualValues(t, "106", resp.Header.Get("Content-Length"))
|
|
assert.EqualValues(t, 106, getSize(resp.Body))
|
|
}
|
|
|
|
func TestGetNotFound(t *testing.T) {
|
|
log.Printf("=== TestGetNotFound ===\n")
|
|
// test custom not found pages
|
|
resp, err := getTestHTTPSClient().Get("https://crystal.localhost.mock.directory:4430/pages-404-demo/blah")
|
|
assert.NoError(t, err)
|
|
if !assert.EqualValues(t, http.StatusNotFound, resp.StatusCode) {
|
|
t.FailNow()
|
|
}
|
|
assert.EqualValues(t, "text/html; charset=utf-8", resp.Header.Get("Content-Type"))
|
|
assert.EqualValues(t, "37", resp.Header.Get("Content-Length"))
|
|
assert.EqualValues(t, 37, getSize(resp.Body))
|
|
}
|
|
|
|
func getTestHTTPSClient() *http.Client {
|
|
cookieJar, _ := cookiejar.New(nil)
|
|
return &http.Client{
|
|
Jar: cookieJar,
|
|
CheckRedirect: func(_ *http.Request, _ []*http.Request) error {
|
|
return http.ErrUseLastResponse
|
|
},
|
|
Transport: &http.Transport{
|
|
TLSClientConfig: &tls.Config{InsecureSkipVerify: true},
|
|
},
|
|
}
|
|
}
|
|
|
|
func getSize(stream io.Reader) int {
|
|
buf := new(bytes.Buffer)
|
|
_, _ = buf.ReadFrom(stream)
|
|
return buf.Len()
|
|
}
|