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
35315cdd
Commit
35315cdd
authored
Jul 03, 2020
by
Valery Sizov
Committed by
Michael Kozono
Jul 03, 2020
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Geo: Replicate delete event of Package Files
Implements replication of delete events for Self-Service framework
parent
8dd8e6ad
Changes
4
Show whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
71 additions
and
3 deletions
+71
-3
ee/app/models/concerns/geo/blob_replicator_strategy.rb
ee/app/models/concerns/geo/blob_replicator_strategy.rb
+31
-0
ee/lib/gitlab/geo/replicable_model.rb
ee/lib/gitlab/geo/replicable_model.rb
+1
-0
ee/lib/gitlab/geo/replicator.rb
ee/lib/gitlab/geo/replicator.rb
+2
-2
ee/spec/support/shared_examples/models/concerns/blob_replicator_strategy_shared_examples.rb
...dels/concerns/blob_replicator_strategy_shared_examples.rb
+37
-1
No files found.
ee/app/models/concerns/geo/blob_replicator_strategy.rb
View file @
35315cdd
...
@@ -9,6 +9,7 @@ module Geo
...
@@ -9,6 +9,7 @@ module Geo
included
do
included
do
event
:created
event
:created
event
:deleted
end
end
def
handle_after_create_commit
def
handle_after_create_commit
...
@@ -26,6 +27,17 @@ module Geo
...
@@ -26,6 +27,17 @@ module Geo
download
download
end
end
def
handle_after_destroy
publish
(
:deleted
,
**
deleted_params
)
end
# Called by Gitlab::Geo::Replicator#consume
def
consume_event_deleted
(
**
params
)
return
if
excluded_by_selective_sync?
replicate_destroy
(
params
)
end
# Return the carrierwave uploader instance scoped to current model
# Return the carrierwave uploader instance scoped to current model
#
#
# @abstract
# @abstract
...
@@ -34,6 +46,13 @@ module Geo
...
@@ -34,6 +46,13 @@ module Geo
raise
NotImplementedError
raise
NotImplementedError
end
end
# Return the absolute path to locally stored package file
#
# @return [String] File path
def
blob_path
carrierwave_uploader
.
class
.
absolute_path
(
carrierwave_uploader
)
end
def
calculate_checksum!
def
calculate_checksum!
checksum
=
model_record
.
calculate_checksum!
checksum
=
model_record
.
calculate_checksum!
update_verification_state!
(
checksum:
checksum
)
update_verification_state!
(
checksum:
checksum
)
...
@@ -77,6 +96,14 @@ module Geo
...
@@ -77,6 +96,14 @@ module Geo
::
Geo
::
BlobDownloadService
.
new
(
replicator:
self
).
execute
::
Geo
::
BlobDownloadService
.
new
(
replicator:
self
).
execute
end
end
def
replicate_destroy
(
event_data
)
::
Geo
::
FileRegistryRemovalService
.
new
(
replicable_name
,
model_record
.
id
,
event_data
[
:blob_path
]
).
execute
end
def
schedule_checksum_calculation
def
schedule_checksum_calculation
Geo
::
BlobVerificationPrimaryWorker
.
perform_async
(
replicable_name
,
model_record
.
id
)
Geo
::
BlobVerificationPrimaryWorker
.
perform_async
(
replicable_name
,
model_record
.
id
)
end
end
...
@@ -85,6 +112,10 @@ module Geo
...
@@ -85,6 +112,10 @@ module Geo
{
model_record_id:
model_record
.
id
}
{
model_record_id:
model_record
.
id
}
end
end
def
deleted_params
{
model_record_id:
model_record
.
id
,
blob_path:
blob_path
}
end
def
needs_checksum?
def
needs_checksum?
return
true
unless
model_record
.
respond_to?
(
:needs_checksum?
)
return
true
unless
model_record
.
respond_to?
(
:needs_checksum?
)
...
...
ee/lib/gitlab/geo/replicable_model.rb
View file @
35315cdd
...
@@ -10,6 +10,7 @@ module Gitlab
...
@@ -10,6 +10,7 @@ module Gitlab
included
do
included
do
# If this hook turns out not to apply to all Models, perhaps we should extract a `ReplicableBlobModel`
# If this hook turns out not to apply to all Models, perhaps we should extract a `ReplicableBlobModel`
after_create_commit
->
{
replicator
.
handle_after_create_commit
if
replicator
.
respond_to?
(
:handle_after_create_commit
)
}
after_create_commit
->
{
replicator
.
handle_after_create_commit
if
replicator
.
respond_to?
(
:handle_after_create_commit
)
}
after_destroy
->
{
replicator
.
handle_after_destroy
if
replicator
.
respond_to?
(
:handle_after_destroy
)
}
scope
:checksummed
,
->
{
where
(
'verification_checksum IS NOT NULL'
)
}
scope
:checksummed
,
->
{
where
(
'verification_checksum IS NOT NULL'
)
}
scope
:checksum_failed
,
->
{
where
(
'verification_failure IS NOT NULL'
)
}
scope
:checksum_failed
,
->
{
where
(
'verification_failure IS NOT NULL'
)
}
...
...
ee/lib/gitlab/geo/replicator.rb
View file @
35315cdd
...
@@ -28,8 +28,8 @@ module Gitlab
...
@@ -28,8 +28,8 @@ module Gitlab
#
#
# @example Declaring support for :update and :delete events
# @example Declaring support for :update and :delete events
# class MyReplicator < Gitlab::Geo::Replicator
# class MyReplicator < Gitlab::Geo::Replicator
# event :update
# event :update
d
# event :delete
# event :delete
d
# end
# end
#
#
# @param [Symbol] event_name
# @param [Symbol] event_name
...
...
ee/spec/support/shared_examples/models/concerns/blob_replicator_strategy_shared_examples.rb
View file @
35315cdd
...
@@ -47,6 +47,17 @@ RSpec.shared_examples 'a blob replicator' do
...
@@ -47,6 +47,17 @@ RSpec.shared_examples 'a blob replicator' do
end
end
end
end
describe
'#handle_after_destroy'
do
it
'creates a Geo::Event'
do
expect
do
replicator
.
handle_after_destroy
end
.
to
change
{
::
Geo
::
Event
.
count
}.
by
(
1
)
expect
(
::
Geo
::
Event
.
last
.
attributes
).
to
include
(
"replicable_name"
=>
replicator
.
replicable_name
,
"event_name"
=>
"deleted"
,
"payload"
=>
{
"model_record_id"
=>
replicator
.
model_record
.
id
,
"blob_path"
=>
replicator
.
blob_path
})
end
end
describe
'#calculate_checksum!'
do
describe
'#calculate_checksum!'
do
it
'calculates the checksum'
do
it
'calculates the checksum'
do
model_record
.
save!
model_record
.
save!
...
@@ -71,7 +82,7 @@ RSpec.shared_examples 'a blob replicator' do
...
@@ -71,7 +82,7 @@ RSpec.shared_examples 'a blob replicator' do
end
end
end
end
describe
'#consume_
created_event
'
do
describe
'#consume_
event_created
'
do
context
"when the blob's project is not excluded by selective sync"
do
context
"when the blob's project is not excluded by selective sync"
do
it
'invokes Geo::BlobDownloadService'
do
it
'invokes Geo::BlobDownloadService'
do
expect
(
replicator
).
to
receive
(
:excluded_by_selective_sync?
).
and_return
(
false
)
expect
(
replicator
).
to
receive
(
:excluded_by_selective_sync?
).
and_return
(
false
)
...
@@ -95,6 +106,31 @@ RSpec.shared_examples 'a blob replicator' do
...
@@ -95,6 +106,31 @@ RSpec.shared_examples 'a blob replicator' do
end
end
end
end
describe
'#consume_event_deleted'
do
context
"when the blob's project is not excluded by selective sync"
do
it
'invokes Geo::FileRegistryRemovalService'
do
expect
(
replicator
).
to
receive
(
:excluded_by_selective_sync?
).
and_return
(
false
)
service
=
double
(
:service
)
expect
(
service
).
to
receive
(
:execute
)
expect
(
::
Geo
::
FileRegistryRemovalService
)
.
to
receive
(
:new
).
with
(
replicator
.
replicable_name
,
replicator
.
model_record_id
,
'blob_path'
).
and_return
(
service
)
replicator
.
consume_event_deleted
({
blob_path:
'blob_path'
})
end
end
context
"when the blob's project is excluded by selective sync"
do
it
'does not invoke Geo::FileRegistryRemovalService'
do
expect
(
replicator
).
to
receive
(
:excluded_by_selective_sync?
).
and_return
(
true
)
expect
(
::
Geo
::
FileRegistryRemovalService
).
not_to
receive
(
:new
)
replicator
.
consume_event_deleted
({
blob_path:
''
})
end
end
end
describe
'#carrierwave_uploader'
do
describe
'#carrierwave_uploader'
do
it
'is implemented'
do
it
'is implemented'
do
expect
do
expect
do
...
...
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