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
1e5b40e8
Commit
1e5b40e8
authored
Jul 12, 2017
by
Kamil Trzciński
Committed by
Rémy Coutable
Jul 12, 2017
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Artifacts store does not use default value
parent
b2a8a27b
Changes
6
Hide whitespace changes
Inline
Side-by-side
Showing
6 changed files
with
124 additions
and
20 deletions
+124
-20
app/uploaders/object_store_uploader.rb
app/uploaders/object_store_uploader.rb
+6
-2
db/migrate/20170601163708_add_artifacts_store_to_ci_build.rb
db/migrate/20170601163708_add_artifacts_store_to_ci_build.rb
+3
-10
db/schema.rb
db/schema.rb
+2
-2
lib/tasks/gitlab/artifacts.rake
lib/tasks/gitlab/artifacts.rake
+9
-6
spec/tasks/gitlab/artifacts_rake_spec.rb
spec/tasks/gitlab/artifacts_rake_spec.rb
+74
-0
spec/uploaders/object_store_uploader_spec.rb
spec/uploaders/object_store_uploader_spec.rb
+30
-0
No files found.
app/uploaders/object_store_uploader.rb
View file @
1e5b40e8
...
@@ -37,10 +37,14 @@ class ObjectStoreUploader < CarrierWave::Uploader::Base
...
@@ -37,10 +37,14 @@ class ObjectStoreUploader < CarrierWave::Uploader::Base
cache_storage
.
is_a?
(
CarrierWave
::
Storage
::
File
)
cache_storage
.
is_a?
(
CarrierWave
::
Storage
::
File
)
end
end
def
object_store
def
real_
object_store
subject
.
public_send
(
:"
#{
field
}
_store"
)
subject
.
public_send
(
:"
#{
field
}
_store"
)
end
end
def
object_store
real_object_store
||
LOCAL_STORE
end
def
object_store
=
(
value
)
def
object_store
=
(
value
)
@storage
=
nil
@storage
=
nil
subject
.
public_send
(
:"
#{
field
}
_store="
,
value
)
subject
.
public_send
(
:"
#{
field
}
_store="
,
value
)
...
@@ -127,7 +131,7 @@ class ObjectStoreUploader < CarrierWave::Uploader::Base
...
@@ -127,7 +131,7 @@ class ObjectStoreUploader < CarrierWave::Uploader::Base
private
private
def
set_default_local_store
(
new_file
)
def
set_default_local_store
(
new_file
)
self
.
object_store
=
LOCAL_STORE
unless
self
.
object_store
self
.
object_store
=
LOCAL_STORE
unless
self
.
real_
object_store
end
end
def
storage
def
storage
...
...
db/migrate/20170601163708_add_artifacts_store_to_ci_build.rb
View file @
1e5b40e8
...
@@ -3,15 +3,8 @@ class AddArtifactsStoreToCiBuild < ActiveRecord::Migration
...
@@ -3,15 +3,8 @@ class AddArtifactsStoreToCiBuild < ActiveRecord::Migration
DOWNTIME
=
false
DOWNTIME
=
false
disable_ddl_transaction!
def
change
add_column
(
:ci_builds
,
:artifacts_file_store
,
:integer
)
def
up
add_column
(
:ci_builds
,
:artifacts_metadata_store
,
:integer
)
add_column_with_default
(
:ci_builds
,
:artifacts_file_store
,
:integer
,
default:
1
)
add_column_with_default
(
:ci_builds
,
:artifacts_metadata_store
,
:integer
,
default:
1
)
end
def
down
remove_column
(
:ci_builds
,
:artifacts_file_store
)
remove_column
(
:ci_builds
,
:artifacts_metadata_store
)
end
end
end
end
db/schema.rb
View file @
1e5b40e8
...
@@ -294,8 +294,8 @@ ActiveRecord::Schema.define(version: 20170707184244) do
...
@@ -294,8 +294,8 @@ ActiveRecord::Schema.define(version: 20170707184244) do
t
.
integer
"auto_canceled_by_id"
t
.
integer
"auto_canceled_by_id"
t
.
boolean
"retried"
t
.
boolean
"retried"
t
.
integer
"stage_id"
t
.
integer
"stage_id"
t
.
integer
"artifacts_file_store"
,
default:
1
,
null:
false
t
.
integer
"artifacts_file_store"
t
.
integer
"artifacts_metadata_store"
,
default:
1
,
null:
false
t
.
integer
"artifacts_metadata_store"
end
end
add_index
"ci_builds"
,
[
"auto_canceled_by_id"
],
name:
"index_ci_builds_on_auto_canceled_by_id"
,
using: :btree
add_index
"ci_builds"
,
[
"auto_canceled_by_id"
],
name:
"index_ci_builds_on_auto_canceled_by_id"
,
using: :btree
...
...
lib/tasks/gitlab/artifacts.rake
View file @
1e5b40e8
...
@@ -3,15 +3,18 @@ namespace :gitlab do
...
@@ -3,15 +3,18 @@ namespace :gitlab do
namespace
:artifacts
do
namespace
:artifacts
do
task
migrate: :environment
do
task
migrate: :environment
do
puts
'Artifacts'
.
color
(
:yellow
)
puts
'Artifacts'
.
color
(
:yellow
)
Ci
::
Build
.
joins
(
:project
).
with_artifacts
Ci
::
Build
.
joins
(
:project
)
.
where
(
artifacts_file_store:
ArtifactUploader
::
LOCAL_STORE
)
.
with_artifacts
.
find_each
(
batch_size:
100
)
do
|
issue
|
.
order
(
id: :asc
)
.
where
(
artifacts_file_store:
[
nil
,
ArtifactUploader
::
LOCAL_STORE
])
.
find_each
(
batch_size:
10
)
do
|
build
|
begin
begin
print
"Migrating job
#{
build
.
id
}
of size
#{
build
.
artifacts_size
.
to_i
.
bytes
}
to remote storage... "
build
.
artifacts_file
.
migrate!
(
ArtifactUploader
::
REMOTE_STORE
)
build
.
artifacts_file
.
migrate!
(
ArtifactUploader
::
REMOTE_STORE
)
build
.
artifacts_metadata
.
migrate!
(
ArtifactUploader
::
REMOTE_STORE
)
build
.
artifacts_metadata
.
migrate!
(
ArtifactUploader
::
REMOTE_STORE
)
p
rint
'.'
p
uts
"OK"
.
color
(
:green
)
rescue
rescue
=>
e
p
rint
'F'
p
uts
"Failed:
#{
e
.
message
}
"
.
color
(
:red
)
end
end
end
end
end
end
...
...
spec/tasks/gitlab/artifacts_rake_spec.rb
0 → 100644
View file @
1e5b40e8
require
'rake_helper'
describe
'gitlab:artifacts namespace rake task'
do
before
:all
do
Rake
.
application
.
rake_require
'tasks/gitlab/artifacts'
end
describe
'migrate'
do
let
(
:job
)
{
create
(
:ci_build
,
:artifacts
,
artifacts_file_store:
store
,
artifacts_metadata_store:
store
)
}
subject
{
run_rake_task
(
'gitlab:artifacts:migrate'
)
}
context
'when local storage is used'
do
let
(
:store
)
{
ObjectStoreUploader
::
LOCAL_STORE
}
context
'and job does not have file store defined'
do
before
do
stub_artifacts_object_storage
job
.
update
(
artifacts_file_store:
nil
)
end
it
"migrates file to remote storage"
do
subject
expect
(
job
.
reload
.
artifacts_file_store
).
to
eq
(
ObjectStoreUploader
::
REMOTE_STORE
)
expect
(
job
.
reload
.
artifacts_metadata_store
).
to
eq
(
ObjectStoreUploader
::
REMOTE_STORE
)
end
end
context
'and remote storage is defined'
do
before
do
stub_artifacts_object_storage
job
end
it
"migrates file to remote storage"
do
subject
expect
(
job
.
reload
.
artifacts_file_store
).
to
eq
(
ObjectStoreUploader
::
REMOTE_STORE
)
expect
(
job
.
reload
.
artifacts_metadata_store
).
to
eq
(
ObjectStoreUploader
::
REMOTE_STORE
)
end
end
context
'and remote storage is not defined'
do
before
do
job
end
it
"fails to migrate to remote storage"
do
subject
expect
(
job
.
reload
.
artifacts_file_store
).
to
eq
(
ObjectStoreUploader
::
LOCAL_STORE
)
expect
(
job
.
reload
.
artifacts_metadata_store
).
to
eq
(
ObjectStoreUploader
::
LOCAL_STORE
)
end
end
end
context
'when remote storage is used'
do
let
(
:store
)
{
ObjectStoreUploader
::
REMOTE_STORE
}
before
do
stub_artifacts_object_storage
job
end
it
"file stays on remote storage"
do
subject
expect
(
job
.
reload
.
artifacts_file_store
).
to
eq
(
ObjectStoreUploader
::
REMOTE_STORE
)
expect
(
job
.
reload
.
artifacts_metadata_store
).
to
eq
(
ObjectStoreUploader
::
REMOTE_STORE
)
end
end
end
end
spec/uploaders/object_store_uploader_spec.rb
View file @
1e5b40e8
...
@@ -12,6 +12,28 @@ describe ObjectStoreUploader do
...
@@ -12,6 +12,28 @@ describe ObjectStoreUploader do
uploader
.
object_store
uploader
.
object_store
end
end
context
'when store is null'
do
before
do
expect
(
object
).
to
receive
(
:artifacts_file_store
).
twice
.
and_return
(
nil
)
end
it
"returns LOCAL_STORE"
do
expect
(
uploader
.
real_object_store
).
to
be_nil
expect
(
uploader
.
object_store
).
to
eq
(
described_class
::
LOCAL_STORE
)
end
end
context
'when value is set'
do
before
do
expect
(
object
).
to
receive
(
:artifacts_file_store
).
twice
.
and_return
(
described_class
::
REMOTE_STORE
)
end
it
"returns given value"
do
expect
(
uploader
.
real_object_store
).
not_to
be_nil
expect
(
uploader
.
object_store
).
to
eq
(
described_class
::
REMOTE_STORE
)
end
end
end
end
describe
'#object_store='
do
describe
'#object_store='
do
...
@@ -72,6 +94,14 @@ describe ObjectStoreUploader do
...
@@ -72,6 +94,14 @@ describe ObjectStoreUploader do
end
end
end
end
context
'when store is null'
do
let
(
:store
)
{
nil
}
it
"sets the store to LOCAL_STORE"
do
expect
(
job
.
artifacts_file_store
).
to
eq
(
described_class
::
LOCAL_STORE
)
end
end
describe
'#use_file'
do
describe
'#use_file'
do
context
'when file is stored locally'
do
context
'when file is stored locally'
do
let
(
:store
)
{
described_class
::
LOCAL_STORE
}
let
(
:store
)
{
described_class
::
LOCAL_STORE
}
...
...
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