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
cbd09793
Commit
cbd09793
authored
Feb 06, 2018
by
Micaël Bergeron
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
apply feedback
mainly renaming `object_storage:object_storage_background_upload` to `*_move`
parent
2aec9d32
Changes
18
Show whitespace changes
Inline
Side-by-side
Showing
18 changed files
with
207 additions
and
62 deletions
+207
-62
app/models/appearance.rb
app/models/appearance.rb
+1
-1
app/models/concerns/avatarable.rb
app/models/concerns/avatarable.rb
+1
-1
app/workers/all_queues.yml
app/workers/all_queues.yml
+1
-1
ee/app/models/ee/ci/build.rb
ee/app/models/ee/ci/build.rb
+1
-1
ee/app/models/ee/ci/job_artifact.rb
ee/app/models/ee/ci/job_artifact.rb
+1
-1
ee/app/models/ee/lfs_object.rb
ee/app/models/ee/lfs_object.rb
+1
-1
ee/app/models/ee/note.rb
ee/app/models/ee/note.rb
+1
-1
ee/app/uploaders/object_storage.rb
ee/app/uploaders/object_storage.rb
+3
-3
ee/app/workers/object_storage/background_move_worker.rb
ee/app/workers/object_storage/background_move_worker.rb
+4
-4
ee/app/workers/object_storage/migrate_uploads_worker.rb
ee/app/workers/object_storage/migrate_uploads_worker.rb
+7
-12
ee/app/workers/object_storage_upload_worker.rb
ee/app/workers/object_storage_upload_worker.rb
+0
-3
ee/lib/tasks/gitlab/uploads/migrate.rake
ee/lib/tasks/gitlab/uploads/migrate.rake
+14
-9
spec/ee/spec/models/ee/lfs_object_spec.rb
spec/ee/spec/models/ee/lfs_object_spec.rb
+4
-4
spec/ee/spec/workers/object_storage/background_move_worker_spec.rb
...pec/workers/object_storage/background_move_worker_spec.rb
+146
-0
spec/ee/spec/workers/object_storage/migrate_uploads_worker_spec.rb
...pec/workers/object_storage/migrate_uploads_worker_spec.rb
+12
-10
spec/models/ci/job_artifact_spec.rb
spec/models/ci/job_artifact_spec.rb
+4
-4
spec/requests/lfs_http_spec.rb
spec/requests/lfs_http_spec.rb
+2
-2
spec/uploaders/lfs_object_uploader_spec.rb
spec/uploaders/lfs_object_uploader_spec.rb
+4
-4
No files found.
app/models/appearance.rb
View file @
cbd09793
class
Appearance
<
ActiveRecord
::
Base
class
Appearance
<
ActiveRecord
::
Base
include
CacheMarkdownField
include
CacheMarkdownField
include
AfterCommitQueue
include
AfterCommitQueue
include
ObjectStorage
::
Background
Upload
include
ObjectStorage
::
Background
Move
cache_markdown_field
:description
cache_markdown_field
:description
cache_markdown_field
:new_project_guidelines
cache_markdown_field
:new_project_guidelines
...
...
app/models/concerns/avatarable.rb
View file @
cbd09793
...
@@ -3,7 +3,7 @@ module Avatarable
...
@@ -3,7 +3,7 @@ module Avatarable
included
do
included
do
prepend
ShadowMethods
prepend
ShadowMethods
include
ObjectStorage
::
Background
Upload
include
ObjectStorage
::
Background
Move
validate
:avatar_type
,
if:
->
(
user
)
{
user
.
avatar
.
present?
&&
user
.
avatar_changed?
}
validate
:avatar_type
,
if:
->
(
user
)
{
user
.
avatar
.
present?
&&
user
.
avatar_changed?
}
validates
:avatar
,
file_size:
{
maximum:
200
.
kilobytes
.
to_i
}
validates
:avatar
,
file_size:
{
maximum:
200
.
kilobytes
.
to_i
}
...
...
app/workers/all_queues.yml
View file @
cbd09793
...
@@ -122,7 +122,7 @@
...
@@ -122,7 +122,7 @@
-
geo:geo_repository_destroy
-
geo:geo_repository_destroy
-
object_storage_upload
-
object_storage_upload
-
object_storage:object_storage_background_
upload
-
object_storage:object_storage_background_
move
-
object_storage:object_storage_migrate_uploads
-
object_storage:object_storage_migrate_uploads
-
admin_emails
-
admin_emails
...
...
ee/app/models/ee/ci/build.rb
View file @
cbd09793
...
@@ -14,7 +14,7 @@ module EE
...
@@ -14,7 +14,7 @@ module EE
DAST_FILE
=
'gl-dast-report.json'
.
freeze
DAST_FILE
=
'gl-dast-report.json'
.
freeze
included
do
included
do
include
ObjectStorage
::
Background
Upload
include
ObjectStorage
::
Background
Move
scope
:codequality
,
->
{
where
(
name:
%w[codequality codeclimate]
)
}
scope
:codequality
,
->
{
where
(
name:
%w[codequality codeclimate]
)
}
scope
:performance
,
->
{
where
(
name:
%w[performance deploy]
)
}
scope
:performance
,
->
{
where
(
name:
%w[performance deploy]
)
}
...
...
ee/app/models/ee/ci/job_artifact.rb
View file @
cbd09793
...
@@ -7,7 +7,7 @@ module EE
...
@@ -7,7 +7,7 @@ module EE
extend
ActiveSupport
::
Concern
extend
ActiveSupport
::
Concern
prepended
do
prepended
do
include
ObjectStorage
::
Background
Upload
include
ObjectStorage
::
Background
Move
after_destroy
:log_geo_event
after_destroy
:log_geo_event
...
...
ee/app/models/ee/lfs_object.rb
View file @
cbd09793
...
@@ -7,7 +7,7 @@ module EE
...
@@ -7,7 +7,7 @@ module EE
extend
ActiveSupport
::
Concern
extend
ActiveSupport
::
Concern
prepended
do
prepended
do
include
ObjectStorage
::
Background
Upload
include
ObjectStorage
::
Background
Move
after_destroy
:log_geo_event
after_destroy
:log_geo_event
...
...
ee/app/models/ee/note.rb
View file @
cbd09793
...
@@ -3,7 +3,7 @@ module EE
...
@@ -3,7 +3,7 @@ module EE
extend
ActiveSupport
::
Concern
extend
ActiveSupport
::
Concern
prepended
do
prepended
do
include
ObjectStorage
::
Background
Upload
include
ObjectStorage
::
Background
Move
end
end
def
for_epic?
def
for_epic?
...
...
ee/app/uploaders/object_storage.rb
View file @
cbd09793
...
@@ -53,7 +53,7 @@ module ObjectStorage
...
@@ -53,7 +53,7 @@ module ObjectStorage
def
schedule_background_upload
(
*
args
)
def
schedule_background_upload
(
*
args
)
return
unless
schedule_background_upload?
return
unless
schedule_background_upload?
ObjectStorage
::
Background
Upload
Worker
.
perform_async
(
self
.
class
.
name
,
ObjectStorage
::
Background
Move
Worker
.
perform_async
(
self
.
class
.
name
,
upload
.
class
.
to_s
,
upload
.
class
.
to_s
,
mounted_as
,
mounted_as
,
upload
.
id
)
upload
.
id
)
...
@@ -74,7 +74,7 @@ module ObjectStorage
...
@@ -74,7 +74,7 @@ module ObjectStorage
# Add support for automatic background uploading after the file is stored.
# Add support for automatic background uploading after the file is stored.
#
#
module
Background
Upload
module
Background
Move
extend
ActiveSupport
::
Concern
extend
ActiveSupport
::
Concern
def
background_upload
(
mount_points
=
[])
def
background_upload
(
mount_points
=
[])
...
@@ -226,7 +226,7 @@ module ObjectStorage
...
@@ -226,7 +226,7 @@ module ObjectStorage
def
schedule_background_upload
(
*
args
)
def
schedule_background_upload
(
*
args
)
return
unless
schedule_background_upload?
return
unless
schedule_background_upload?
ObjectStorage
::
Background
Upload
Worker
.
perform_async
(
self
.
class
.
name
,
ObjectStorage
::
Background
Move
Worker
.
perform_async
(
self
.
class
.
name
,
model
.
class
.
name
,
model
.
class
.
name
,
mounted_as
,
mounted_as
,
model
.
id
)
model
.
id
)
...
...
ee/app/workers/object_storage/background_
upload
_worker.rb
→
ee/app/workers/object_storage/background_
move
_worker.rb
View file @
cbd09793
module
ObjectStorage
module
ObjectStorage
class
Background
Upload
Worker
class
Background
Move
Worker
include
ApplicationWorker
include
ApplicationWorker
include
ObjectStorageQueue
include
ObjectStorageQueue
...
@@ -10,13 +10,13 @@ module ObjectStorage
...
@@ -10,13 +10,13 @@ module ObjectStorage
subject_class
=
subject_class_name
.
constantize
subject_class
=
subject_class_name
.
constantize
return
unless
uploader_class
<
ObjectStorage
::
Concern
return
unless
uploader_class
<
ObjectStorage
::
Concern
return
unless
uploader_class
.
object_store_enabled?
return
unless
uploader_class
.
licensed?
return
unless
uploader_class
.
background_upload_enabled?
subject
=
subject_class
.
find
(
subject_id
)
subject
=
subject_class
.
find
(
subject_id
)
uploader
=
build_uploader
(
subject
,
file_field
&
.
to_sym
)
uploader
=
build_uploader
(
subject
,
file_field
&
.
to_sym
)
uploader
.
migrate!
(
ObjectStorage
::
Store
::
REMOTE
)
uploader
.
migrate!
(
ObjectStorage
::
Store
::
REMOTE
)
rescue
RecordNotFound
# does not retry when the record do not exists
Rails
.
logger
.
warn
(
"Cannot find subject
#{
subject_class
}
with id=
#{
subject_id
}
."
)
end
end
def
build_uploader
(
subject
,
mount_point
)
def
build_uploader
(
subject
,
mount_point
)
...
...
ee/app/workers/object_storage/migrate_uploads_worker.rb
View file @
cbd09793
...
@@ -99,10 +99,6 @@ module ObjectStorage
...
@@ -99,10 +99,6 @@ module ObjectStorage
def
success?
def
success?
error
.
nil?
error
.
nil?
end
end
def
to_s
success?
?
"Migration sucessful."
:
"Error while migrating
#{
upload
.
id
}
:
#{
error
.
message
}
"
end
end
end
module
Report
module
Report
...
@@ -176,7 +172,7 @@ module ObjectStorage
...
@@ -176,7 +172,7 @@ module ObjectStorage
report!
(
results
)
report!
(
results
)
rescue
SanityCheckError
=>
e
rescue
SanityCheckError
=>
e
# do not retry: the job is insane
# do not retry: the job is insane
Rails
.
logger
.
warn
"
UploadsToObjectStorage sanity check error:
#{
e
.
message
}
"
Rails
.
logger
.
warn
"
#{
self
.
class
}
: Sanity check error (
#{
e
.
message
}
)
"
end
end
def
sanity_check!
(
uploads
)
def
sanity_check!
(
uploads
)
...
@@ -192,13 +188,12 @@ module ObjectStorage
...
@@ -192,13 +188,12 @@ module ObjectStorage
end
end
def
process_uploader
(
uploader
)
def
process_uploader
(
uploader
)
result
=
MigrationResult
.
new
(
uploader
.
upload
)
MigrationResult
.
new
(
uploader
.
upload
).
tap
do
|
result
|
begin
begin
uploader
.
migrate!
(
@to_store
)
uploader
.
migrate!
(
@to_store
)
result
rescue
=>
e
rescue
=>
e
result
.
error
=
e
result
.
error
=
e
result
end
end
end
end
end
end
end
...
...
ee/app/workers/object_storage_upload_worker.rb
View file @
cbd09793
...
@@ -18,8 +18,5 @@ class ObjectStorageUploadWorker
...
@@ -18,8 +18,5 @@ class ObjectStorageUploadWorker
subject
=
subject_class
.
find
(
subject_id
)
subject
=
subject_class
.
find
(
subject_id
)
uploader
=
subject
.
public_send
(
file_field
)
# rubocop:disable GitlabSecurity/PublicSend
uploader
=
subject
.
public_send
(
file_field
)
# rubocop:disable GitlabSecurity/PublicSend
uploader
.
migrate!
(
ObjectStorage
::
Store
::
REMOTE
)
uploader
.
migrate!
(
ObjectStorage
::
Store
::
REMOTE
)
rescue
RecordNotFound
# does not retry when the record do not exists
Rails
.
logger
.
warn
(
"Cannot find subject
#{
subject_class
}
with id=
#{
subject_id
}
."
)
end
end
end
end
ee/lib/tasks/gitlab/uploads/migrate.rake
View file @
cbd09793
...
@@ -5,24 +5,29 @@ namespace :gitlab do
...
@@ -5,24 +5,29 @@ namespace :gitlab do
batch_size
=
ENV
.
fetch
(
'BATCH'
,
200
).
to_i
batch_size
=
ENV
.
fetch
(
'BATCH'
,
200
).
to_i
@to_store
=
ObjectStorage
::
Store
::
REMOTE
@to_store
=
ObjectStorage
::
Store
::
REMOTE
@mounted_as
=
args
.
mounted_as
&
.
gsub
(
':'
,
''
)
&
.
to_sym
@mounted_as
=
args
.
mounted_as
&
.
gsub
(
':'
,
''
)
&
.
to_sym
uploader_class
=
args
.
uploader_class
.
constantize
@
uploader_class
=
args
.
uploader_class
.
constantize
model_class
=
args
.
model_class
.
constantize
@
model_class
=
args
.
model_class
.
constantize
Upload
uploads
.
each_batch
(
of:
batch_size
,
&
method
(
:enqueue_batch
))
# rubocop: disable Cop/InBatches
.
where
.
not
(
store:
@to_store
)
.
where
(
uploader:
uploader_class
.
to_s
,
model_type:
model_class
.
base_class
.
sti_name
)
.
in_batches
(
of:
batch_size
,
&
method
(
:enqueue_batch
))
# rubocop: disable Cop/InBatches
end
end
def
enqueue_batch
(
batch
)
def
enqueue_batch
(
batch
,
index
)
job
=
ObjectStorage
::
MigrateUploadsWorker
.
enqueue!
(
batch
,
job
=
ObjectStorage
::
MigrateUploadsWorker
.
enqueue!
(
batch
,
@mounted_as
,
@mounted_as
,
@to_store
)
@to_store
)
puts
"Enqueued job:
#{
job
}
"
puts
"Enqueued job
#
#{
index
}
:
#{
job
}
"
rescue
ObjectStorage
::
MigrateUploadsWorker
::
SanityCheckError
=>
e
rescue
ObjectStorage
::
MigrateUploadsWorker
::
SanityCheckError
=>
e
# continue for the next batch
# continue for the next batch
puts
"Could not enqueue batch (
#{
batch
.
ids
}
)
#{
e
.
message
}
"
.
color
(
:red
)
puts
"Could not enqueue batch (
#{
batch
.
ids
}
)
#{
e
.
message
}
"
.
color
(
:red
)
end
end
def
uploads
Upload
.
class_eval
{
include
EachBatch
}
unless
Upload
<
EachBatch
Upload
.
where
.
not
(
store:
@to_store
)
.
where
(
uploader:
@uploader_class
.
to_s
,
model_type:
@model_class
.
base_class
.
sti_name
)
end
end
end
end
end
spec/ee/spec/models/ee/lfs_object_spec.rb
View file @
cbd09793
...
@@ -47,7 +47,7 @@ describe LfsObject do
...
@@ -47,7 +47,7 @@ describe LfsObject do
end
end
it
'does not schedule the migration'
do
it
'does not schedule the migration'
do
expect
(
ObjectStorage
::
Background
Upload
Worker
).
not_to
receive
(
:perform_async
)
expect
(
ObjectStorage
::
Background
Move
Worker
).
not_to
receive
(
:perform_async
)
subject
subject
end
end
...
@@ -61,7 +61,7 @@ describe LfsObject do
...
@@ -61,7 +61,7 @@ describe LfsObject do
end
end
it
'schedules the model for migration'
do
it
'schedules the model for migration'
do
expect
(
ObjectStorage
::
Background
Upload
Worker
).
to
receive
(
:perform_async
).
with
(
'LfsObjectUploader'
,
described_class
.
name
,
:file
,
kind_of
(
Numeric
))
expect
(
ObjectStorage
::
Background
Move
Worker
).
to
receive
(
:perform_async
).
with
(
'LfsObjectUploader'
,
described_class
.
name
,
:file
,
kind_of
(
Numeric
))
subject
subject
end
end
...
@@ -73,7 +73,7 @@ describe LfsObject do
...
@@ -73,7 +73,7 @@ describe LfsObject do
end
end
it
'does not schedule the migration'
do
it
'does not schedule the migration'
do
expect
(
ObjectStorage
::
Background
Upload
Worker
).
not_to
receive
(
:perform_async
)
expect
(
ObjectStorage
::
Background
Move
Worker
).
not_to
receive
(
:perform_async
)
subject
subject
end
end
...
@@ -86,7 +86,7 @@ describe LfsObject do
...
@@ -86,7 +86,7 @@ describe LfsObject do
end
end
it
'schedules the model for migration'
do
it
'schedules the model for migration'
do
expect
(
ObjectStorage
::
Background
Upload
Worker
).
not_to
receive
(
:perform_async
)
expect
(
ObjectStorage
::
Background
Move
Worker
).
not_to
receive
(
:perform_async
)
subject
subject
end
end
...
...
spec/ee/spec/workers/object_storage/background_move_worker_spec.rb
0 → 100644
View file @
cbd09793
require
'spec_helper'
describe
ObjectStorage
::
BackgroundMoveWorker
do
let
(
:local
)
{
ObjectStorage
::
Store
::
LOCAL
}
let
(
:remote
)
{
ObjectStorage
::
Store
::
REMOTE
}
def
perform
described_class
.
perform_async
(
uploader_class
.
name
,
subject_class
,
file_field
,
subject_id
)
end
context
'for LFS'
do
let!
(
:lfs_object
)
{
create
(
:lfs_object
,
:with_file
,
file_store:
local
)
}
let
(
:uploader_class
)
{
LfsObjectUploader
}
let
(
:subject_class
)
{
LfsObject
}
let
(
:file_field
)
{
:file
}
let
(
:subject_id
)
{
lfs_object
.
id
}
context
'when object storage is enabled'
do
before
do
stub_lfs_object_storage
(
background_upload:
true
)
end
it
'uploads object to storage'
do
expect
{
perform
}.
to
change
{
lfs_object
.
reload
.
file_store
}.
from
(
local
).
to
(
remote
)
end
context
'when background upload is disabled'
do
before
do
allow
(
Gitlab
.
config
.
lfs
.
object_store
).
to
receive
(
:background_upload
)
{
false
}
end
it
'is skipped'
do
expect
{
perform
}.
not_to
change
{
lfs_object
.
reload
.
file_store
}
end
end
end
context
'when object storage is disabled'
do
before
do
stub_lfs_object_storage
(
enabled:
false
)
end
it
"doesn't migrate files"
do
perform
expect
(
lfs_object
.
reload
.
file_store
).
to
eq
(
local
)
end
end
end
context
'for legacy artifacts'
do
let
(
:build
)
{
create
(
:ci_build
,
:legacy_artifacts
)
}
let
(
:uploader_class
)
{
LegacyArtifactUploader
}
let
(
:subject_class
)
{
Ci
::
Build
}
let
(
:file_field
)
{
:artifacts_file
}
let
(
:subject_id
)
{
build
.
id
}
context
'when local storage is used'
do
let
(
:store
)
{
local
}
context
'and remote storage is defined'
do
before
do
stub_artifacts_object_storage
(
background_upload:
true
)
end
it
"migrates file to remote storage"
do
perform
expect
(
build
.
reload
.
artifacts_file_store
).
to
eq
(
remote
)
end
context
'for artifacts_metadata'
do
let
(
:file_field
)
{
:artifacts_metadata
}
it
'migrates metadata to remote storage'
do
perform
expect
(
build
.
reload
.
artifacts_metadata_store
).
to
eq
(
remote
)
end
end
end
end
end
context
'for job artifacts'
do
let
(
:artifact
)
{
create
(
:ci_job_artifact
,
:archive
)
}
let
(
:uploader_class
)
{
JobArtifactUploader
}
let
(
:subject_class
)
{
Ci
::
JobArtifact
}
let
(
:file_field
)
{
:file
}
let
(
:subject_id
)
{
artifact
.
id
}
context
'when local storage is used'
do
let
(
:store
)
{
local
}
context
'and remote storage is defined'
do
before
do
stub_artifacts_object_storage
(
background_upload:
true
)
end
it
"migrates file to remote storage"
do
perform
expect
(
artifact
.
reload
.
file_store
).
to
eq
(
remote
)
end
end
end
end
context
'for uploads'
do
let!
(
:project
)
{
create
(
:project
,
:with_avatar
)
}
let
(
:uploader_class
)
{
AvatarUploader
}
let
(
:file_field
)
{
:avatar
}
context
'when local storage is used'
do
let
(
:store
)
{
local
}
context
'and remote storage is defined'
do
before
do
stub_uploads_object_storage
(
uploader_class
,
background_upload:
true
)
end
describe
'supports using the model'
do
let
(
:subject_class
)
{
project
.
class
}
let
(
:subject_id
)
{
project
.
id
}
it
"migrates file to remote storage"
do
perform
expect
(
project
.
reload
.
avatar
.
file_storage?
).
to
be_falsey
end
end
describe
'supports using the Upload'
do
let
(
:subject_class
)
{
Upload
}
let
(
:subject_id
)
{
project
.
avatar
.
upload
.
id
}
it
"migrates file to remote storage"
do
perform
expect
(
project
.
reload
.
avatar
.
file_storage?
).
to
be_falsey
end
end
end
end
end
end
spec/ee/spec/workers/object_storage/migrate_uploads_worker_spec.rb
View file @
cbd09793
...
@@ -75,23 +75,25 @@ describe ObjectStorage::MigrateUploadsWorker, :sidekiq do
...
@@ -75,23 +75,25 @@ describe ObjectStorage::MigrateUploadsWorker, :sidekiq do
# swallow
# swallow
end
end
# rubocop:disable Style/MultilineIfModifier
shared_examples
'outputs correctly'
do
|
success:
0
,
failures:
0
|
shared_examples
'outputs correctly'
do
|
success:
0
,
failures:
0
|
total
=
success
+
failures
total
=
success
+
failures
if
success
it
'outputs the reports'
do
it
'outputs the reports'
do
expect
(
Rails
.
logger
).
to
receive
(
:info
).
with
(
%r{Migrated
#{
success
}
/
#{
total
}
files}
)
expect
(
Rails
.
logger
).
to
receive
(
:info
).
with
(
%r{Migrated
#{
success
}
/
#{
total
}
files}
)
perform
perform
end
if
success
>
0
end
end
if
failures
it
'outputs upload failures'
do
it
'outputs upload failures'
do
expect
(
Rails
.
logger
).
to
receive
(
:warn
).
with
(
/Error .* I am a teapot/
)
expect
(
Rails
.
logger
).
to
receive
(
:warn
).
with
(
/Error .* I am a teapot/
)
perform
perform
end
if
failures
>
0
end
end
# rubocop:enable Style/MultilineIfModifier
end
end
it_behaves_like
'outputs correctly'
,
success:
10
it_behaves_like
'outputs correctly'
,
success:
10
...
...
spec/models/ci/job_artifact_spec.rb
View file @
cbd09793
...
@@ -25,7 +25,7 @@ describe Ci::JobArtifact do
...
@@ -25,7 +25,7 @@ describe Ci::JobArtifact do
end
end
it
'does not schedule the migration'
do
it
'does not schedule the migration'
do
expect
(
ObjectStorage
::
Background
Upload
Worker
).
not_to
receive
(
:perform_async
)
expect
(
ObjectStorage
::
Background
Move
Worker
).
not_to
receive
(
:perform_async
)
subject
subject
end
end
...
@@ -39,7 +39,7 @@ describe Ci::JobArtifact do
...
@@ -39,7 +39,7 @@ describe Ci::JobArtifact do
end
end
it
'schedules the model for migration'
do
it
'schedules the model for migration'
do
expect
(
ObjectStorage
::
Background
Upload
Worker
).
to
receive
(
:perform_async
).
with
(
'JobArtifactUploader'
,
described_class
.
name
,
:file
,
kind_of
(
Numeric
))
expect
(
ObjectStorage
::
Background
Move
Worker
).
to
receive
(
:perform_async
).
with
(
'JobArtifactUploader'
,
described_class
.
name
,
:file
,
kind_of
(
Numeric
))
subject
subject
end
end
...
@@ -51,7 +51,7 @@ describe Ci::JobArtifact do
...
@@ -51,7 +51,7 @@ describe Ci::JobArtifact do
end
end
it
'does not schedule the migration'
do
it
'does not schedule the migration'
do
expect
(
ObjectStorage
::
Background
Upload
Worker
).
not_to
receive
(
:perform_async
)
expect
(
ObjectStorage
::
Background
Move
Worker
).
not_to
receive
(
:perform_async
)
subject
subject
end
end
...
@@ -64,7 +64,7 @@ describe Ci::JobArtifact do
...
@@ -64,7 +64,7 @@ describe Ci::JobArtifact do
end
end
it
'schedules the model for migration'
do
it
'schedules the model for migration'
do
expect
(
ObjectStorage
::
Background
Upload
Worker
).
not_to
receive
(
:perform_async
)
expect
(
ObjectStorage
::
Background
Move
Worker
).
not_to
receive
(
:perform_async
)
subject
subject
end
end
...
...
spec/requests/lfs_http_spec.rb
View file @
cbd09793
...
@@ -1030,7 +1030,7 @@ describe 'Git LFS API and storage' do
...
@@ -1030,7 +1030,7 @@ describe 'Git LFS API and storage' do
context
'with object storage disabled'
do
context
'with object storage disabled'
do
it
"doesn't attempt to migrate file to object storage"
do
it
"doesn't attempt to migrate file to object storage"
do
expect
(
ObjectStorage
::
Background
Upload
Worker
).
not_to
receive
(
:perform_async
)
expect
(
ObjectStorage
::
Background
Move
Worker
).
not_to
receive
(
:perform_async
)
put_finalize
(
with_tempfile:
true
)
put_finalize
(
with_tempfile:
true
)
end
end
...
@@ -1042,7 +1042,7 @@ describe 'Git LFS API and storage' do
...
@@ -1042,7 +1042,7 @@ describe 'Git LFS API and storage' do
end
end
it
'schedules migration of file to object storage'
do
it
'schedules migration of file to object storage'
do
expect
(
ObjectStorage
::
Background
Upload
Worker
).
to
receive
(
:perform_async
).
with
(
'LfsObjectUploader'
,
'LfsObject'
,
:file
,
kind_of
(
Numeric
))
expect
(
ObjectStorage
::
Background
Move
Worker
).
to
receive
(
:perform_async
).
with
(
'LfsObjectUploader'
,
'LfsObject'
,
:file
,
kind_of
(
Numeric
))
put_finalize
(
with_tempfile:
true
)
put_finalize
(
with_tempfile:
true
)
end
end
...
...
spec/uploaders/lfs_object_uploader_spec.rb
View file @
cbd09793
...
@@ -26,7 +26,7 @@ describe LfsObjectUploader do
...
@@ -26,7 +26,7 @@ describe LfsObjectUploader do
describe
'migration to object storage'
do
describe
'migration to object storage'
do
context
'with object storage disabled'
do
context
'with object storage disabled'
do
it
"is skipped"
do
it
"is skipped"
do
expect
(
ObjectStorage
::
Background
Upload
Worker
).
not_to
receive
(
:perform_async
)
expect
(
ObjectStorage
::
Background
Move
Worker
).
not_to
receive
(
:perform_async
)
lfs_object
lfs_object
end
end
...
@@ -38,7 +38,7 @@ describe LfsObjectUploader do
...
@@ -38,7 +38,7 @@ describe LfsObjectUploader do
end
end
it
'is scheduled to run after creation'
do
it
'is scheduled to run after creation'
do
expect
(
ObjectStorage
::
Background
Upload
Worker
).
to
receive
(
:perform_async
).
with
(
described_class
.
name
,
'LfsObject'
,
:file
,
kind_of
(
Numeric
))
expect
(
ObjectStorage
::
Background
Move
Worker
).
to
receive
(
:perform_async
).
with
(
described_class
.
name
,
'LfsObject'
,
:file
,
kind_of
(
Numeric
))
lfs_object
lfs_object
end
end
...
@@ -50,7 +50,7 @@ describe LfsObjectUploader do
...
@@ -50,7 +50,7 @@ describe LfsObjectUploader do
end
end
it
'is skipped'
do
it
'is skipped'
do
expect
(
ObjectStorage
::
Background
Upload
Worker
).
not_to
receive
(
:perform_async
)
expect
(
ObjectStorage
::
Background
Move
Worker
).
not_to
receive
(
:perform_async
)
lfs_object
lfs_object
end
end
...
@@ -67,7 +67,7 @@ describe LfsObjectUploader do
...
@@ -67,7 +67,7 @@ describe LfsObjectUploader do
end
end
it
'can store file remotely'
do
it
'can store file remotely'
do
allow
(
ObjectStorage
::
Background
Upload
Worker
).
to
receive
(
:perform_async
)
allow
(
ObjectStorage
::
Background
Move
Worker
).
to
receive
(
:perform_async
)
store_file
(
lfs_object
)
store_file
(
lfs_object
)
...
...
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