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
5a9f23e7
Commit
5a9f23e7
authored
Jul 09, 2018
by
Kamil Trzciński
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Fix and add specs for testing metadata entry
parent
bc00803a
Changes
8
Hide whitespace changes
Inline
Side-by-side
Showing
8 changed files
with
172 additions
and
97 deletions
+172
-97
app/uploaders/gitlab_uploader.rb
app/uploaders/gitlab_uploader.rb
+4
-0
spec/controllers/projects/jobs_controller_spec.rb
spec/controllers/projects/jobs_controller_spec.rb
+5
-2
spec/lib/gitlab/http_io_spec.rb
spec/lib/gitlab/http_io_spec.rb
+22
-19
spec/models/ci/build_spec.rb
spec/models/ci/build_spec.rb
+54
-0
spec/requests/api/jobs_spec.rb
spec/requests/api/jobs_spec.rb
+5
-3
spec/support/http_io/http_io_helpers.rb
spec/support/http_io/http_io_helpers.rb
+20
-36
spec/uploaders/gitlab_uploader_spec.rb
spec/uploaders/gitlab_uploader_spec.rb
+62
-0
spec/uploaders/job_artifact_uploader_spec.rb
spec/uploaders/job_artifact_uploader_spec.rb
+0
-37
No files found.
app/uploaders/gitlab_uploader.rb
View file @
5a9f23e7
...
@@ -71,6 +71,10 @@ class GitlabUploader < CarrierWave::Uploader::Base
...
@@ -71,6 +71,10 @@ class GitlabUploader < CarrierWave::Uploader::Base
File
.
join
(
'/'
,
self
.
class
.
base_dir
,
dynamic_segment
,
filename
)
File
.
join
(
'/'
,
self
.
class
.
base_dir
,
dynamic_segment
,
filename
)
end
end
def
cached_size
size
end
def
open
def
open
stream
=
if
file_storage?
stream
=
if
file_storage?
File
.
open
(
path
,
"rb"
)
if
path
File
.
open
(
path
,
"rb"
)
if
path
...
...
spec/controllers/projects/jobs_controller_spec.rb
View file @
5a9f23e7
...
@@ -225,8 +225,11 @@ describe Projects::JobsController, :clean_gitlab_redis_shared_state do
...
@@ -225,8 +225,11 @@ describe Projects::JobsController, :clean_gitlab_redis_shared_state do
end
end
context
'when there are no network issues'
do
context
'when there are no network issues'
do
let
(
:url
)
{
'http://object-storage/trace'
}
let
(
:file
)
{
expand_fixture_path
(
'trace/sample_trace'
)
}
before
do
before
do
stub_remote_
trace_206
stub_remote_
url_206
(
url
,
file
)
get_trace
get_trace
end
end
...
@@ -241,7 +244,7 @@ describe Projects::JobsController, :clean_gitlab_redis_shared_state do
...
@@ -241,7 +244,7 @@ describe Projects::JobsController, :clean_gitlab_redis_shared_state do
context
'when there is a network issue'
do
context
'when there is a network issue'
do
before
do
before
do
stub_remote_
trace_500
stub_remote_
url_500
(
url
)
end
end
it
'returns a trace'
do
it
'returns a trace'
do
...
...
spec/lib/gitlab/http_io_spec.rb
View file @
5a9f23e7
...
@@ -4,8 +4,11 @@ describe Gitlab::HttpIO do
...
@@ -4,8 +4,11 @@ describe Gitlab::HttpIO do
include
HttpIOHelpers
include
HttpIOHelpers
let
(
:http_io
)
{
described_class
.
new
(
url
,
size
)
}
let
(
:http_io
)
{
described_class
.
new
(
url
,
size
)
}
let
(
:url
)
{
remote_trace_url
}
let
(
:size
)
{
remote_trace_size
}
let
(
:url
)
{
'http://object-storage/trace'
}
let
(
:file_path
)
{
expand_fixture_path
(
'trace/sample_trace'
)
}
let
(
:file_body
)
{
File
.
read
(
file_path
).
force_encoding
(
Encoding
::
BINARY
)
}
let
(
:size
)
{
File
.
size
(
file_path
)
}
describe
'#close'
do
describe
'#close'
do
subject
{
http_io
.
close
}
subject
{
http_io
.
close
}
...
@@ -86,10 +89,10 @@ describe Gitlab::HttpIO do
...
@@ -86,10 +89,10 @@ describe Gitlab::HttpIO do
describe
'#each_line'
do
describe
'#each_line'
do
subject
{
http_io
.
each_line
}
subject
{
http_io
.
each_line
}
let
(
:string_io
)
{
StringIO
.
new
(
remote_trac
e_body
)
}
let
(
:string_io
)
{
StringIO
.
new
(
fil
e_body
)
}
before
do
before
do
stub_remote_
trace_206
stub_remote_
url_206
(
url
,
file_path
)
end
end
it
'yields lines'
do
it
'yields lines'
do
...
@@ -99,7 +102,7 @@ describe Gitlab::HttpIO do
...
@@ -99,7 +102,7 @@ describe Gitlab::HttpIO do
context
'when buckets on GCS'
do
context
'when buckets on GCS'
do
context
'when BUFFER_SIZE is larger than file size'
do
context
'when BUFFER_SIZE is larger than file size'
do
before
do
before
do
stub_remote_
trace_200
stub_remote_
url_200
(
url
,
file_path
)
set_larger_buffer_size_than
(
size
)
set_larger_buffer_size_than
(
size
)
end
end
...
@@ -117,7 +120,7 @@ describe Gitlab::HttpIO do
...
@@ -117,7 +120,7 @@ describe Gitlab::HttpIO do
context
'when there are no network issue'
do
context
'when there are no network issue'
do
before
do
before
do
stub_remote_
trace_206
stub_remote_
url_206
(
url
,
file_path
)
end
end
context
'when read whole size'
do
context
'when read whole size'
do
...
@@ -129,7 +132,7 @@ describe Gitlab::HttpIO do
...
@@ -129,7 +132,7 @@ describe Gitlab::HttpIO do
end
end
it
'reads a trace'
do
it
'reads a trace'
do
is_expected
.
to
eq
(
remote_trac
e_body
)
is_expected
.
to
eq
(
fil
e_body
)
end
end
end
end
...
@@ -139,7 +142,7 @@ describe Gitlab::HttpIO do
...
@@ -139,7 +142,7 @@ describe Gitlab::HttpIO do
end
end
it
'reads a trace'
do
it
'reads a trace'
do
is_expected
.
to
eq
(
remote_trac
e_body
)
is_expected
.
to
eq
(
fil
e_body
)
end
end
end
end
end
end
...
@@ -153,7 +156,7 @@ describe Gitlab::HttpIO do
...
@@ -153,7 +156,7 @@ describe Gitlab::HttpIO do
end
end
it
'reads a trace'
do
it
'reads a trace'
do
is_expected
.
to
eq
(
remote_trac
e_body
[
0
,
length
])
is_expected
.
to
eq
(
fil
e_body
[
0
,
length
])
end
end
end
end
...
@@ -163,7 +166,7 @@ describe Gitlab::HttpIO do
...
@@ -163,7 +166,7 @@ describe Gitlab::HttpIO do
end
end
it
'reads a trace'
do
it
'reads a trace'
do
is_expected
.
to
eq
(
remote_trac
e_body
[
0
,
length
])
is_expected
.
to
eq
(
fil
e_body
[
0
,
length
])
end
end
end
end
end
end
...
@@ -177,7 +180,7 @@ describe Gitlab::HttpIO do
...
@@ -177,7 +180,7 @@ describe Gitlab::HttpIO do
end
end
it
'reads a trace'
do
it
'reads a trace'
do
is_expected
.
to
eq
(
remote_trac
e_body
)
is_expected
.
to
eq
(
fil
e_body
)
end
end
end
end
...
@@ -187,7 +190,7 @@ describe Gitlab::HttpIO do
...
@@ -187,7 +190,7 @@ describe Gitlab::HttpIO do
end
end
it
'reads a trace'
do
it
'reads a trace'
do
is_expected
.
to
eq
(
remote_trac
e_body
)
is_expected
.
to
eq
(
fil
e_body
)
end
end
end
end
end
end
...
@@ -221,11 +224,11 @@ describe Gitlab::HttpIO do
...
@@ -221,11 +224,11 @@ describe Gitlab::HttpIO do
let
(
:length
)
{
nil
}
let
(
:length
)
{
nil
}
before
do
before
do
stub_remote_
trace_500
stub_remote_
url_500
(
url
)
end
end
it
'reads a trace'
do
it
'reads a trace'
do
expect
{
subject
}.
to
raise_error
(
Gitlab
::
Ci
::
Trace
::
HttpIO
::
FailedToGetChunkError
)
expect
{
subject
}.
to
raise_error
(
Gitlab
::
HttpIO
::
FailedToGetChunkError
)
end
end
end
end
end
end
...
@@ -233,15 +236,15 @@ describe Gitlab::HttpIO do
...
@@ -233,15 +236,15 @@ describe Gitlab::HttpIO do
describe
'#readline'
do
describe
'#readline'
do
subject
{
http_io
.
readline
}
subject
{
http_io
.
readline
}
let
(
:string_io
)
{
StringIO
.
new
(
remote_trac
e_body
)
}
let
(
:string_io
)
{
StringIO
.
new
(
fil
e_body
)
}
before
do
before
do
stub_remote_
trace_206
stub_remote_
url_206
(
url
,
file_path
)
end
end
shared_examples
'all line matching'
do
shared_examples
'all line matching'
do
it
'reads a line'
do
it
'reads a line'
do
(
0
...
remote_trac
e_body
.
lines
.
count
).
each
do
(
0
...
fil
e_body
.
lines
.
count
).
each
do
expect
(
http_io
.
readline
).
to
eq
(
string_io
.
readline
)
expect
(
http_io
.
readline
).
to
eq
(
string_io
.
readline
)
end
end
end
end
...
@@ -251,11 +254,11 @@ describe Gitlab::HttpIO do
...
@@ -251,11 +254,11 @@ describe Gitlab::HttpIO do
let
(
:length
)
{
nil
}
let
(
:length
)
{
nil
}
before
do
before
do
stub_remote_
trace_500
stub_remote_
url_500
(
url
)
end
end
it
'reads a trace'
do
it
'reads a trace'
do
expect
{
subject
}.
to
raise_error
(
Gitlab
::
Ci
::
Trace
::
HttpIO
::
FailedToGetChunkError
)
expect
{
subject
}.
to
raise_error
(
Gitlab
::
HttpIO
::
FailedToGetChunkError
)
end
end
end
end
...
...
spec/models/ci/build_spec.rb
View file @
5a9f23e7
...
@@ -2687,4 +2687,58 @@ describe Ci::Build do
...
@@ -2687,4 +2687,58 @@ describe Ci::Build do
end
end
end
end
end
end
describe
'#artifacts_metadata_entry'
do
set
(
:build
)
{
create
(
:ci_build
,
project:
project
)
}
let
(
:path
)
{
'other_artifacts_0.1.2/another-subdirectory/banana_sample.gif'
}
before
do
stub_artifacts_object_storage
end
subject
{
build
.
artifacts_metadata_entry
(
path
)
}
context
'when using local storage'
do
let!
(
:metadata
)
{
create
(
:ci_job_artifact
,
:metadata
,
job:
build
)
}
context
'for existing file'
do
it
'does exist'
do
is_expected
.
to
be_exists
end
end
context
'for non-existing file'
do
let
(
:path
)
{
'invalid-file'
}
it
'does not exist'
do
is_expected
.
not_to
be_exists
end
end
end
context
'when using remote storage'
do
include
HttpIOHelpers
let!
(
:metadata
)
{
create
(
:ci_job_artifact
,
:remote_store
,
:metadata
,
job:
build
)
}
let
(
:file_path
)
{
expand_fixture_path
(
'ci_build_artifacts_metadata.gz'
)
}
before
do
stub_remote_url_206
(
metadata
.
file
.
url
,
file_path
)
end
context
'for existing file'
do
it
'does exist'
do
is_expected
.
to
be_exists
end
end
context
'for non-existing file'
do
let
(
:path
)
{
'invalid-file'
}
it
'does not exist'
do
is_expected
.
not_to
be_exists
end
end
end
end
end
end
spec/requests/api/jobs_spec.rb
View file @
5a9f23e7
...
@@ -535,12 +535,14 @@ describe API::Jobs do
...
@@ -535,12 +535,14 @@ describe API::Jobs do
context
'authorized user'
do
context
'authorized user'
do
context
'when trace is in ObjectStorage'
do
context
'when trace is in ObjectStorage'
do
let!
(
:job
)
{
create
(
:ci_build
,
:trace_artifact
,
pipeline:
pipeline
)
}
let!
(
:job
)
{
create
(
:ci_build
,
:trace_artifact
,
pipeline:
pipeline
)
}
let
(
:url
)
{
'http://object-storage/trace'
}
let
(
:file
)
{
expand_fixture_path
(
'trace/sample_trace'
)
}
before
do
before
do
stub_remote_
trace_206
stub_remote_
url_206
(
url
,
file_path
)
allow_any_instance_of
(
JobArtifactUploader
).
to
receive
(
:file_storage?
)
{
false
}
allow_any_instance_of
(
JobArtifactUploader
).
to
receive
(
:file_storage?
)
{
false
}
allow_any_instance_of
(
JobArtifactUploader
).
to
receive
(
:url
)
{
remote_trace_
url
}
allow_any_instance_of
(
JobArtifactUploader
).
to
receive
(
:url
)
{
url
}
allow_any_instance_of
(
JobArtifactUploader
).
to
receive
(
:size
)
{
remote_trace_size
}
allow_any_instance_of
(
JobArtifactUploader
).
to
receive
(
:size
)
{
File
.
size
(
file
)
}
end
end
it
'returns specific job trace'
do
it
'returns specific job trace'
do
...
...
spec/support/http_io/http_io_helpers.rb
View file @
5a9f23e7
module
HttpIOHelpers
module
HttpIOHelpers
def
stub_remote_
trace_206
def
stub_remote_
url_206
(
url
,
file_path
)
WebMock
.
stub_request
(
:get
,
remote_trace_
url
)
WebMock
.
stub_request
(
:get
,
url
)
.
to_return
{
|
request
|
remote_
trace_response
(
request
,
206
)
}
.
to_return
{
|
request
|
remote_
url_response
(
file_path
,
request
,
206
)
}
end
end
def
stub_remote_
trace_200
def
stub_remote_
url_200
(
url
,
file_path
)
WebMock
.
stub_request
(
:get
,
remote_trace_
url
)
WebMock
.
stub_request
(
:get
,
url
)
.
to_return
{
|
request
|
remote_
trace_response
(
request
,
200
)
}
.
to_return
{
|
request
|
remote_
url_response
(
file_path
,
request
,
200
)
}
end
end
def
stub_remote_
trace_500
def
stub_remote_
url_500
(
url
)
WebMock
.
stub_request
(
:get
,
remote_trace_
url
)
WebMock
.
stub_request
(
:get
,
url
)
.
to_return
(
status:
[
500
,
"Internal Server Error"
])
.
to_return
(
status:
[
500
,
"Internal Server Error"
])
end
end
def
remote_trace_url
def
remote_url_response
(
file_path
,
request
,
response_status
)
"http://trace.com/trace"
end
def
remote_trace_response
(
request
,
responce_status
)
range
=
request
.
headers
[
'Range'
].
match
(
/bytes=(\d+)-(\d+)/
)
range
=
request
.
headers
[
'Range'
].
match
(
/bytes=(\d+)-(\d+)/
)
body
=
File
.
read
(
file_path
).
force_encoding
(
Encoding
::
BINARY
)
size
=
body
.
bytesize
{
{
status:
respon
c
e_status
,
status:
respon
s
e_status
,
headers:
remote_
trace_response_headers
(
responce_status
,
range
[
1
].
to_i
,
range
[
2
].
to_i
),
headers:
remote_
url_response_headers
(
response_status
,
range
[
1
].
to_i
,
range
[
2
].
to_i
,
size
),
body:
range_trace_body
(
range
[
1
].
to_i
,
range
[
2
].
to_i
)
body:
body
[
range
[
1
].
to_i
..
range
[
2
].
to_i
]
}
}
end
end
def
remote_
trace_response_headers
(
responce_status
,
from
,
to
)
def
remote_
url_response_headers
(
response_status
,
from
,
to
,
size
)
headers
=
{
'Content-Type'
=>
'text/plain'
}
{
'Content-Type'
=>
'text/plain'
}.
tap
do
|
headers
|
if
response_status
==
206
if
responce_status
==
206
headers
.
merge
(
'Content-Range'
=>
"bytes
#{
from
}
-
#{
to
}
/
#{
size
}
"
)
headers
.
merge
(
'Content-Range'
=>
"bytes
#{
from
}
-
#{
to
}
/
#{
remote_trace_size
}
"
)
end
end
end
headers
end
def
range_trace_body
(
from
,
to
)
remote_trace_body
[
from
..
to
]
end
def
remote_trace_body
@remote_trace_body
||=
File
.
read
(
expand_fixture_path
(
'trace/sample_trace'
))
.
force_encoding
(
Encoding
::
BINARY
)
end
def
remote_trace_size
remote_trace_body
.
bytesize
end
end
def
set_smaller_buffer_size_than
(
file_size
)
def
set_smaller_buffer_size_than
(
file_size
)
...
...
spec/uploaders/gitlab_uploader_spec.rb
View file @
5a9f23e7
...
@@ -68,4 +68,66 @@ describe GitlabUploader do
...
@@ -68,4 +68,66 @@ describe GitlabUploader do
expect
(
subject
.
file
.
path
).
to
match
(
/
#{
subject
.
cache_dir
}
/
)
expect
(
subject
.
file
.
path
).
to
match
(
/
#{
subject
.
cache_dir
}
/
)
end
end
end
end
describe
'#open'
do
context
'when trace is stored in File storage'
do
context
'when file exists'
do
let
(
:file
)
do
fixture_file_upload
(
'spec/fixtures/trace/sample_trace'
,
'text/plain'
)
end
before
do
subject
.
store!
(
file
)
end
it
'returns io stream'
do
expect
(
subject
.
open
).
to
be_a
(
IO
)
end
it
'when passing block it yields'
do
expect
{
|
b
|
subject
.
open
(
&
b
)
}.
to
yield_control
end
end
context
'when file does not exist'
do
it
'returns nil'
do
expect
(
subject
.
open
).
to
be_nil
end
it
'when passing block it does not yield'
do
expect
{
|
b
|
subject
.
open
(
&
b
)
}.
not_to
yield_control
end
end
end
context
'when trace is stored in Object storage'
do
before
do
allow
(
subject
).
to
receive
(
:file_storage?
)
{
false
}
end
context
'when file exists'
do
before
do
allow
(
subject
).
to
receive
(
:url
)
{
'http://object_storage.com/trace'
}
end
it
'returns http io stream'
do
expect
(
subject
.
open
).
to
be_a
(
Gitlab
::
HttpIO
)
end
it
'when passing block it yields'
do
expect
{
|
b
|
subject
.
open
(
&
b
)
}.
to
yield_control
.
once
end
end
context
'when file does not exist'
do
it
'returns nil'
do
expect
(
subject
.
open
).
to
be_nil
end
it
'when passing block it does not yield'
do
expect
{
|
b
|
subject
.
open
(
&
b
)
}.
not_to
yield_control
end
end
end
end
end
end
spec/uploaders/job_artifact_uploader_spec.rb
View file @
5a9f23e7
...
@@ -23,43 +23,6 @@ describe JobArtifactUploader do
...
@@ -23,43 +23,6 @@ describe JobArtifactUploader do
store_dir:
%r[
\h
{2}/
\h
{2}/
\h
{64}/
\d
{4}_
\d
{1,2}_
\d
{1,2}/
\d
+/
\d
+
\z
]
store_dir:
%r[
\h
{2}/
\h
{2}/
\h
{64}/
\d
{4}_
\d
{1,2}_
\d
{1,2}/
\d
+/
\d
+
\z
]
end
end
describe
'#open'
do
subject
{
uploader
.
open
}
context
'when trace is stored in File storage'
do
context
'when file exists'
do
let
(
:file
)
do
fixture_file_upload
(
'spec/fixtures/trace/sample_trace'
,
'text/plain'
)
end
before
do
uploader
.
store!
(
file
)
end
it
'returns io stream'
do
is_expected
.
to
be_a
(
IO
)
end
end
context
'when file does not exist'
do
it
'returns nil'
do
is_expected
.
to
be_nil
end
end
end
context
'when trace is stored in Object storage'
do
before
do
allow
(
uploader
).
to
receive
(
:file_storage?
)
{
false
}
allow
(
uploader
).
to
receive
(
:url
)
{
'http://object_storage.com/trace'
}
end
it
'returns http io stream'
do
is_expected
.
to
be_a
(
Gitlab
::
HttpIO
)
end
end
end
context
'file is stored in valid local_path'
do
context
'file is stored in valid local_path'
do
let
(
:file
)
do
let
(
:file
)
do
fixture_file_upload
(
'spec/fixtures/ci_build_artifacts.zip'
,
'application/zip'
)
fixture_file_upload
(
'spec/fixtures/ci_build_artifacts.zip'
,
'application/zip'
)
...
...
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