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
b2da81ee
Commit
b2da81ee
authored
Sep 20, 2016
by
Nick Thomas
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Refactor and flesh out some Gitlab-Workhorse-Send-Data tests
parent
8abee43f
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
105 additions
and
106 deletions
+105
-106
internal/testhelper/testhelper.go
internal/testhelper/testhelper.go
+32
-0
main_test.go
main_test.go
+73
-106
No files found.
internal/testhelper/testhelper.go
View file @
b2da81ee
package
testhelper
package
testhelper
import
(
import
(
"bufio"
"bytes"
"errors"
"errors"
"fmt"
"fmt"
"io/ioutil"
"io/ioutil"
...
@@ -12,6 +14,7 @@ import (
...
@@ -12,6 +14,7 @@ import (
"path"
"path"
"regexp"
"regexp"
"runtime"
"runtime"
"strings"
"testing"
"testing"
)
)
...
@@ -19,6 +22,35 @@ func SecretPath() string {
...
@@ -19,6 +22,35 @@ func SecretPath() string {
return
path
.
Join
(
RootDir
(),
"testdata/test-secret"
)
return
path
.
Join
(
RootDir
(),
"testdata/test-secret"
)
}
}
var
extractPatchSeriesMatcher
=
regexp
.
MustCompile
(
`^From (\w+)`
)
// AssertPatchSeries takes a `git format-patch` blob, extracts the From xxxxx
// lines and compares the SHAs to expected list.
func
AssertPatchSeries
(
t
*
testing
.
T
,
blob
[]
byte
,
expected
...
string
)
{
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
AssertResponseCode
(
t
*
testing
.
T
,
response
*
httptest
.
ResponseRecorder
,
expectedCode
int
)
{
func
AssertResponseCode
(
t
*
testing
.
T
,
response
*
httptest
.
ResponseRecorder
,
expectedCode
int
)
{
if
response
.
Code
!=
expectedCode
{
if
response
.
Code
!=
expectedCode
{
t
.
Fatalf
(
"for HTTP request expected to get %d, got %d instead"
,
expectedCode
,
response
.
Code
)
t
.
Fatalf
(
"for HTTP request expected to get %d, got %d instead"
,
expectedCode
,
response
.
Code
)
...
...
main_test.go
View file @
b2da81ee
...
@@ -577,35 +577,68 @@ func TestArtifactsUpload(t *testing.T) {
...
@@ -577,35 +577,68 @@ func TestArtifactsUpload(t *testing.T) {
}
}
}
}
func
TestArtifactsGetSingleFile
(
t
*
testing
.
T
)
{
var
sendDataHeader
=
"Gitlab-Workhorse-Send-Data"
// We manually created this zip file in the gitlab-workhorse Git repository
archivePath
:=
`testdata/artifacts-archive.zip`
func
sendDataResponder
(
command
string
,
literalJSON
string
)
*
httptest
.
Server
{
fileName
:=
"myfile"
handler
:=
func
(
w
http
.
ResponseWriter
,
r
*
http
.
Request
)
{
fileContents
:=
"MY FILE"
data
:=
base64
.
URLEncoding
.
EncodeToString
([]
byte
(
literalJSON
))
resourcePath
:=
`/namespace/project/builds/123/artifacts/file/`
+
fileName
w
.
Header
()
.
Set
(
sendDataHeader
,
fmt
.
Sprintf
(
"%s:%s"
,
command
,
data
))
ts
:=
testhelper
.
TestServerWithHandler
(
regexp
.
MustCompile
(
`\A`
+
resourcePath
+
`\z`
),
func
(
w
http
.
ResponseWriter
,
r
*
http
.
Request
)
{
encodedFilename
:=
base64
.
StdEncoding
.
EncodeToString
([]
byte
(
fileName
))
// This should never be returned
jsonParams
:=
fmt
.
Sprintf
(
`{"Archive":"%s","Entry":"%s"}`
,
archivePath
,
encodedFilename
)
if
_
,
err
:=
fmt
.
Fprintf
(
w
,
"gibberish"
);
err
!=
nil
{
data
:=
base64
.
URLEncoding
.
EncodeToString
([]
byte
(
jsonParams
))
panic
(
err
)
w
.
Header
()
.
Set
(
"Gitlab-Workhorse-Send-Data"
,
"artifacts-entry:"
+
data
)
}
return
return
})
}
return
testhelper
.
TestServerWithHandler
(
regexp
.
MustCompile
(
`.`
),
handler
)
}
func
doSendDataRequest
(
path
string
,
command
,
literalJSON
string
)
(
*
http
.
Response
,
[]
byte
,
error
)
{
ts
:=
sendDataResponder
(
command
,
literalJSON
)
defer
ts
.
Close
()
defer
ts
.
Close
()
ws
:=
startWorkhorseServer
(
ts
.
URL
)
ws
:=
startWorkhorseServer
(
ts
.
URL
)
defer
ws
.
Close
()
defer
ws
.
Close
()
resp
,
err
:=
http
.
Get
(
ws
.
URL
+
resourceP
ath
)
resp
,
err
:=
http
.
Get
(
ws
.
URL
+
p
ath
)
if
err
!=
nil
{
if
err
!=
nil
{
t
.
Error
(
err
)
return
nil
,
nil
,
err
}
}
defer
resp
.
Body
.
Close
()
defer
resp
.
Body
.
Close
()
if
resp
.
StatusCode
!=
200
{
t
.
Errorf
(
"GET %q: expected 200, got %d"
,
resourcePath
,
resp
.
StatusCode
)
bodyData
,
err
:=
ioutil
.
ReadAll
(
resp
.
Body
)
if
err
!=
nil
{
return
resp
,
nil
,
err
}
}
body
,
err
:=
ioutil
.
ReadAll
(
resp
.
Body
)
headerValue
:=
resp
.
Header
.
Get
(
sendDataHeader
)
if
headerValue
!=
""
{
return
resp
,
bodyData
,
fmt
.
Errorf
(
"%s header should not be present, but has value %q"
,
sendDataHeader
,
headerValue
)
}
return
resp
,
bodyData
,
nil
}
func
TestArtifactsGetSingleFile
(
t
*
testing
.
T
)
{
// We manually created this zip file in the gitlab-workhorse Git repository
archivePath
:=
`testdata/artifacts-archive.zip`
fileName
:=
"myfile"
fileContents
:=
"MY FILE"
resourcePath
:=
`/namespace/project/builds/123/artifacts/file/`
+
fileName
encodedFilename
:=
base64
.
StdEncoding
.
EncodeToString
([]
byte
(
fileName
))
jsonParams
:=
fmt
.
Sprintf
(
`{"Archive":"%s","Entry":"%s"}`
,
archivePath
,
encodedFilename
)
resp
,
body
,
err
:=
doSendDataRequest
(
resourcePath
,
"artifacts-entry"
,
jsonParams
)
if
err
!=
nil
{
if
err
!=
nil
{
t
.
Fatal
(
err
)
t
.
Error
(
err
)
}
}
if
resp
.
StatusCode
!=
http
.
StatusOK
{
t
.
Errorf
(
"GET %q: expected HTTP 200, got %d"
,
resp
.
Request
.
URL
,
resp
.
StatusCode
)
}
if
string
(
body
)
!=
fileContents
{
if
string
(
body
)
!=
fileContents
{
t
.
Fatalf
(
"Expected file contents %q, got %q"
,
fileContents
,
body
)
t
.
Fatalf
(
"Expected file contents %q, got %q"
,
fileContents
,
body
)
}
}
...
@@ -614,41 +647,25 @@ func TestArtifactsGetSingleFile(t *testing.T) {
...
@@ -614,41 +647,25 @@ func TestArtifactsGetSingleFile(t *testing.T) {
func
TestGetGitBlob
(
t
*
testing
.
T
)
{
func
TestGetGitBlob
(
t
*
testing
.
T
)
{
blobId
:=
"50b27c6518be44c42c4d87966ae2481ce895624c"
// the LICENSE file in the test repository
blobId
:=
"50b27c6518be44c42c4d87966ae2481ce895624c"
// the LICENSE file in the test repository
blobLength
:=
1075
blobLength
:=
1075
headerKey
:=
http
.
CanonicalHeaderKey
(
"Gitlab-Workhorse-Send-Data"
)
jsonParams
:=
fmt
.
Sprintf
(
`{"RepoPath":"%s","BlobId":"%s"}`
,
path
.
Join
(
testRepoRoot
,
testRepo
),
blobId
)
ts
:=
testhelper
.
TestServerWithHandler
(
regexp
.
MustCompile
(
`.`
),
func
(
w
http
.
ResponseWriter
,
r
*
http
.
Request
)
{
responseJSON
:=
fmt
.
Sprintf
(
`{"RepoPath":"%s","BlobId":"%s"}`
,
path
.
Join
(
testRepoRoot
,
testRepo
),
blobId
)
resp
,
body
,
err
:=
doSendDataRequest
(
"/something"
,
"git-blob"
,
jsonParams
)
encodedJSON
:=
base64
.
URLEncoding
.
EncodeToString
([]
byte
(
responseJSON
))
w
.
Header
()
.
Set
(
headerKey
,
"git-blob:"
+
encodedJSON
)
if
_
,
err
:=
fmt
.
Fprintf
(
w
,
"GNU General Public License"
);
err
!=
nil
{
t
.
Fatal
(
err
)
}
return
})
defer
ts
.
Close
()
ws
:=
startWorkhorseServer
(
ts
.
URL
)
defer
ws
.
Close
()
resourcePath
:=
"/something"
resp
,
err
:=
http
.
Get
(
ws
.
URL
+
resourcePath
)
if
err
!=
nil
{
if
err
!=
nil
{
t
.
Error
(
err
)
t
.
Error
(
err
)
}
}
defer
resp
.
Body
.
Close
()
if
resp
.
StatusCode
!=
200
{
if
resp
.
StatusCode
!=
http
.
StatusOK
{
t
.
Errorf
(
"GET %q: expected 200, got %d"
,
resourcePath
,
resp
.
StatusCode
)
t
.
Errorf
(
"GET %q: expected HTTP 200, got %d"
,
resp
.
Request
.
URL
,
resp
.
StatusCode
)
}
if
len
(
resp
.
Header
[
headerKey
])
!=
0
{
t
.
Fatalf
(
"Unexpected response header: %s: %q"
,
headerKey
,
resp
.
Header
.
Get
(
headerKey
))
}
body
,
err
:=
ioutil
.
ReadAll
(
resp
.
Body
)
if
err
!=
nil
{
t
.
Fatal
(
err
)
}
}
if
len
(
body
)
!=
blobLength
{
if
len
(
body
)
!=
blobLength
{
t
.
Fatalf
(
"Expected body of %d bytes, got %d"
,
blobLength
,
len
(
body
))
t
.
Fatalf
(
"Expected body of %d bytes, got %d"
,
blobLength
,
len
(
body
))
}
}
if
cl
:=
resp
.
Header
.
Get
(
"Content-Length"
);
cl
!=
fmt
.
Sprintf
(
"%d"
,
blobLength
)
{
if
cl
:=
resp
.
Header
.
Get
(
"Content-Length"
);
cl
!=
fmt
.
Sprintf
(
"%d"
,
blobLength
)
{
t
.
Fatalf
(
"Expected Content-Length %v, got %q"
,
blobLength
,
cl
)
t
.
Fatalf
(
"Expected Content-Length %v, got %q"
,
blobLength
,
cl
)
}
}
if
!
strings
.
HasPrefix
(
string
(
body
),
"The MIT License (MIT)"
)
{
if
!
strings
.
HasPrefix
(
string
(
body
),
"The MIT License (MIT)"
)
{
t
.
Fatalf
(
"Expected MIT license, got %q"
,
body
)
t
.
Fatalf
(
"Expected MIT license, got %q"
,
body
)
}
}
...
@@ -657,35 +674,15 @@ func TestGetGitBlob(t *testing.T) {
...
@@ -657,35 +674,15 @@ func TestGetGitBlob(t *testing.T) {
func
TestGetGitDiff
(
t
*
testing
.
T
)
{
func
TestGetGitDiff
(
t
*
testing
.
T
)
{
fromSha
:=
"be93687618e4b132087f430a4d8fc3a609c9b77c"
fromSha
:=
"be93687618e4b132087f430a4d8fc3a609c9b77c"
toSha
:=
"54fcc214b94e78d7a41a9a8fe6d87a5e59500e51"
toSha
:=
"54fcc214b94e78d7a41a9a8fe6d87a5e59500e51"
headerKey
:=
http
.
CanonicalHeaderKey
(
"Gitlab-Workhorse-Send-Data"
)
jsonParams
:=
fmt
.
Sprintf
(
`{"RepoPath":"%s","ShaFrom":"%s","ShaTo":"%s"}`
,
path
.
Join
(
testRepoRoot
,
testRepo
),
fromSha
,
toSha
)
ts
:=
testhelper
.
TestServerWithHandler
(
regexp
.
MustCompile
(
`.`
),
func
(
w
http
.
ResponseWriter
,
r
*
http
.
Request
)
{
resp
,
body
,
err
:=
doSendDataRequest
(
"/something"
,
"git-diff"
,
jsonParams
)
responseJSON
:=
fmt
.
Sprintf
(
`{"RepoPath":"%s","ShaFrom":"%s","ShaTo":"%s"}`
,
path
.
Join
(
testRepoRoot
,
testRepo
),
fromSha
,
toSha
)
encodedJSON
:=
base64
.
URLEncoding
.
EncodeToString
([]
byte
(
responseJSON
))
w
.
Header
()
.
Set
(
headerKey
,
"git-diff:"
+
encodedJSON
)
return
})
defer
ts
.
Close
()
ws
:=
startWorkhorseServer
(
ts
.
URL
)
defer
ws
.
Close
()
resourcePath
:=
"/something"
resp
,
err
:=
http
.
Get
(
ws
.
URL
+
resourcePath
)
if
err
!=
nil
{
if
err
!=
nil
{
t
.
Error
(
err
)
t
.
Error
(
err
)
}
}
defer
resp
.
Body
.
Close
()
if
resp
.
StatusCode
!=
200
{
t
.
Errorf
(
"GET %q: expected 200, got %d"
,
resourcePath
,
resp
.
StatusCode
)
}
if
len
(
resp
.
Header
[
headerKey
])
!=
0
{
t
.
Fatalf
(
"Unexpected response header: %s: %q"
,
headerKey
,
resp
.
Header
.
Get
(
headerKey
))
}
body
,
err
:=
ioutil
.
ReadAll
(
resp
.
Body
)
if
resp
.
StatusCode
!=
http
.
StatusOK
{
if
err
!=
nil
{
t
.
Errorf
(
"GET %q: expected HTTP 200, got %d"
,
resp
.
Request
.
URL
,
resp
.
StatusCode
)
t
.
Fatal
(
err
)
}
}
if
!
strings
.
HasPrefix
(
string
(
body
),
"diff --git a/README b/README"
)
{
if
!
strings
.
HasPrefix
(
string
(
body
),
"diff --git a/README b/README"
)
{
...
@@ -699,52 +696,22 @@ func TestGetGitDiff(t *testing.T) {
...
@@ -699,52 +696,22 @@ func TestGetGitDiff(t *testing.T) {
}
}
func
TestGetGitPatch
(
t
*
testing
.
T
)
{
func
TestGetGitPatch
(
t
*
testing
.
T
)
{
fromSha
:=
"be93687618e4b132087f430a4d8fc3a609c9b77c"
// HEAD of master branch against HEAD of fix branch
toSha
:=
"54fcc214b94e78d7a41a9a8fe6d87a5e59500e51"
fromSha
:=
"6907208d755b60ebeacb2e9dfea74c92c3449a1f"
headerKey
:=
http
.
CanonicalHeaderKey
(
"Gitlab-Workhorse-Send-Data"
)
toSha
:=
"48f0be4bd10c1decee6fae52f9ae6d10f77b60f4"
jsonParams
:=
fmt
.
Sprintf
(
`{"RepoPath":"%s","ShaFrom":"%s","ShaTo":"%s"}`
,
path
.
Join
(
testRepoRoot
,
testRepo
),
fromSha
,
toSha
)
ts
:=
testhelper
.
TestServerWithHandler
(
regexp
.
MustCompile
(
`.`
),
func
(
w
http
.
ResponseWriter
,
r
*
http
.
Request
)
{
resp
,
body
,
err
:=
doSendDataRequest
(
"/something"
,
"git-format-patch"
,
jsonParams
)
responseJSON
:=
fmt
.
Sprintf
(
`{"RepoPath":"%s","ShaFrom":"%s","ShaTo":"%s"}`
,
path
.
Join
(
testRepoRoot
,
testRepo
),
fromSha
,
toSha
)
encodedJSON
:=
base64
.
URLEncoding
.
EncodeToString
([]
byte
(
responseJSON
))
w
.
Header
()
.
Set
(
headerKey
,
"git-format-patch:"
+
encodedJSON
)
return
})
defer
ts
.
Close
()
ws
:=
startWorkhorseServer
(
ts
.
URL
)
defer
ws
.
Close
()
resourcePath
:=
"/something"
resp
,
err
:=
http
.
Get
(
ws
.
URL
+
resourcePath
)
if
err
!=
nil
{
if
err
!=
nil
{
t
.
Error
(
err
)
t
.
Error
(
err
)
}
}
defer
resp
.
Body
.
Close
()
if
resp
.
StatusCode
!=
200
{
t
.
Errorf
(
"GET %q: expected 200, got %d"
,
resourcePath
,
resp
.
StatusCode
)
}
if
len
(
resp
.
Header
[
headerKey
])
!=
0
{
t
.
Fatalf
(
"Unexpected response header: %s: %q"
,
headerKey
,
resp
.
Header
.
Get
(
headerKey
))
}
body
,
err
:=
ioutil
.
ReadAll
(
resp
.
Body
)
if
resp
.
StatusCode
!=
http
.
StatusOK
{
if
err
!=
nil
{
t
.
Errorf
(
"GET %q: expected HTTP 200, got %d"
,
resp
.
Request
.
URL
,
resp
.
StatusCode
)
t
.
Fatal
(
err
)
}
}
if
!
strings
.
HasPrefix
(
string
(
body
),
"From 54fcc214b94e78d7a41a9a8fe6d87a5e59500e51 Mon Sep 17 00:00:00 2001"
)
{
// Only the two commits on the fix branch should be included
t
.
Fatalf
(
"Expected: From 54fcc214b94e78d7a41a9a8fe6d87a5e59500e51 Mon Sep 17 00:00:00 2001, got: %v"
,
body
)
testhelper
.
AssertPatchSeries
(
t
,
body
,
"12d65c8dd2b2676fa3ac47d955accc085a37a9c1"
,
toSha
)
}
// The contents of the last line of the patch depend on the version of
// Git used during the test run. Ignore that data and look at the line
// that should terminate the diff.
lastPatchIndex
:=
442
endOfPatch
:=
string
(
body
[
lastPatchIndex
-
5
:
lastPatchIndex
])
if
endOfPatch
!=
"
\n
--
\n
"
{
t
.
Fatalf
(
"Expected end of patch at %d, found %q"
,
lastPatchIndex
,
endOfPatch
)
}
}
}
func
TestApiContentTypeBlock
(
t
*
testing
.
T
)
{
func
TestApiContentTypeBlock
(
t
*
testing
.
T
)
{
...
...
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