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
69a35280
Commit
69a35280
authored
Jul 26, 2017
by
Douglas Barbosa Alexandre
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Add group restrictions to Geo::FileDownloadDispatchWorker
parent
8fb5da12
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
75 additions
and
18 deletions
+75
-18
app/workers/geo/file_download_dispatch_worker.rb
app/workers/geo/file_download_dispatch_worker.rb
+35
-14
spec/workers/geo/file_download_dispatch_worker_spec.rb
spec/workers/geo/file_download_dispatch_worker_spec.rb
+40
-4
No files found.
app/workers/geo/file_download_dispatch_worker.rb
View file @
69a35280
...
@@ -9,30 +9,51 @@ module Geo
...
@@ -9,30 +9,51 @@ module Geo
end
end
def
load_pending_resources
def
load_pending_resources
lfs_object_ids
=
find_lfs_object_ids
(
db_retrieve_batch_size
)
restricted_project_ids
=
Gitlab
::
Geo
.
current_node
.
project_ids
objects_ids
=
find_object_ids
(
db_retrieve_batch_size
)
lfs_object_ids
=
find_lfs_object_ids
(
restricted_project_ids
)
objects_ids
=
find_object_ids
(
restricted_project_ids
)
interleave
(
lfs_object_ids
,
objects_ids
)
interleave
(
lfs_object_ids
,
objects_ids
)
end
end
def
find_object_ids
(
limit
)
def
find_object_ids
(
restricted_project_ids
)
downloaded_ids
=
find_downloaded_ids
([
:attachment
,
:avatar
,
:file
])
downloaded_ids
=
find_downloaded_ids
([
:attachment
,
:avatar
,
:file
])
Upload
.
where
.
not
(
id:
downloaded_ids
)
relation
=
.
order
(
created_at: :desc
)
if
restricted_project_ids
.
limit
(
limit
)
uploads_table
=
Upload
.
arel_table
.
pluck
(
:id
,
:uploader
)
group_uploads
=
uploads_table
[
:model_type
].
eq
(
'Namespace'
).
and
(
uploads_table
[
:model_id
].
in
(
Gitlab
::
Geo
.
current_node
.
group_ids
))
.
map
{
|
id
,
uploader
|
[
id
,
uploader
.
sub
(
/Uploader\z/
,
''
).
downcase
]
}
project_uploads
=
uploads_table
[
:model_type
].
eq
(
'Project'
).
and
(
uploads_table
[
:model_id
].
in
(
restricted_project_ids
))
other_uploads
=
uploads_table
[
:model_type
].
not_in
(
%w[Namespace Project]
)
Upload
.
where
(
group_uploads
.
or
(
project_uploads
).
or
(
other_uploads
))
else
Upload
.
all
end
relation
.
where
.
not
(
id:
downloaded_ids
)
.
order
(
created_at: :desc
)
.
limit
(
db_retrieve_batch_size
)
.
pluck
(
:id
,
:uploader
)
.
map
{
|
id
,
uploader
|
[
id
,
uploader
.
sub
(
/Uploader\z/
,
''
).
downcase
]
}
end
end
def
find_lfs_object_ids
(
limit
)
def
find_lfs_object_ids
(
restricted_project_ids
)
downloaded_ids
=
find_downloaded_ids
([
:lfs
])
downloaded_ids
=
find_downloaded_ids
([
:lfs
])
LfsObject
.
where
.
not
(
id:
downloaded_ids
)
relation
=
.
order
(
created_at: :desc
)
if
restricted_project_ids
.
limit
(
limit
)
LfsObject
.
joins
(
:projects
).
where
(
projects:
{
id:
restricted_project_ids
})
.
pluck
(
:id
)
else
.
map
{
|
id
|
[
id
,
:lfs
]
}
LfsObject
.
all
end
relation
.
where
.
not
(
id:
downloaded_ids
)
.
order
(
created_at: :desc
)
.
limit
(
db_retrieve_batch_size
)
.
pluck
(
:id
)
.
map
{
|
id
|
[
id
,
:lfs
]
}
end
end
def
find_downloaded_ids
(
file_types
)
def
find_downloaded_ids
(
file_types
)
...
...
spec/workers/geo/file_download_dispatch_worker_spec.rb
View file @
69a35280
require
'spec_helper'
require
'spec_helper'
describe
Geo
::
FileDownloadDispatchWorker
do
describe
Geo
::
FileDownloadDispatchWorker
do
let!
(
:primary
)
{
create
(
:geo_node
,
:primary
,
host:
'primary-geo-node'
)
}
let!
(
:secondary
)
{
create
(
:geo_node
,
:current
)
}
before
do
before
do
@primary
=
create
(
:geo_node
,
:primary
,
host:
'primary-geo-node'
)
@secondary
=
create
(
:geo_node
,
:current
)
allow
(
Gitlab
::
Geo
).
to
receive
(
:secondary?
).
and_return
(
true
)
allow
(
Gitlab
::
Geo
).
to
receive
(
:secondary?
).
and_return
(
true
)
allow_any_instance_of
(
Gitlab
::
ExclusiveLease
)
allow_any_instance_of
(
Gitlab
::
ExclusiveLease
)
.
to
receive
(
:try_obtain
).
and_return
(
true
)
.
to
receive
(
:try_obtain
).
and_return
(
true
)
...
@@ -28,8 +29,8 @@ describe Geo::FileDownloadDispatchWorker do
...
@@ -28,8 +29,8 @@ describe Geo::FileDownloadDispatchWorker do
it
'does not schedule anything when node is disabled'
do
it
'does not schedule anything when node is disabled'
do
create
(
:lfs_object
,
:with_file
)
create
(
:lfs_object
,
:with_file
)
@
secondary
.
enabled
=
false
secondary
.
enabled
=
false
@
secondary
.
save
secondary
.
save
expect
(
GeoFileDownloadWorker
).
not_to
receive
(
:perform_async
)
expect
(
GeoFileDownloadWorker
).
not_to
receive
(
:perform_async
)
...
@@ -73,5 +74,40 @@ describe Geo::FileDownloadDispatchWorker do
...
@@ -73,5 +74,40 @@ describe Geo::FileDownloadDispatchWorker do
subject
.
perform
subject
.
perform
end
end
end
end
context
'when node have group restrictions'
do
let
(
:group_1
)
{
create
(
:group
)
}
let!
(
:project_1
)
{
create
(
:empty_project
,
group:
group_1
)
}
let!
(
:project_2
)
{
create
(
:empty_project
)
}
before
do
allow
(
ProjectCacheWorker
).
to
receive
(
:perform_async
).
and_return
(
true
)
allow_any_instance_of
(
described_class
).
to
receive
(
:over_time?
).
and_return
(
false
)
secondary
.
update_attribute
(
:groups
,
[
group_1
])
end
it
'does not perform GeoFileDownloadWorker for LFS object that do not belong to selected groups to replicate'
do
create
(
:lfs_objects_project
,
project:
project_1
)
create
(
:lfs_objects_project
,
project:
project_2
)
expect
(
GeoFileDownloadWorker
).
to
receive
(
:perform_async
).
once
.
and_return
(
spy
)
subject
.
perform
end
it
'does not perform GeoFileDownloadWorker for upload objects that do not belong to selected groups to replicate'
do
avatar
=
fixture_file_upload
(
Rails
.
root
.
join
(
'spec/fixtures/dk.png'
))
create
(
:upload
,
model:
group_1
,
path:
avatar
)
create
(
:upload
,
model:
create
(
:group
),
path:
avatar
)
create
(
:upload
,
model:
project_1
,
path:
avatar
)
create
(
:upload
,
model:
project_2
,
path:
avatar
)
create
(
:note
,
:with_attachment
)
expect
(
GeoFileDownloadWorker
).
to
receive
(
:perform_async
).
exactly
(
3
).
times
.
and_return
(
spy
)
subject
.
perform
end
end
end
end
end
end
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