Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
G
gitlab-ce
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
1
Merge Requests
1
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
nexedi
gitlab-ce
Commits
2460bbbb
Commit
2460bbbb
authored
Aug 25, 2020
by
Jacob Vosmaer
Committed by
Nick Thomas
Aug 25, 2020
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Make more use of testify/require
parent
c17736b6
Changes
16
Show whitespace changes
Inline
Side-by-side
Showing
16 changed files
with
137 additions
and
181 deletions
+137
-181
authorization_test.go
authorization_test.go
+3
-1
gitaly_integration_test.go
gitaly_integration_test.go
+30
-1
internal/artifacts/artifacts_store_test.go
internal/artifacts/artifacts_store_test.go
+6
-6
internal/artifacts/artifacts_upload_test.go
internal/artifacts/artifacts_upload_test.go
+6
-6
internal/artifacts/entry_test.go
internal/artifacts/entry_test.go
+10
-10
internal/git/archive_test.go
internal/git/archive_test.go
+7
-5
internal/git/blob_test.go
internal/git/blob_test.go
+2
-2
internal/sendurl/sendurl_test.go
internal/sendurl/sendurl_test.go
+23
-23
internal/staticpages/deploy_page_test.go
internal/staticpages/deploy_page_test.go
+3
-1
internal/staticpages/error_pages_test.go
internal/staticpages/error_pages_test.go
+7
-7
internal/staticpages/servefile_test.go
internal/staticpages/servefile_test.go
+10
-8
internal/testhelper/testhelper.go
internal/testhelper/testhelper.go
+10
-89
internal/upload/uploads_test.go
internal/upload/uploads_test.go
+9
-9
internal/upstream/development_test.go
internal/upstream/development_test.go
+1
-3
internal/upstream/handlers_test.go
internal/upstream/handlers_test.go
+3
-5
proxy_test.go
proxy_test.go
+7
-5
No files found.
authorization_test.go
View file @
2460bbbb
...
@@ -14,6 +14,8 @@ import (
...
@@ -14,6 +14,8 @@ import (
"gitlab.com/gitlab-org/gitlab-workhorse/internal/secret"
"gitlab.com/gitlab-org/gitlab-workhorse/internal/secret"
"gitlab.com/gitlab-org/gitlab-workhorse/internal/testhelper"
"gitlab.com/gitlab-org/gitlab-workhorse/internal/testhelper"
"gitlab.com/gitlab-org/gitlab-workhorse/internal/upstream/roundtripper"
"gitlab.com/gitlab-org/gitlab-workhorse/internal/upstream/roundtripper"
"github.com/stretchr/testify/require"
)
)
func
okHandler
(
w
http
.
ResponseWriter
,
_
*
http
.
Request
,
_
*
api
.
Response
)
{
func
okHandler
(
w
http
.
ResponseWriter
,
_
*
http
.
Request
,
_
*
api
.
Response
)
{
...
@@ -38,7 +40,7 @@ func runPreAuthorizeHandler(t *testing.T, ts *httptest.Server, suffix string, ur
...
@@ -38,7 +40,7 @@ func runPreAuthorizeHandler(t *testing.T, ts *httptest.Server, suffix string, ur
response
:=
httptest
.
NewRecorder
()
response
:=
httptest
.
NewRecorder
()
a
.
PreAuthorizeHandler
(
okHandler
,
suffix
)
.
ServeHTTP
(
response
,
httpRequest
)
a
.
PreAuthorizeHandler
(
okHandler
,
suffix
)
.
ServeHTTP
(
response
,
httpRequest
)
testhelper
.
RequireResponseCode
(
t
,
response
,
expected
Code
)
require
.
Equal
(
t
,
expectedCode
,
response
.
Code
)
return
response
return
response
}
}
...
...
gitaly_integration_test.go
View file @
2460bbbb
...
@@ -4,13 +4,16 @@ package main
...
@@ -4,13 +4,16 @@ package main
import
(
import
(
"archive/tar"
"archive/tar"
"bufio"
"bytes"
"bytes"
"context"
"context"
"fmt"
"fmt"
"os"
"os"
"os/exec"
"os/exec"
"path"
"path"
"regexp"
"strconv"
"strconv"
"strings"
"testing"
"testing"
"github.com/stretchr/testify/assert"
"github.com/stretchr/testify/assert"
...
@@ -317,7 +320,7 @@ func TestAllowedGetGitFormatPatch(t *testing.T) {
...
@@ -317,7 +320,7 @@ func TestAllowedGetGitFormatPatch(t *testing.T) {
assert
.
Equal
(
t
,
200
,
resp
.
StatusCode
,
"GET %q: status code"
,
resp
.
Request
.
URL
)
assert
.
Equal
(
t
,
200
,
resp
.
StatusCode
,
"GET %q: status code"
,
resp
.
Request
.
URL
)
assertNginxResponseBuffering
(
t
,
"no"
,
resp
,
"GET %q: nginx response buffering"
,
resp
.
Request
.
URL
)
assertNginxResponseBuffering
(
t
,
"no"
,
resp
,
"GET %q: nginx response buffering"
,
resp
.
Request
.
URL
)
testhelper
.
R
equirePatchSeries
(
r
equirePatchSeries
(
t
,
t
,
body
,
body
,
"372ab6950519549b14d220271ee2322caa44d4eb"
,
"372ab6950519549b14d220271ee2322caa44d4eb"
,
...
@@ -327,3 +330,29 @@ func TestAllowedGetGitFormatPatch(t *testing.T) {
...
@@ -327,3 +330,29 @@ func TestAllowedGetGitFormatPatch(t *testing.T) {
rightCommit
,
rightCommit
,
)
)
}
}
var
extractPatchSeriesMatcher
=
regexp
.
MustCompile
(
`^From (\w+)`
)
// RequirePatchSeries takes a `git format-patch` blob, extracts the From xxxxx
// lines and compares the SHAs to expected list.
func
requirePatchSeries
(
t
*
testing
.
T
,
blob
[]
byte
,
expected
...
string
)
{
t
.
Helper
()
var
actual
[]
string
footer
:=
make
([]
string
,
3
)
scanner
:=
bufio
.
NewScanner
(
bytes
.
NewReader
(
blob
))
for
scanner
.
Scan
()
{
line
:=
scanner
.
Text
()
if
matches
:=
extractPatchSeriesMatcher
.
FindStringSubmatch
(
line
);
len
(
matches
)
==
2
{
actual
=
append
(
actual
,
matches
[
1
])
}
footer
=
[]
string
{
footer
[
1
],
footer
[
2
],
line
}
}
require
.
Equal
(
t
,
strings
.
Join
(
expected
,
"
\n
"
),
strings
.
Join
(
actual
,
"
\n
"
),
"patch series"
)
// Check the last returned patch is complete
// Don't assert on the final line, it is a git version
require
.
Equal
(
t
,
"-- "
,
footer
[
0
],
"end of patch marker"
)
}
internal/artifacts/artifacts_store_test.go
View file @
2460bbbb
...
@@ -136,7 +136,7 @@ func TestUploadHandlerSendingToExternalStorage(t *testing.T) {
...
@@ -136,7 +136,7 @@ func TestUploadHandlerSendingToExternalStorage(t *testing.T) {
contentBuffer
,
contentType
:=
createTestMultipartForm
(
t
,
archiveData
)
contentBuffer
,
contentType
:=
createTestMultipartForm
(
t
,
archiveData
)
response
:=
testUploadArtifacts
(
t
,
contentType
,
ts
.
URL
+
Path
,
&
contentBuffer
)
response
:=
testUploadArtifacts
(
t
,
contentType
,
ts
.
URL
+
Path
,
&
contentBuffer
)
testhelper
.
RequireResponseCode
(
t
,
response
,
http
.
StatusOK
)
require
.
Equal
(
t
,
http
.
StatusOK
,
response
.
Code
)
testhelper
.
RequireResponseHeader
(
t
,
response
,
MetadataHeaderKey
,
MetadataHeaderPresent
)
testhelper
.
RequireResponseHeader
(
t
,
response
,
MetadataHeaderKey
,
MetadataHeaderPresent
)
assert
.
Equal
(
t
,
1
,
storeServerCalled
,
"store should be called only once"
)
assert
.
Equal
(
t
,
1
,
storeServerCalled
,
"store should be called only once"
)
assert
.
Equal
(
t
,
1
,
responseProcessorCalled
,
"response processor should be called only once"
)
assert
.
Equal
(
t
,
1
,
responseProcessorCalled
,
"response processor should be called only once"
)
...
@@ -167,7 +167,7 @@ func TestUploadHandlerSendingToExternalStorageAndStorageServerUnreachable(t *tes
...
@@ -167,7 +167,7 @@ func TestUploadHandlerSendingToExternalStorageAndStorageServerUnreachable(t *tes
defer
ts
.
Close
()
defer
ts
.
Close
()
response
:=
testUploadArtifactsFromTestZip
(
t
,
ts
)
response
:=
testUploadArtifactsFromTestZip
(
t
,
ts
)
testhelper
.
RequireResponseCode
(
t
,
response
,
http
.
StatusInternalServerError
)
require
.
Equal
(
t
,
http
.
StatusInternalServerError
,
response
.
Code
)
}
}
func
TestUploadHandlerSendingToExternalStorageAndInvalidURLIsUsed
(
t
*
testing
.
T
)
{
func
TestUploadHandlerSendingToExternalStorageAndInvalidURLIsUsed
(
t
*
testing
.
T
)
{
...
@@ -193,7 +193,7 @@ func TestUploadHandlerSendingToExternalStorageAndInvalidURLIsUsed(t *testing.T)
...
@@ -193,7 +193,7 @@ func TestUploadHandlerSendingToExternalStorageAndInvalidURLIsUsed(t *testing.T)
defer
ts
.
Close
()
defer
ts
.
Close
()
response
:=
testUploadArtifactsFromTestZip
(
t
,
ts
)
response
:=
testUploadArtifactsFromTestZip
(
t
,
ts
)
testhelper
.
RequireResponseCode
(
t
,
response
,
http
.
StatusInternalServerError
)
require
.
Equal
(
t
,
http
.
StatusInternalServerError
,
response
.
Code
)
}
}
func
TestUploadHandlerSendingToExternalStorageAndItReturnsAnError
(
t
*
testing
.
T
)
{
func
TestUploadHandlerSendingToExternalStorageAndItReturnsAnError
(
t
*
testing
.
T
)
{
...
@@ -231,7 +231,7 @@ func TestUploadHandlerSendingToExternalStorageAndItReturnsAnError(t *testing.T)
...
@@ -231,7 +231,7 @@ func TestUploadHandlerSendingToExternalStorageAndItReturnsAnError(t *testing.T)
defer
ts
.
Close
()
defer
ts
.
Close
()
response
:=
testUploadArtifactsFromTestZip
(
t
,
ts
)
response
:=
testUploadArtifactsFromTestZip
(
t
,
ts
)
testhelper
.
RequireResponseCode
(
t
,
response
,
http
.
StatusInternalServerError
)
require
.
Equal
(
t
,
http
.
StatusInternalServerError
,
response
.
Code
)
assert
.
Equal
(
t
,
1
,
putCalledTimes
,
"upload should be called only once"
)
assert
.
Equal
(
t
,
1
,
putCalledTimes
,
"upload should be called only once"
)
}
}
...
@@ -272,7 +272,7 @@ func TestUploadHandlerSendingToExternalStorageAndSupportRequestTimeout(t *testin
...
@@ -272,7 +272,7 @@ func TestUploadHandlerSendingToExternalStorageAndSupportRequestTimeout(t *testin
defer
ts
.
Close
()
defer
ts
.
Close
()
response
:=
testUploadArtifactsFromTestZip
(
t
,
ts
)
response
:=
testUploadArtifactsFromTestZip
(
t
,
ts
)
testhelper
.
RequireResponseCode
(
t
,
response
,
http
.
StatusInternalServerError
)
require
.
Equal
(
t
,
http
.
StatusInternalServerError
,
response
.
Code
)
assert
.
Equal
(
t
,
1
,
putCalledTimes
,
"upload should be called only once"
)
assert
.
Equal
(
t
,
1
,
putCalledTimes
,
"upload should be called only once"
)
}
}
...
@@ -308,7 +308,7 @@ func TestUploadHandlerMultipartUploadSizeLimit(t *testing.T) {
...
@@ -308,7 +308,7 @@ func TestUploadHandlerMultipartUploadSizeLimit(t *testing.T) {
contentBuffer
,
contentType
:=
createTestMultipartForm
(
t
,
make
([]
byte
,
uploadSize
))
contentBuffer
,
contentType
:=
createTestMultipartForm
(
t
,
make
([]
byte
,
uploadSize
))
response
:=
testUploadArtifacts
(
t
,
contentType
,
ts
.
URL
+
Path
,
&
contentBuffer
)
response
:=
testUploadArtifacts
(
t
,
contentType
,
ts
.
URL
+
Path
,
&
contentBuffer
)
testhelper
.
RequireResponseCode
(
t
,
response
,
http
.
StatusRequestEntityTooLarg
e
)
require
.
Equal
(
t
,
http
.
StatusRequestEntityTooLarge
,
response
.
Cod
e
)
// Poll because AbortMultipartUpload is async
// Poll because AbortMultipartUpload is async
for
i
:=
0
;
os
.
IsMultipartUpload
(
test
.
ObjectPath
)
&&
i
<
100
;
i
++
{
for
i
:=
0
;
os
.
IsMultipartUpload
(
test
.
ObjectPath
)
&&
i
<
100
;
i
++
{
...
...
internal/artifacts/artifacts_upload_test.go
View file @
2460bbbb
...
@@ -184,7 +184,7 @@ func TestUploadHandlerAddingMetadata(t *testing.T) {
...
@@ -184,7 +184,7 @@ func TestUploadHandlerAddingMetadata(t *testing.T) {
require
.
NoError
(
t
,
s
.
writer
.
Close
())
require
.
NoError
(
t
,
s
.
writer
.
Close
())
response
:=
testUploadArtifacts
(
t
,
s
.
writer
.
FormDataContentType
(),
s
.
url
,
s
.
buffer
)
response
:=
testUploadArtifacts
(
t
,
s
.
writer
.
FormDataContentType
(),
s
.
url
,
s
.
buffer
)
testhelper
.
RequireResponseCode
(
t
,
response
,
http
.
StatusOK
)
require
.
Equal
(
t
,
http
.
StatusOK
,
response
.
Code
)
testhelper
.
RequireResponseHeader
(
t
,
response
,
MetadataHeaderKey
,
MetadataHeaderPresent
)
testhelper
.
RequireResponseHeader
(
t
,
response
,
MetadataHeaderKey
,
MetadataHeaderPresent
)
}
}
...
@@ -194,7 +194,7 @@ func TestUploadHandlerForUnsupportedArchive(t *testing.T) {
...
@@ -194,7 +194,7 @@ func TestUploadHandlerForUnsupportedArchive(t *testing.T) {
require
.
NoError
(
t
,
s
.
writer
.
Close
())
require
.
NoError
(
t
,
s
.
writer
.
Close
())
response
:=
testUploadArtifacts
(
t
,
s
.
writer
.
FormDataContentType
(),
s
.
url
,
s
.
buffer
)
response
:=
testUploadArtifacts
(
t
,
s
.
writer
.
FormDataContentType
(),
s
.
url
,
s
.
buffer
)
testhelper
.
RequireResponseCode
(
t
,
response
,
http
.
StatusOK
)
require
.
Equal
(
t
,
http
.
StatusOK
,
response
.
Code
)
testhelper
.
RequireResponseHeader
(
t
,
response
,
MetadataHeaderKey
,
MetadataHeaderMissing
)
testhelper
.
RequireResponseHeader
(
t
,
response
,
MetadataHeaderKey
,
MetadataHeaderMissing
)
}
}
...
@@ -208,7 +208,7 @@ func TestUploadHandlerForMultipleFiles(t *testing.T) {
...
@@ -208,7 +208,7 @@ func TestUploadHandlerForMultipleFiles(t *testing.T) {
require
.
NoError
(
t
,
s
.
writer
.
Close
())
require
.
NoError
(
t
,
s
.
writer
.
Close
())
response
:=
testUploadArtifacts
(
t
,
s
.
writer
.
FormDataContentType
(),
s
.
url
,
s
.
buffer
)
response
:=
testUploadArtifacts
(
t
,
s
.
writer
.
FormDataContentType
(),
s
.
url
,
s
.
buffer
)
testhelper
.
RequireResponseCode
(
t
,
response
,
http
.
StatusInternalServerError
)
require
.
Equal
(
t
,
http
.
StatusInternalServerError
,
response
.
Code
)
}
}
func
TestUploadFormProcessing
(
t
*
testing
.
T
)
{
func
TestUploadFormProcessing
(
t
*
testing
.
T
)
{
...
@@ -217,7 +217,7 @@ func TestUploadFormProcessing(t *testing.T) {
...
@@ -217,7 +217,7 @@ func TestUploadFormProcessing(t *testing.T) {
require
.
NoError
(
t
,
s
.
writer
.
Close
())
require
.
NoError
(
t
,
s
.
writer
.
Close
())
response
:=
testUploadArtifacts
(
t
,
s
.
writer
.
FormDataContentType
(),
s
.
url
,
s
.
buffer
)
response
:=
testUploadArtifacts
(
t
,
s
.
writer
.
FormDataContentType
(),
s
.
url
,
s
.
buffer
)
testhelper
.
RequireResponseCode
(
t
,
response
,
http
.
StatusInternalServerError
)
require
.
Equal
(
t
,
http
.
StatusInternalServerError
,
response
.
Code
)
}
}
func
TestLsifFileProcessing
(
t
*
testing
.
T
)
{
func
TestLsifFileProcessing
(
t
*
testing
.
T
)
{
...
@@ -236,7 +236,7 @@ func TestLsifFileProcessing(t *testing.T) {
...
@@ -236,7 +236,7 @@ func TestLsifFileProcessing(t *testing.T) {
require
.
NoError
(
t
,
s
.
writer
.
Close
())
require
.
NoError
(
t
,
s
.
writer
.
Close
())
response
:=
testUploadArtifacts
(
t
,
s
.
writer
.
FormDataContentType
(),
s
.
url
,
s
.
buffer
)
response
:=
testUploadArtifacts
(
t
,
s
.
writer
.
FormDataContentType
(),
s
.
url
,
s
.
buffer
)
testhelper
.
RequireResponseCode
(
t
,
response
,
http
.
StatusOK
)
require
.
Equal
(
t
,
http
.
StatusOK
,
response
.
Code
)
testhelper
.
RequireResponseHeader
(
t
,
response
,
MetadataHeaderKey
,
MetadataHeaderPresent
)
testhelper
.
RequireResponseHeader
(
t
,
response
,
MetadataHeaderKey
,
MetadataHeaderPresent
)
}
}
...
@@ -256,5 +256,5 @@ func TestInvalidLsifFileProcessing(t *testing.T) {
...
@@ -256,5 +256,5 @@ func TestInvalidLsifFileProcessing(t *testing.T) {
require
.
NoError
(
t
,
s
.
writer
.
Close
())
require
.
NoError
(
t
,
s
.
writer
.
Close
())
response
:=
testUploadArtifacts
(
t
,
s
.
writer
.
FormDataContentType
(),
s
.
url
,
s
.
buffer
)
response
:=
testUploadArtifacts
(
t
,
s
.
writer
.
FormDataContentType
(),
s
.
url
,
s
.
buffer
)
testhelper
.
RequireResponseCode
(
t
,
response
,
http
.
StatusInternalServerError
)
require
.
Equal
(
t
,
http
.
StatusInternalServerError
,
response
.
Code
)
}
}
internal/artifacts/entry_test.go
View file @
2460bbbb
...
@@ -50,12 +50,12 @@ func TestDownloadingFromValidArchive(t *testing.T) {
...
@@ -50,12 +50,12 @@ func TestDownloadingFromValidArchive(t *testing.T) {
response
:=
testEntryServer
(
t
,
tempFile
.
Name
(),
"test.txt"
)
response
:=
testEntryServer
(
t
,
tempFile
.
Name
(),
"test.txt"
)
testhelper
.
RequireResponseCode
(
t
,
response
,
200
)
require
.
Equal
(
t
,
200
,
response
.
Code
)
testhelper
.
RequireResponse
Writer
Header
(
t
,
response
,
testhelper
.
RequireResponseHeader
(
t
,
response
,
"Content-Type"
,
"Content-Type"
,
"text/plain; charset=utf-8"
)
"text/plain; charset=utf-8"
)
testhelper
.
RequireResponse
Writer
Header
(
t
,
response
,
testhelper
.
RequireResponseHeader
(
t
,
response
,
"Content-Disposition"
,
"Content-Disposition"
,
"attachment; filename=
\"
test.txt
\"
"
)
"attachment; filename=
\"
test.txt
\"
"
)
...
@@ -84,12 +84,12 @@ func TestDownloadingFromValidHTTPArchive(t *testing.T) {
...
@@ -84,12 +84,12 @@ func TestDownloadingFromValidHTTPArchive(t *testing.T) {
response
:=
testEntryServer
(
t
,
fileServer
.
URL
+
"/archive.zip"
,
"test.txt"
)
response
:=
testEntryServer
(
t
,
fileServer
.
URL
+
"/archive.zip"
,
"test.txt"
)
testhelper
.
RequireResponseCode
(
t
,
response
,
200
)
require
.
Equal
(
t
,
200
,
response
.
Code
)
testhelper
.
RequireResponse
Writer
Header
(
t
,
response
,
testhelper
.
RequireResponseHeader
(
t
,
response
,
"Content-Type"
,
"Content-Type"
,
"text/plain; charset=utf-8"
)
"text/plain; charset=utf-8"
)
testhelper
.
RequireResponse
Writer
Header
(
t
,
response
,
testhelper
.
RequireResponseHeader
(
t
,
response
,
"Content-Disposition"
,
"Content-Disposition"
,
"attachment; filename=
\"
test.txt
\"
"
)
"attachment; filename=
\"
test.txt
\"
"
)
...
@@ -107,17 +107,17 @@ func TestDownloadingNonExistingFile(t *testing.T) {
...
@@ -107,17 +107,17 @@ func TestDownloadingNonExistingFile(t *testing.T) {
archive
.
Close
()
archive
.
Close
()
response
:=
testEntryServer
(
t
,
tempFile
.
Name
(),
"test"
)
response
:=
testEntryServer
(
t
,
tempFile
.
Name
(),
"test"
)
testhelper
.
RequireResponseCode
(
t
,
response
,
404
)
require
.
Equal
(
t
,
404
,
response
.
Code
)
}
}
func
TestDownloadingFromInvalidArchive
(
t
*
testing
.
T
)
{
func
TestDownloadingFromInvalidArchive
(
t
*
testing
.
T
)
{
response
:=
testEntryServer
(
t
,
"path/to/non/existing/file"
,
"test"
)
response
:=
testEntryServer
(
t
,
"path/to/non/existing/file"
,
"test"
)
testhelper
.
RequireResponseCode
(
t
,
response
,
404
)
require
.
Equal
(
t
,
404
,
response
.
Code
)
}
}
func
TestIncompleteApiResponse
(
t
*
testing
.
T
)
{
func
TestIncompleteApiResponse
(
t
*
testing
.
T
)
{
response
:=
testEntryServer
(
t
,
""
,
""
)
response
:=
testEntryServer
(
t
,
""
,
""
)
testhelper
.
RequireResponseCode
(
t
,
response
,
500
)
require
.
Equal
(
t
,
500
,
response
.
Code
)
}
}
func
TestDownloadingFromNonExistingHTTPArchive
(
t
*
testing
.
T
)
{
func
TestDownloadingFromNonExistingHTTPArchive
(
t
*
testing
.
T
)
{
...
@@ -130,5 +130,5 @@ func TestDownloadingFromNonExistingHTTPArchive(t *testing.T) {
...
@@ -130,5 +130,5 @@ func TestDownloadingFromNonExistingHTTPArchive(t *testing.T) {
response
:=
testEntryServer
(
t
,
fileServer
.
URL
+
"/not-existing-archive-file.zip"
,
"test.txt"
)
response
:=
testEntryServer
(
t
,
fileServer
.
URL
+
"/not-existing-archive-file.zip"
,
"test.txt"
)
testhelper
.
RequireResponseCode
(
t
,
response
,
404
)
require
.
Equal
(
t
,
404
,
response
.
Code
)
}
}
internal/git/archive_test.go
View file @
2460bbbb
...
@@ -8,6 +8,8 @@ import (
...
@@ -8,6 +8,8 @@ import (
"gitlab.com/gitlab-org/gitaly/proto/go/gitalypb"
"gitlab.com/gitlab-org/gitaly/proto/go/gitalypb"
"gitlab.com/gitlab-org/gitlab-workhorse/internal/testhelper"
"gitlab.com/gitlab-org/gitlab-workhorse/internal/testhelper"
"github.com/stretchr/testify/require"
)
)
func
TestParseBasename
(
t
*
testing
.
T
)
{
func
TestParseBasename
(
t
*
testing
.
T
)
{
...
@@ -76,10 +78,10 @@ func TestSetArchiveHeaders(t *testing.T) {
...
@@ -76,10 +78,10 @@ func TestSetArchiveHeaders(t *testing.T) {
setArchiveHeaders
(
w
,
testCase
.
in
,
"filename"
)
setArchiveHeaders
(
w
,
testCase
.
in
,
"filename"
)
testhelper
.
RequireResponse
Writer
Header
(
t
,
w
,
"Content-Type"
,
testCase
.
out
)
testhelper
.
RequireResponseHeader
(
t
,
w
,
"Content-Type"
,
testCase
.
out
)
testhelper
.
RequireResponse
Writer
Header
(
t
,
w
,
"Content-Length"
)
testhelper
.
RequireResponseHeader
(
t
,
w
,
"Content-Length"
)
testhelper
.
RequireResponse
Writer
Header
(
t
,
w
,
"Content-Disposition"
,
`attachment; filename="filename"`
)
testhelper
.
RequireResponseHeader
(
t
,
w
,
"Content-Disposition"
,
`attachment; filename="filename"`
)
testhelper
.
RequireResponse
Writer
Header
(
t
,
w
,
"Cache-Control"
,
"public, max-age=3600"
)
testhelper
.
RequireResponseHeader
(
t
,
w
,
"Cache-Control"
,
"public, max-age=3600"
)
testhelper
.
RequireAbsentResponseWriterHeader
(
t
,
w
,
"
Set-Cookie"
)
require
.
Empty
(
t
,
w
.
Header
()
.
Get
(
"Set-Cookie"
),
"remove
Set-Cookie"
)
}
}
}
}
internal/git/blob_test.go
View file @
2460bbbb
...
@@ -4,7 +4,7 @@ import (
...
@@ -4,7 +4,7 @@ import (
"net/http/httptest"
"net/http/httptest"
"testing"
"testing"
"git
lab.com/gitlab-org/gitlab-workhorse/internal/testhelper
"
"git
hub.com/stretchr/testify/require
"
)
)
func
TestSetBlobHeaders
(
t
*
testing
.
T
)
{
func
TestSetBlobHeaders
(
t
*
testing
.
T
)
{
...
@@ -13,5 +13,5 @@ func TestSetBlobHeaders(t *testing.T) {
...
@@ -13,5 +13,5 @@ func TestSetBlobHeaders(t *testing.T) {
setBlobHeaders
(
w
)
setBlobHeaders
(
w
)
testhelper
.
RequireAbsentResponseWriterHeader
(
t
,
w
,
"
Set-Cookie"
)
require
.
Empty
(
t
,
w
.
Header
()
.
Get
(
"Set-Cookie"
),
"remove
Set-Cookie"
)
}
}
internal/sendurl/sendurl_test.go
View file @
2460bbbb
...
@@ -84,12 +84,12 @@ func testEntryServer(t *testing.T, requestURL string, httpHeaders http.Header, a
...
@@ -84,12 +84,12 @@ func testEntryServer(t *testing.T, requestURL string, httpHeaders http.Header, a
func
TestDownloadingUsingSendURL
(
t
*
testing
.
T
)
{
func
TestDownloadingUsingSendURL
(
t
*
testing
.
T
)
{
response
:=
testEntryServer
(
t
,
"/get/request"
,
nil
,
false
)
response
:=
testEntryServer
(
t
,
"/get/request"
,
nil
,
false
)
testhelper
.
RequireResponseCode
(
t
,
response
,
http
.
StatusOK
)
require
.
Equal
(
t
,
http
.
StatusOK
,
response
.
Code
)
testhelper
.
RequireResponse
Writer
Header
(
t
,
response
,
testhelper
.
RequireResponseHeader
(
t
,
response
,
"Content-Type"
,
"Content-Type"
,
"text/plain; charset=utf-8"
)
"text/plain; charset=utf-8"
)
testhelper
.
RequireResponse
Writer
Header
(
t
,
response
,
testhelper
.
RequireResponseHeader
(
t
,
response
,
"Content-Disposition"
,
"Content-Disposition"
,
"attachment; filename=
\"
archive.txt
\"
"
)
"attachment; filename=
\"
archive.txt
\"
"
)
...
@@ -104,15 +104,15 @@ func TestDownloadingAChunkOfDataWithSendURL(t *testing.T) {
...
@@ -104,15 +104,15 @@ func TestDownloadingAChunkOfDataWithSendURL(t *testing.T) {
}
}
response
:=
testEntryServer
(
t
,
"/get/request"
,
httpHeaders
,
false
)
response
:=
testEntryServer
(
t
,
"/get/request"
,
httpHeaders
,
false
)
testhelper
.
RequireResponseCode
(
t
,
response
,
http
.
StatusPartialContent
)
require
.
Equal
(
t
,
http
.
StatusPartialContent
,
response
.
Code
)
testhelper
.
RequireResponse
Writer
Header
(
t
,
response
,
testhelper
.
RequireResponseHeader
(
t
,
response
,
"Content-Type"
,
"Content-Type"
,
"text/plain; charset=utf-8"
)
"text/plain; charset=utf-8"
)
testhelper
.
RequireResponse
Writer
Header
(
t
,
response
,
testhelper
.
RequireResponseHeader
(
t
,
response
,
"Content-Disposition"
,
"Content-Disposition"
,
"attachment; filename=
\"
archive.txt
\"
"
)
"attachment; filename=
\"
archive.txt
\"
"
)
testhelper
.
RequireResponse
Writer
Header
(
t
,
response
,
testhelper
.
RequireResponseHeader
(
t
,
response
,
"Content-Range"
,
"Content-Range"
,
"bytes 1-2/30"
)
"bytes 1-2/30"
)
...
@@ -125,22 +125,22 @@ func TestAccessingAlreadyDownloadedFileWithSendURL(t *testing.T) {
...
@@ -125,22 +125,22 @@ func TestAccessingAlreadyDownloadedFileWithSendURL(t *testing.T) {
}
}
response
:=
testEntryServer
(
t
,
"/get/request"
,
httpHeaders
,
false
)
response
:=
testEntryServer
(
t
,
"/get/request"
,
httpHeaders
,
false
)
testhelper
.
RequireResponseCode
(
t
,
response
,
http
.
StatusNotModified
)
require
.
Equal
(
t
,
http
.
StatusNotModified
,
response
.
Code
)
}
}
func
TestAccessingRedirectWithSendURL
(
t
*
testing
.
T
)
{
func
TestAccessingRedirectWithSendURL
(
t
*
testing
.
T
)
{
response
:=
testEntryServer
(
t
,
"/get/redirect"
,
nil
,
false
)
response
:=
testEntryServer
(
t
,
"/get/redirect"
,
nil
,
false
)
testhelper
.
RequireResponseCode
(
t
,
response
,
http
.
StatusTemporaryRedirect
)
require
.
Equal
(
t
,
http
.
StatusTemporaryRedirect
,
response
.
Code
)
}
}
func
TestAccessingAllowedRedirectWithSendURL
(
t
*
testing
.
T
)
{
func
TestAccessingAllowedRedirectWithSendURL
(
t
*
testing
.
T
)
{
response
:=
testEntryServer
(
t
,
"/get/redirect"
,
nil
,
true
)
response
:=
testEntryServer
(
t
,
"/get/redirect"
,
nil
,
true
)
testhelper
.
RequireResponseCode
(
t
,
response
,
http
.
StatusOK
)
require
.
Equal
(
t
,
http
.
StatusOK
,
response
.
Code
)
testhelper
.
RequireResponse
Writer
Header
(
t
,
response
,
testhelper
.
RequireResponseHeader
(
t
,
response
,
"Content-Type"
,
"Content-Type"
,
"text/plain; charset=utf-8"
)
"text/plain; charset=utf-8"
)
testhelper
.
RequireResponse
Writer
Header
(
t
,
response
,
testhelper
.
RequireResponseHeader
(
t
,
response
,
"Content-Disposition"
,
"Content-Disposition"
,
"attachment; filename=
\"
archive.txt
\"
"
)
"attachment; filename=
\"
archive.txt
\"
"
)
}
}
...
@@ -153,15 +153,15 @@ func TestAccessingAllowedRedirectWithChunkOfDataWithSendURL(t *testing.T) {
...
@@ -153,15 +153,15 @@ func TestAccessingAllowedRedirectWithChunkOfDataWithSendURL(t *testing.T) {
}
}
response
:=
testEntryServer
(
t
,
"/get/redirect"
,
httpHeaders
,
true
)
response
:=
testEntryServer
(
t
,
"/get/redirect"
,
httpHeaders
,
true
)
testhelper
.
RequireResponseCode
(
t
,
response
,
http
.
StatusPartialContent
)
require
.
Equal
(
t
,
http
.
StatusPartialContent
,
response
.
Code
)
testhelper
.
RequireResponse
Writer
Header
(
t
,
response
,
testhelper
.
RequireResponseHeader
(
t
,
response
,
"Content-Type"
,
"Content-Type"
,
"text/plain; charset=utf-8"
)
"text/plain; charset=utf-8"
)
testhelper
.
RequireResponse
Writer
Header
(
t
,
response
,
testhelper
.
RequireResponseHeader
(
t
,
response
,
"Content-Disposition"
,
"Content-Disposition"
,
"attachment; filename=
\"
archive.txt
\"
"
)
"attachment; filename=
\"
archive.txt
\"
"
)
testhelper
.
RequireResponse
Writer
Header
(
t
,
response
,
testhelper
.
RequireResponseHeader
(
t
,
response
,
"Content-Range"
,
"Content-Range"
,
"bytes 1-2/30"
)
"bytes 1-2/30"
)
...
@@ -170,28 +170,28 @@ func TestAccessingAllowedRedirectWithChunkOfDataWithSendURL(t *testing.T) {
...
@@ -170,28 +170,28 @@ func TestAccessingAllowedRedirectWithChunkOfDataWithSendURL(t *testing.T) {
func
TestOriginalCacheHeadersPreservedWithSendURL
(
t
*
testing
.
T
)
{
func
TestOriginalCacheHeadersPreservedWithSendURL
(
t
*
testing
.
T
)
{
response
:=
testEntryServer
(
t
,
"/get/redirect"
,
nil
,
true
)
response
:=
testEntryServer
(
t
,
"/get/redirect"
,
nil
,
true
)
testhelper
.
RequireResponseCode
(
t
,
response
,
http
.
StatusOK
)
require
.
Equal
(
t
,
http
.
StatusOK
,
response
.
Code
)
testhelper
.
RequireResponse
Writer
Header
(
t
,
response
,
testhelper
.
RequireResponseHeader
(
t
,
response
,
"Cache-Control"
,
"Cache-Control"
,
"no-cache"
)
"no-cache"
)
testhelper
.
RequireResponse
Writer
Header
(
t
,
response
,
testhelper
.
RequireResponseHeader
(
t
,
response
,
"Expires"
,
"Expires"
,
""
)
""
)
testhelper
.
RequireResponse
Writer
Header
(
t
,
response
,
testhelper
.
RequireResponseHeader
(
t
,
response
,
"Date"
,
"Date"
,
"Wed, 21 Oct 2015 05:28:00 GMT"
)
"Wed, 21 Oct 2015 05:28:00 GMT"
)
testhelper
.
RequireResponse
Writer
Header
(
t
,
response
,
testhelper
.
RequireResponseHeader
(
t
,
response
,
"Pragma"
,
"Pragma"
,
"no-cache"
)
"no-cache"
)
}
}
func
TestDownloadingNonExistingFileUsingSendURL
(
t
*
testing
.
T
)
{
func
TestDownloadingNonExistingFileUsingSendURL
(
t
*
testing
.
T
)
{
response
:=
testEntryServer
(
t
,
"/invalid/path"
,
nil
,
false
)
response
:=
testEntryServer
(
t
,
"/invalid/path"
,
nil
,
false
)
testhelper
.
RequireResponseCode
(
t
,
response
,
http
.
StatusNotFound
)
require
.
Equal
(
t
,
http
.
StatusNotFound
,
response
.
Code
)
}
}
func
TestDownloadingNonExistingRemoteFileWithSendURL
(
t
*
testing
.
T
)
{
func
TestDownloadingNonExistingRemoteFileWithSendURL
(
t
*
testing
.
T
)
{
response
:=
testEntryServer
(
t
,
"/get/file-not-existing"
,
nil
,
false
)
response
:=
testEntryServer
(
t
,
"/get/file-not-existing"
,
nil
,
false
)
testhelper
.
RequireResponseCode
(
t
,
response
,
http
.
StatusNotFound
)
require
.
Equal
(
t
,
http
.
StatusNotFound
,
response
.
Code
)
}
}
internal/staticpages/deploy_page_test.go
View file @
2460bbbb
...
@@ -9,6 +9,8 @@ import (
...
@@ -9,6 +9,8 @@ import (
"testing"
"testing"
"gitlab.com/gitlab-org/gitlab-workhorse/internal/testhelper"
"gitlab.com/gitlab-org/gitlab-workhorse/internal/testhelper"
"github.com/stretchr/testify/require"
)
)
func
TestIfNoDeployPageExist
(
t
*
testing
.
T
)
{
func
TestIfNoDeployPageExist
(
t
*
testing
.
T
)
{
...
@@ -52,6 +54,6 @@ func TestIfDeployPageExist(t *testing.T) {
...
@@ -52,6 +54,6 @@ func TestIfDeployPageExist(t *testing.T) {
}
}
w
.
Flush
()
w
.
Flush
()
testhelper
.
RequireResponseCode
(
t
,
w
,
200
)
require
.
Equal
(
t
,
200
,
w
.
Code
)
testhelper
.
RequireResponseBody
(
t
,
w
,
deployPage
)
testhelper
.
RequireResponseBody
(
t
,
w
,
deployPage
)
}
}
internal/staticpages/error_pages_test.go
View file @
2460bbbb
...
@@ -36,7 +36,7 @@ func TestIfErrorPageIsPresented(t *testing.T) {
...
@@ -36,7 +36,7 @@ func TestIfErrorPageIsPresented(t *testing.T) {
st
.
ErrorPagesUnless
(
false
,
ErrorFormatHTML
,
h
)
.
ServeHTTP
(
w
,
nil
)
st
.
ErrorPagesUnless
(
false
,
ErrorFormatHTML
,
h
)
.
ServeHTTP
(
w
,
nil
)
w
.
Flush
()
w
.
Flush
()
testhelper
.
RequireResponseCode
(
t
,
w
,
404
)
require
.
Equal
(
t
,
404
,
w
.
Code
)
testhelper
.
RequireResponseBody
(
t
,
w
,
errorPage
)
testhelper
.
RequireResponseBody
(
t
,
w
,
errorPage
)
testhelper
.
RequireResponseHeader
(
t
,
w
,
"Content-Type"
,
"text/html; charset=utf-8"
)
testhelper
.
RequireResponseHeader
(
t
,
w
,
"Content-Type"
,
"text/html; charset=utf-8"
)
}
}
...
@@ -58,7 +58,7 @@ func TestIfErrorPassedIfNoErrorPageIsFound(t *testing.T) {
...
@@ -58,7 +58,7 @@ func TestIfErrorPassedIfNoErrorPageIsFound(t *testing.T) {
st
.
ErrorPagesUnless
(
false
,
ErrorFormatHTML
,
h
)
.
ServeHTTP
(
w
,
nil
)
st
.
ErrorPagesUnless
(
false
,
ErrorFormatHTML
,
h
)
.
ServeHTTP
(
w
,
nil
)
w
.
Flush
()
w
.
Flush
()
testhelper
.
RequireResponseCode
(
t
,
w
,
404
)
require
.
Equal
(
t
,
404
,
w
.
Code
)
testhelper
.
RequireResponseBody
(
t
,
w
,
errorResponse
)
testhelper
.
RequireResponseBody
(
t
,
w
,
errorResponse
)
}
}
...
@@ -81,7 +81,7 @@ func TestIfErrorPageIsIgnoredInDevelopment(t *testing.T) {
...
@@ -81,7 +81,7 @@ func TestIfErrorPageIsIgnoredInDevelopment(t *testing.T) {
st
:=
&
Static
{
dir
}
st
:=
&
Static
{
dir
}
st
.
ErrorPagesUnless
(
true
,
ErrorFormatHTML
,
h
)
.
ServeHTTP
(
w
,
nil
)
st
.
ErrorPagesUnless
(
true
,
ErrorFormatHTML
,
h
)
.
ServeHTTP
(
w
,
nil
)
w
.
Flush
()
w
.
Flush
()
testhelper
.
RequireResponseCode
(
t
,
w
,
500
)
require
.
Equal
(
t
,
500
,
w
.
Code
)
testhelper
.
RequireResponseBody
(
t
,
w
,
serverError
)
testhelper
.
RequireResponseBody
(
t
,
w
,
serverError
)
}
}
...
@@ -105,7 +105,7 @@ func TestIfErrorPageIsIgnoredIfCustomError(t *testing.T) {
...
@@ -105,7 +105,7 @@ func TestIfErrorPageIsIgnoredIfCustomError(t *testing.T) {
st
:=
&
Static
{
dir
}
st
:=
&
Static
{
dir
}
st
.
ErrorPagesUnless
(
false
,
ErrorFormatHTML
,
h
)
.
ServeHTTP
(
w
,
nil
)
st
.
ErrorPagesUnless
(
false
,
ErrorFormatHTML
,
h
)
.
ServeHTTP
(
w
,
nil
)
w
.
Flush
()
w
.
Flush
()
testhelper
.
RequireResponseCode
(
t
,
w
,
500
)
require
.
Equal
(
t
,
500
,
w
.
Code
)
testhelper
.
RequireResponseBody
(
t
,
w
,
serverError
)
testhelper
.
RequireResponseBody
(
t
,
w
,
serverError
)
}
}
...
@@ -140,7 +140,7 @@ func TestErrorPageInterceptedByContentType(t *testing.T) {
...
@@ -140,7 +140,7 @@ func TestErrorPageInterceptedByContentType(t *testing.T) {
st
:=
&
Static
{
dir
}
st
:=
&
Static
{
dir
}
st
.
ErrorPagesUnless
(
false
,
ErrorFormatHTML
,
h
)
.
ServeHTTP
(
w
,
nil
)
st
.
ErrorPagesUnless
(
false
,
ErrorFormatHTML
,
h
)
.
ServeHTTP
(
w
,
nil
)
w
.
Flush
()
w
.
Flush
()
testhelper
.
RequireResponseCode
(
t
,
w
,
500
)
require
.
Equal
(
t
,
500
,
w
.
Code
)
if
tc
.
intercepted
{
if
tc
.
intercepted
{
testhelper
.
RequireResponseBody
(
t
,
w
,
errorPage
)
testhelper
.
RequireResponseBody
(
t
,
w
,
errorPage
)
...
@@ -165,7 +165,7 @@ func TestIfErrorPageIsPresentedJSON(t *testing.T) {
...
@@ -165,7 +165,7 @@ func TestIfErrorPageIsPresentedJSON(t *testing.T) {
st
.
ErrorPagesUnless
(
false
,
ErrorFormatJSON
,
h
)
.
ServeHTTP
(
w
,
nil
)
st
.
ErrorPagesUnless
(
false
,
ErrorFormatJSON
,
h
)
.
ServeHTTP
(
w
,
nil
)
w
.
Flush
()
w
.
Flush
()
testhelper
.
RequireResponseCode
(
t
,
w
,
404
)
require
.
Equal
(
t
,
404
,
w
.
Code
)
testhelper
.
RequireResponseBody
(
t
,
w
,
errorPage
)
testhelper
.
RequireResponseBody
(
t
,
w
,
errorPage
)
testhelper
.
RequireResponseHeader
(
t
,
w
,
"Content-Type"
,
"application/json; charset=utf-8"
)
testhelper
.
RequireResponseHeader
(
t
,
w
,
"Content-Type"
,
"application/json; charset=utf-8"
)
}
}
...
@@ -185,7 +185,7 @@ func TestIfErrorPageIsPresentedText(t *testing.T) {
...
@@ -185,7 +185,7 @@ func TestIfErrorPageIsPresentedText(t *testing.T) {
st
.
ErrorPagesUnless
(
false
,
ErrorFormatText
,
h
)
.
ServeHTTP
(
w
,
nil
)
st
.
ErrorPagesUnless
(
false
,
ErrorFormatText
,
h
)
.
ServeHTTP
(
w
,
nil
)
w
.
Flush
()
w
.
Flush
()
testhelper
.
RequireResponseCode
(
t
,
w
,
404
)
require
.
Equal
(
t
,
404
,
w
.
Code
)
testhelper
.
RequireResponseBody
(
t
,
w
,
errorPage
)
testhelper
.
RequireResponseBody
(
t
,
w
,
errorPage
)
testhelper
.
RequireResponseHeader
(
t
,
w
,
"Content-Type"
,
"text/plain; charset=utf-8"
)
testhelper
.
RequireResponseHeader
(
t
,
w
,
"Content-Type"
,
"text/plain; charset=utf-8"
)
}
}
internal/staticpages/servefile_test.go
View file @
2460bbbb
...
@@ -11,6 +11,8 @@ import (
...
@@ -11,6 +11,8 @@ import (
"testing"
"testing"
"gitlab.com/gitlab-org/gitlab-workhorse/internal/testhelper"
"gitlab.com/gitlab-org/gitlab-workhorse/internal/testhelper"
"github.com/stretchr/testify/require"
)
)
func
TestServingNonExistingFile
(
t
*
testing
.
T
)
{
func
TestServingNonExistingFile
(
t
*
testing
.
T
)
{
...
@@ -20,7 +22,7 @@ func TestServingNonExistingFile(t *testing.T) {
...
@@ -20,7 +22,7 @@ func TestServingNonExistingFile(t *testing.T) {
w
:=
httptest
.
NewRecorder
()
w
:=
httptest
.
NewRecorder
()
st
:=
&
Static
{
dir
}
st
:=
&
Static
{
dir
}
st
.
ServeExisting
(
"/"
,
CacheDisabled
,
nil
)
.
ServeHTTP
(
w
,
httpRequest
)
st
.
ServeExisting
(
"/"
,
CacheDisabled
,
nil
)
.
ServeHTTP
(
w
,
httpRequest
)
testhelper
.
RequireResponseCode
(
t
,
w
,
404
)
require
.
Equal
(
t
,
404
,
w
.
Code
)
}
}
func
TestServingDirectory
(
t
*
testing
.
T
)
{
func
TestServingDirectory
(
t
*
testing
.
T
)
{
...
@@ -34,7 +36,7 @@ func TestServingDirectory(t *testing.T) {
...
@@ -34,7 +36,7 @@ func TestServingDirectory(t *testing.T) {
w
:=
httptest
.
NewRecorder
()
w
:=
httptest
.
NewRecorder
()
st
:=
&
Static
{
dir
}
st
:=
&
Static
{
dir
}
st
.
ServeExisting
(
"/"
,
CacheDisabled
,
nil
)
.
ServeHTTP
(
w
,
httpRequest
)
st
.
ServeExisting
(
"/"
,
CacheDisabled
,
nil
)
.
ServeHTTP
(
w
,
httpRequest
)
testhelper
.
RequireResponseCode
(
t
,
w
,
404
)
require
.
Equal
(
t
,
404
,
w
.
Code
)
}
}
func
TestServingMalformedUri
(
t
*
testing
.
T
)
{
func
TestServingMalformedUri
(
t
*
testing
.
T
)
{
...
@@ -44,7 +46,7 @@ func TestServingMalformedUri(t *testing.T) {
...
@@ -44,7 +46,7 @@ func TestServingMalformedUri(t *testing.T) {
w
:=
httptest
.
NewRecorder
()
w
:=
httptest
.
NewRecorder
()
st
:=
&
Static
{
dir
}
st
:=
&
Static
{
dir
}
st
.
ServeExisting
(
"/"
,
CacheDisabled
,
nil
)
.
ServeHTTP
(
w
,
httpRequest
)
st
.
ServeExisting
(
"/"
,
CacheDisabled
,
nil
)
.
ServeHTTP
(
w
,
httpRequest
)
testhelper
.
RequireResponseCode
(
t
,
w
,
404
)
require
.
Equal
(
t
,
404
,
w
.
Code
)
}
}
func
TestExecutingHandlerWhenNoFileFound
(
t
*
testing
.
T
)
{
func
TestExecutingHandlerWhenNoFileFound
(
t
*
testing
.
T
)
{
...
@@ -76,7 +78,7 @@ func TestServingTheActualFile(t *testing.T) {
...
@@ -76,7 +78,7 @@ func TestServingTheActualFile(t *testing.T) {
w
:=
httptest
.
NewRecorder
()
w
:=
httptest
.
NewRecorder
()
st
:=
&
Static
{
dir
}
st
:=
&
Static
{
dir
}
st
.
ServeExisting
(
"/"
,
CacheDisabled
,
nil
)
.
ServeHTTP
(
w
,
httpRequest
)
st
.
ServeExisting
(
"/"
,
CacheDisabled
,
nil
)
.
ServeHTTP
(
w
,
httpRequest
)
testhelper
.
RequireResponseCode
(
t
,
w
,
200
)
require
.
Equal
(
t
,
200
,
w
.
Code
)
if
w
.
Body
.
String
()
!=
fileContent
{
if
w
.
Body
.
String
()
!=
fileContent
{
t
.
Error
(
"We should serve the file: "
,
w
.
Body
.
String
())
t
.
Error
(
"We should serve the file: "
,
w
.
Body
.
String
())
}
}
...
@@ -108,15 +110,15 @@ func testServingThePregzippedFile(t *testing.T, enableGzip bool) {
...
@@ -108,15 +110,15 @@ func testServingThePregzippedFile(t *testing.T, enableGzip bool) {
w
:=
httptest
.
NewRecorder
()
w
:=
httptest
.
NewRecorder
()
st
:=
&
Static
{
dir
}
st
:=
&
Static
{
dir
}
st
.
ServeExisting
(
"/"
,
CacheDisabled
,
nil
)
.
ServeHTTP
(
w
,
httpRequest
)
st
.
ServeExisting
(
"/"
,
CacheDisabled
,
nil
)
.
ServeHTTP
(
w
,
httpRequest
)
testhelper
.
RequireResponseCode
(
t
,
w
,
200
)
require
.
Equal
(
t
,
200
,
w
.
Code
)
if
enableGzip
{
if
enableGzip
{
testhelper
.
RequireResponse
Writer
Header
(
t
,
w
,
"Content-Encoding"
,
"gzip"
)
testhelper
.
RequireResponseHeader
(
t
,
w
,
"Content-Encoding"
,
"gzip"
)
if
!
bytes
.
Equal
(
w
.
Body
.
Bytes
(),
fileGzipContent
.
Bytes
())
{
if
!
bytes
.
Equal
(
w
.
Body
.
Bytes
(),
fileGzipContent
.
Bytes
())
{
t
.
Error
(
"We should serve the pregzipped file"
)
t
.
Error
(
"We should serve the pregzipped file"
)
}
}
}
else
{
}
else
{
testhelper
.
RequireResponseCode
(
t
,
w
,
200
)
require
.
Equal
(
t
,
200
,
w
.
Code
)
testhelper
.
RequireResponse
Writer
Header
(
t
,
w
,
"Content-Encoding"
)
testhelper
.
RequireResponseHeader
(
t
,
w
,
"Content-Encoding"
)
if
w
.
Body
.
String
()
!=
fileContent
{
if
w
.
Body
.
String
()
!=
fileContent
{
t
.
Error
(
"We should serve the file: "
,
w
.
Body
.
String
())
t
.
Error
(
"We should serve the file: "
,
w
.
Body
.
String
())
}
}
...
...
internal/testhelper/testhelper.go
View file @
2460bbbb
package
testhelper
package
testhelper
import
(
import
(
"bufio"
"bytes"
"errors"
"errors"
"fmt"
"fmt"
"io"
"io"
...
@@ -13,7 +11,6 @@ import (
...
@@ -13,7 +11,6 @@ import (
"path"
"path"
"regexp"
"regexp"
"runtime"
"runtime"
"strings"
"testing"
"testing"
"time"
"time"
...
@@ -31,71 +28,9 @@ func ConfigureSecret() {
...
@@ -31,71 +28,9 @@ func ConfigureSecret() {
secret
.
SetPath
(
path
.
Join
(
RootDir
(),
"testdata/test-secret"
))
secret
.
SetPath
(
path
.
Join
(
RootDir
(),
"testdata/test-secret"
))
}
}
var
extractPatchSeriesMatcher
=
regexp
.
MustCompile
(
`^From (\w+)`
)
// RequirePatchSeries takes a `git format-patch` blob, extracts the From xxxxx
// lines and compares the SHAs to expected list.
func
RequirePatchSeries
(
t
*
testing
.
T
,
blob
[]
byte
,
expected
...
string
)
{
t
.
Helper
()
var
actual
[]
string
footer
:=
make
([]
string
,
3
)
scanner
:=
bufio
.
NewScanner
(
bytes
.
NewReader
(
blob
))
for
scanner
.
Scan
()
{
line
:=
scanner
.
Text
()
if
matches
:=
extractPatchSeriesMatcher
.
FindStringSubmatch
(
line
);
len
(
matches
)
==
2
{
actual
=
append
(
actual
,
matches
[
1
])
}
footer
=
[]
string
{
footer
[
1
],
footer
[
2
],
line
}
}
if
strings
.
Join
(
actual
,
"
\n
"
)
!=
strings
.
Join
(
expected
,
"
\n
"
)
{
t
.
Fatalf
(
"Patch series differs. Expected: %v. Got: %v"
,
expected
,
actual
)
}
// Check the last returned patch is complete
// Don't assert on the final line, it is a git version
if
footer
[
0
]
!=
"-- "
{
t
.
Fatalf
(
"Expected end of patch, found:
\n\t
%q"
,
strings
.
Join
(
footer
,
"
\n\t
"
))
}
}
func
RequireResponseCode
(
t
*
testing
.
T
,
response
*
httptest
.
ResponseRecorder
,
expectedCode
int
)
{
t
.
Helper
()
if
response
.
Code
!=
expectedCode
{
t
.
Fatalf
(
"for HTTP request expected to get %d, got %d instead"
,
expectedCode
,
response
.
Code
)
}
}
func
RequireResponseBody
(
t
*
testing
.
T
,
response
*
httptest
.
ResponseRecorder
,
expectedBody
string
)
{
func
RequireResponseBody
(
t
*
testing
.
T
,
response
*
httptest
.
ResponseRecorder
,
expectedBody
string
)
{
t
.
Helper
()
t
.
Helper
()
if
response
.
Body
.
String
()
!=
expectedBody
{
require
.
Equal
(
t
,
expectedBody
,
response
.
Body
.
String
(),
"response body"
)
t
.
Fatalf
(
"for HTTP request expected to receive %q, got %q instead as body"
,
expectedBody
,
response
.
Body
.
String
())
}
}
func
RequireResponseBodyRegexp
(
t
*
testing
.
T
,
response
*
httptest
.
ResponseRecorder
,
expectedBody
*
regexp
.
Regexp
)
{
t
.
Helper
()
if
!
expectedBody
.
MatchString
(
response
.
Body
.
String
())
{
t
.
Fatalf
(
"for HTTP request expected to receive body matching %q, got %q instead"
,
expectedBody
.
String
(),
response
.
Body
.
String
())
}
}
func
RequireResponseWriterHeader
(
t
*
testing
.
T
,
w
http
.
ResponseWriter
,
header
string
,
expected
...
string
)
{
t
.
Helper
()
actual
:=
w
.
Header
()[
http
.
CanonicalHeaderKey
(
header
)]
requireHeaderExists
(
t
,
header
,
actual
,
expected
)
}
func
RequireAbsentResponseWriterHeader
(
t
*
testing
.
T
,
w
http
.
ResponseWriter
,
header
string
)
{
t
.
Helper
()
actual
:=
w
.
Header
()[
http
.
CanonicalHeaderKey
(
header
)]
if
len
(
actual
)
!=
0
{
t
.
Fatalf
(
"for HTTP request expected not to receive the header %q, got %+v"
,
header
,
actual
)
}
}
}
func
RequireResponseHeader
(
t
*
testing
.
T
,
w
interface
{},
header
string
,
expected
...
string
)
{
func
RequireResponseHeader
(
t
*
testing
.
T
,
w
interface
{},
header
string
,
expected
...
string
)
{
...
@@ -103,31 +38,18 @@ func RequireResponseHeader(t *testing.T, w interface{}, header string, expected
...
@@ -103,31 +38,18 @@ func RequireResponseHeader(t *testing.T, w interface{}, header string, expected
var
actual
[]
string
var
actual
[]
string
header
=
http
.
CanonicalHeaderKey
(
header
)
header
=
http
.
CanonicalHeaderKey
(
header
)
type
headerer
interface
{
Header
()
http
.
Header
}
if
resp
,
ok
:=
w
.
(
*
http
.
Response
);
ok
{
switch
resp
:=
w
.
(
type
)
{
case
*
http
.
Response
:
actual
=
resp
.
Header
[
header
]
actual
=
resp
.
Header
[
header
]
}
else
if
resp
,
ok
:=
w
.
(
http
.
ResponseWriter
);
ok
{
case
headerer
:
actual
=
resp
.
Header
()[
header
]
actual
=
resp
.
Header
()[
header
]
}
else
if
resp
,
ok
:=
w
.
(
*
httptest
.
ResponseRecorder
);
ok
{
default
:
actual
=
resp
.
Header
()[
header
]
t
.
Fatal
(
"invalid type of w passed RequireResponseHeader"
)
}
else
{
t
.
Fatalf
(
"invalid type of w passed RequireResponseHeader"
)
}
}
requireHeaderExists
(
t
,
header
,
actual
,
expected
)
require
.
Equal
(
t
,
expected
,
actual
,
"values for HTTP header %s"
,
header
)
}
func
requireHeaderExists
(
t
*
testing
.
T
,
header
string
,
actual
,
expected
[]
string
)
{
t
.
Helper
()
if
len
(
expected
)
!=
len
(
actual
)
{
t
.
Fatalf
(
"for HTTP request expected to receive the header %q with %+v, got %+v"
,
header
,
expected
,
actual
)
}
for
i
,
value
:=
range
expected
{
if
value
!=
actual
[
i
]
{
t
.
Fatalf
(
"for HTTP request expected to receive the header %q with %+v, got %+v"
,
header
,
expected
,
actual
)
}
}
}
}
func
TestServerWithHandler
(
url
*
regexp
.
Regexp
,
handler
http
.
HandlerFunc
)
*
httptest
.
Server
{
func
TestServerWithHandler
(
url
*
regexp
.
Regexp
,
handler
http
.
HandlerFunc
)
*
httptest
.
Server
{
...
@@ -183,10 +105,9 @@ func RootDir() string {
...
@@ -183,10 +105,9 @@ func RootDir() string {
}
}
func
LoadFile
(
t
*
testing
.
T
,
filePath
string
)
string
{
func
LoadFile
(
t
*
testing
.
T
,
filePath
string
)
string
{
t
.
Helper
()
content
,
err
:=
ioutil
.
ReadFile
(
path
.
Join
(
RootDir
(),
filePath
))
content
,
err
:=
ioutil
.
ReadFile
(
path
.
Join
(
RootDir
(),
filePath
))
if
err
!=
nil
{
require
.
NoError
(
t
,
err
)
t
.
Fatal
(
err
)
}
return
string
(
content
)
return
string
(
content
)
}
}
...
...
internal/upload/uploads_test.go
View file @
2460bbbb
...
@@ -59,7 +59,7 @@ func TestUploadTempPathRequirement(t *testing.T) {
...
@@ -59,7 +59,7 @@ func TestUploadTempPathRequirement(t *testing.T) {
require
.
NoError
(
t
,
err
)
require
.
NoError
(
t
,
err
)
HandleFileUploads
(
response
,
request
,
nilHandler
,
apiResponse
,
&
testFormProcessor
{},
opts
)
HandleFileUploads
(
response
,
request
,
nilHandler
,
apiResponse
,
&
testFormProcessor
{},
opts
)
testhelper
.
RequireResponseCode
(
t
,
response
,
500
)
require
.
Equal
(
t
,
500
,
response
.
Code
)
}
}
func
TestUploadHandlerForwardingRawData
(
t
*
testing
.
T
)
{
func
TestUploadHandlerForwardingRawData
(
t
*
testing
.
T
)
{
...
@@ -92,7 +92,7 @@ func TestUploadHandlerForwardingRawData(t *testing.T) {
...
@@ -92,7 +92,7 @@ func TestUploadHandlerForwardingRawData(t *testing.T) {
HandleFileUploads
(
response
,
httpRequest
,
handler
,
apiResponse
,
nil
,
opts
)
HandleFileUploads
(
response
,
httpRequest
,
handler
,
apiResponse
,
nil
,
opts
)
testhelper
.
RequireResponseCode
(
t
,
response
,
202
)
require
.
Equal
(
t
,
202
,
response
.
Code
)
require
.
Equal
(
t
,
"RESPONSE"
,
response
.
Body
.
String
(),
"response body"
)
require
.
Equal
(
t
,
"RESPONSE"
,
response
.
Body
.
String
(),
"response body"
)
}
}
...
@@ -162,7 +162,7 @@ func TestUploadHandlerRewritingMultiPartData(t *testing.T) {
...
@@ -162,7 +162,7 @@ func TestUploadHandlerRewritingMultiPartData(t *testing.T) {
require
.
NoError
(
t
,
err
)
require
.
NoError
(
t
,
err
)
HandleFileUploads
(
response
,
httpRequest
,
handler
,
apiResponse
,
&
testFormProcessor
{},
opts
)
HandleFileUploads
(
response
,
httpRequest
,
handler
,
apiResponse
,
&
testFormProcessor
{},
opts
)
testhelper
.
RequireResponseCode
(
t
,
response
,
202
)
require
.
Equal
(
t
,
202
,
response
.
Code
)
cancel
()
// this will trigger an async cleanup
cancel
()
// this will trigger an async cleanup
waitUntilDeleted
(
t
,
filePath
)
waitUntilDeleted
(
t
,
filePath
)
...
@@ -231,7 +231,7 @@ func TestUploadHandlerDetectingInjectedMultiPartData(t *testing.T) {
...
@@ -231,7 +231,7 @@ func TestUploadHandlerDetectingInjectedMultiPartData(t *testing.T) {
require
.
NoError
(
t
,
err
)
require
.
NoError
(
t
,
err
)
HandleFileUploads
(
response
,
httpRequest
,
handler
,
apiResponse
,
&
testFormProcessor
{},
opts
)
HandleFileUploads
(
response
,
httpRequest
,
handler
,
apiResponse
,
&
testFormProcessor
{},
opts
)
testhelper
.
RequireResponseCode
(
t
,
response
,
test
.
respons
e
)
require
.
Equal
(
t
,
test
.
response
,
response
.
Cod
e
)
cancel
()
// this will trigger an async cleanup
cancel
()
// this will trigger an async cleanup
waitUntilDeleted
(
t
,
filePath
)
waitUntilDeleted
(
t
,
filePath
)
...
@@ -262,7 +262,7 @@ func TestUploadProcessingField(t *testing.T) {
...
@@ -262,7 +262,7 @@ func TestUploadProcessingField(t *testing.T) {
HandleFileUploads
(
response
,
httpRequest
,
nilHandler
,
apiResponse
,
&
testFormProcessor
{},
opts
)
HandleFileUploads
(
response
,
httpRequest
,
nilHandler
,
apiResponse
,
&
testFormProcessor
{},
opts
)
testhelper
.
RequireResponseCode
(
t
,
response
,
500
)
require
.
Equal
(
t
,
500
,
response
.
Code
)
}
}
func
TestUploadProcessingFile
(
t
*
testing
.
T
)
{
func
TestUploadProcessingFile
(
t
*
testing
.
T
)
{
...
@@ -317,7 +317,7 @@ func TestUploadProcessingFile(t *testing.T) {
...
@@ -317,7 +317,7 @@ func TestUploadProcessingFile(t *testing.T) {
HandleFileUploads
(
response
,
httpRequest
,
nilHandler
,
apiResponse
,
&
testFormProcessor
{},
opts
)
HandleFileUploads
(
response
,
httpRequest
,
nilHandler
,
apiResponse
,
&
testFormProcessor
{},
opts
)
testhelper
.
RequireResponseCode
(
t
,
response
,
200
)
require
.
Equal
(
t
,
200
,
response
.
Code
)
})
})
}
}
...
@@ -359,7 +359,7 @@ func TestInvalidFileNames(t *testing.T) {
...
@@ -359,7 +359,7 @@ func TestInvalidFileNames(t *testing.T) {
require
.
NoError
(
t
,
err
)
require
.
NoError
(
t
,
err
)
HandleFileUploads
(
response
,
httpRequest
,
nilHandler
,
apiResponse
,
&
SavedFileTracker
{
Request
:
httpRequest
},
opts
)
HandleFileUploads
(
response
,
httpRequest
,
nilHandler
,
apiResponse
,
&
SavedFileTracker
{
Request
:
httpRequest
},
opts
)
testhelper
.
RequireResponseCode
(
t
,
response
,
testCase
.
c
ode
)
require
.
Equal
(
t
,
testCase
.
code
,
response
.
C
ode
)
}
}
}
}
...
@@ -415,7 +415,7 @@ func TestUploadHandlerRemovingExif(t *testing.T) {
...
@@ -415,7 +415,7 @@ func TestUploadHandlerRemovingExif(t *testing.T) {
require
.
NoError
(
t
,
err
)
require
.
NoError
(
t
,
err
)
HandleFileUploads
(
response
,
httpRequest
,
handler
,
apiResponse
,
&
testFormProcessor
{},
opts
)
HandleFileUploads
(
response
,
httpRequest
,
handler
,
apiResponse
,
&
testFormProcessor
{},
opts
)
testhelper
.
RequireResponseCode
(
t
,
response
,
200
)
require
.
Equal
(
t
,
200
,
response
.
Code
)
}
}
func
TestUploadHandlerRemovingInvalidExif
(
t
*
testing
.
T
)
{
func
TestUploadHandlerRemovingInvalidExif
(
t
*
testing
.
T
)
{
...
@@ -457,7 +457,7 @@ func TestUploadHandlerRemovingInvalidExif(t *testing.T) {
...
@@ -457,7 +457,7 @@ func TestUploadHandlerRemovingInvalidExif(t *testing.T) {
require
.
NoError
(
t
,
err
)
require
.
NoError
(
t
,
err
)
HandleFileUploads
(
response
,
httpRequest
,
handler
,
apiResponse
,
&
testFormProcessor
{},
opts
)
HandleFileUploads
(
response
,
httpRequest
,
handler
,
apiResponse
,
&
testFormProcessor
{},
opts
)
testhelper
.
RequireResponseCode
(
t
,
response
,
422
)
require
.
Equal
(
t
,
422
,
response
.
Code
)
}
}
func
newProxy
(
url
string
)
*
proxy
.
Proxy
{
func
newProxy
(
url
string
)
*
proxy
.
Proxy
{
...
...
internal/upstream/development_test.go
View file @
2460bbbb
...
@@ -5,8 +5,6 @@ import (
...
@@ -5,8 +5,6 @@ import (
"net/http/httptest"
"net/http/httptest"
"testing"
"testing"
"gitlab.com/gitlab-org/gitlab-workhorse/internal/testhelper"
"github.com/stretchr/testify/require"
"github.com/stretchr/testify/require"
)
)
...
@@ -37,5 +35,5 @@ func TestDevelopmentModeDisabled(t *testing.T) {
...
@@ -37,5 +35,5 @@ func TestDevelopmentModeDisabled(t *testing.T) {
require
.
False
(
t
,
executed
,
"The handler should not get executed"
)
require
.
False
(
t
,
executed
,
"The handler should not get executed"
)
testhelper
.
RequireResponseCode
(
t
,
w
,
404
)
require
.
Equal
(
t
,
404
,
w
.
Code
)
}
}
internal/upstream/handlers_test.go
View file @
2460bbbb
...
@@ -9,8 +9,6 @@ import (
...
@@ -9,8 +9,6 @@ import (
"net/http/httptest"
"net/http/httptest"
"testing"
"testing"
"gitlab.com/gitlab-org/gitlab-workhorse/internal/testhelper"
"github.com/stretchr/testify/require"
"github.com/stretchr/testify/require"
)
)
...
@@ -33,7 +31,7 @@ func TestGzipEncoding(t *testing.T) {
...
@@ -33,7 +31,7 @@ func TestGzipEncoding(t *testing.T) {
require
.
Empty
(
t
,
r
.
Header
.
Get
(
"Content-Encoding"
),
"Content-Encoding should be deleted"
)
require
.
Empty
(
t
,
r
.
Header
.
Get
(
"Content-Encoding"
),
"Content-Encoding should be deleted"
)
}))
.
ServeHTTP
(
resp
,
req
)
}))
.
ServeHTTP
(
resp
,
req
)
testhelper
.
RequireResponseCode
(
t
,
resp
,
200
)
require
.
Equal
(
t
,
200
,
resp
.
Code
)
}
}
func
TestNoEncoding
(
t
*
testing
.
T
)
{
func
TestNoEncoding
(
t
*
testing
.
T
)
{
...
@@ -51,7 +49,7 @@ func TestNoEncoding(t *testing.T) {
...
@@ -51,7 +49,7 @@ func TestNoEncoding(t *testing.T) {
require
.
Empty
(
t
,
r
.
Header
.
Get
(
"Content-Encoding"
),
"Content-Encoding should be deleted"
)
require
.
Empty
(
t
,
r
.
Header
.
Get
(
"Content-Encoding"
),
"Content-Encoding should be deleted"
)
}))
.
ServeHTTP
(
resp
,
req
)
}))
.
ServeHTTP
(
resp
,
req
)
testhelper
.
RequireResponseCode
(
t
,
resp
,
200
)
require
.
Equal
(
t
,
200
,
resp
.
Code
)
}
}
func
TestInvalidEncoding
(
t
*
testing
.
T
)
{
func
TestInvalidEncoding
(
t
*
testing
.
T
)
{
...
@@ -65,5 +63,5 @@ func TestInvalidEncoding(t *testing.T) {
...
@@ -65,5 +63,5 @@ func TestInvalidEncoding(t *testing.T) {
t
.
Fatal
(
"it shouldn't be executed"
)
t
.
Fatal
(
"it shouldn't be executed"
)
}))
.
ServeHTTP
(
resp
,
req
)
}))
.
ServeHTTP
(
resp
,
req
)
testhelper
.
RequireResponseCode
(
t
,
resp
,
500
)
require
.
Equal
(
t
,
500
,
resp
.
Code
)
}
}
proxy_test.go
View file @
2460bbbb
...
@@ -17,6 +17,8 @@ import (
...
@@ -17,6 +17,8 @@ import (
"gitlab.com/gitlab-org/gitlab-workhorse/internal/proxy"
"gitlab.com/gitlab-org/gitlab-workhorse/internal/proxy"
"gitlab.com/gitlab-org/gitlab-workhorse/internal/testhelper"
"gitlab.com/gitlab-org/gitlab-workhorse/internal/testhelper"
"gitlab.com/gitlab-org/gitlab-workhorse/internal/upstream/roundtripper"
"gitlab.com/gitlab-org/gitlab-workhorse/internal/upstream/roundtripper"
"github.com/stretchr/testify/require"
)
)
const
testVersion
=
"123"
const
testVersion
=
"123"
...
@@ -66,7 +68,7 @@ func TestProxyRequest(t *testing.T) {
...
@@ -66,7 +68,7 @@ func TestProxyRequest(t *testing.T) {
w
:=
httptest
.
NewRecorder
()
w
:=
httptest
.
NewRecorder
()
newProxy
(
ts
.
URL
,
nil
)
.
ServeHTTP
(
w
,
httpRequest
)
newProxy
(
ts
.
URL
,
nil
)
.
ServeHTTP
(
w
,
httpRequest
)
testhelper
.
RequireResponseCode
(
t
,
w
,
202
)
require
.
Equal
(
t
,
202
,
w
.
Code
)
testhelper
.
RequireResponseBody
(
t
,
w
,
"RESPONSE"
)
testhelper
.
RequireResponseBody
(
t
,
w
,
"RESPONSE"
)
if
w
.
Header
()
.
Get
(
"Custom-Response-Header"
)
!=
"test"
{
if
w
.
Header
()
.
Get
(
"Custom-Response-Header"
)
!=
"test"
{
...
@@ -83,8 +85,8 @@ func TestProxyError(t *testing.T) {
...
@@ -83,8 +85,8 @@ func TestProxyError(t *testing.T) {
w
:=
httptest
.
NewRecorder
()
w
:=
httptest
.
NewRecorder
()
newProxy
(
"http://localhost:655575/"
,
nil
)
.
ServeHTTP
(
w
,
httpRequest
)
newProxy
(
"http://localhost:655575/"
,
nil
)
.
ServeHTTP
(
w
,
httpRequest
)
testhelper
.
RequireResponseCode
(
t
,
w
,
502
)
require
.
Equal
(
t
,
502
,
w
.
Code
)
testhelper
.
RequireResponseBodyRegexp
(
t
,
w
,
regexp
.
MustCompile
(
"dial tcp:.*invalid port.*"
)
)
require
.
Regexp
(
t
,
regexp
.
MustCompile
(
"dial tcp:.*invalid port.*"
),
w
.
Body
.
String
(),
"response body"
)
}
}
func
TestProxyReadTimeout
(
t
*
testing
.
T
)
{
func
TestProxyReadTimeout
(
t
*
testing
.
T
)
{
...
@@ -110,7 +112,7 @@ func TestProxyReadTimeout(t *testing.T) {
...
@@ -110,7 +112,7 @@ func TestProxyReadTimeout(t *testing.T) {
p
:=
newProxy
(
ts
.
URL
,
rt
)
p
:=
newProxy
(
ts
.
URL
,
rt
)
w
:=
httptest
.
NewRecorder
()
w
:=
httptest
.
NewRecorder
()
p
.
ServeHTTP
(
w
,
httpRequest
)
p
.
ServeHTTP
(
w
,
httpRequest
)
testhelper
.
RequireResponseCode
(
t
,
w
,
502
)
require
.
Equal
(
t
,
502
,
w
.
Code
)
testhelper
.
RequireResponseBody
(
t
,
w
,
"GitLab is not responding"
)
testhelper
.
RequireResponseBody
(
t
,
w
,
"GitLab is not responding"
)
}
}
...
@@ -128,6 +130,6 @@ func TestProxyHandlerTimeout(t *testing.T) {
...
@@ -128,6 +130,6 @@ func TestProxyHandlerTimeout(t *testing.T) {
w
:=
httptest
.
NewRecorder
()
w
:=
httptest
.
NewRecorder
()
newProxy
(
ts
.
URL
,
nil
)
.
ServeHTTP
(
w
,
httpRequest
)
newProxy
(
ts
.
URL
,
nil
)
.
ServeHTTP
(
w
,
httpRequest
)
testhelper
.
RequireResponseCode
(
t
,
w
,
503
)
require
.
Equal
(
t
,
503
,
w
.
Code
)
testhelper
.
RequireResponseBody
(
t
,
w
,
"Request took too long"
)
testhelper
.
RequireResponseBody
(
t
,
w
,
"Request took too long"
)
}
}
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment