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
37b623b0
Commit
37b623b0
authored
Oct 06, 2017
by
Stan Hu
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Fix personal snippet attachments not downloading in Geo secondaries
Closes #3644
parent
8026bb93
Changes
6
Show whitespace changes
Inline
Side-by-side
Showing
6 changed files
with
35 additions
and
8 deletions
+35
-8
app/services/geo/file_service.rb
app/services/geo/file_service.rb
+1
-1
app/workers/geo/file_download_dispatch_worker.rb
app/workers/geo/file_download_dispatch_worker.rb
+2
-2
changelogs/unreleased-ee/sh-geo-fix-snippet-downloads.yml
changelogs/unreleased-ee/sh-geo-fix-snippet-downloads.yml
+5
-0
spec/factories/uploads.rb
spec/factories/uploads.rb
+5
-0
spec/services/geo/file_download_service_spec.rb
spec/services/geo/file_download_service_spec.rb
+15
-0
spec/workers/geo/file_download_dispatch_worker_spec.rb
spec/workers/geo/file_download_dispatch_worker_spec.rb
+7
-5
No files found.
app/services/geo/file_service.rb
View file @
37b623b0
...
@@ -2,7 +2,7 @@ module Geo
...
@@ -2,7 +2,7 @@ module Geo
class
FileService
class
FileService
attr_reader
:object_type
,
:object_db_id
attr_reader
:object_type
,
:object_db_id
DEFAULT_OBJECT_TYPES
=
%w[attachment avatar file]
.
freeze
DEFAULT_OBJECT_TYPES
=
%w[attachment avatar file
personal_file
]
.
freeze
DEFAULT_SERVICE_TYPE
=
'file'
.
freeze
DEFAULT_SERVICE_TYPE
=
'file'
.
freeze
def
initialize
(
object_type
,
object_db_id
)
def
initialize
(
object_type
,
object_db_id
)
...
...
app/workers/geo/file_download_dispatch_worker.rb
View file @
37b623b0
...
@@ -16,7 +16,7 @@ module Geo
...
@@ -16,7 +16,7 @@ module Geo
end
end
def
find_object_ids
def
find_object_ids
downloaded_ids
=
find_downloaded_ids
(
[
:attachment
,
:avatar
,
:file
]
)
downloaded_ids
=
find_downloaded_ids
(
Geo
::
FileService
::
DEFAULT_OBJECT_TYPES
)
unsynched_downloads
=
filter_downloaded_ids
(
unsynched_downloads
=
filter_downloaded_ids
(
current_node
.
uploads
,
downloaded_ids
,
Upload
.
table_name
)
current_node
.
uploads
,
downloaded_ids
,
Upload
.
table_name
)
...
@@ -25,7 +25,7 @@ module Geo
...
@@ -25,7 +25,7 @@ module Geo
.
order
(
created_at: :desc
)
.
order
(
created_at: :desc
)
.
limit
(
db_retrieve_batch_size
)
.
limit
(
db_retrieve_batch_size
)
.
pluck
(
:id
,
:uploader
)
.
pluck
(
:id
,
:uploader
)
.
map
{
|
id
,
uploader
|
[
id
,
uploader
.
sub
(
/Uploader\z/
,
''
).
downcas
e
]
}
.
map
{
|
id
,
uploader
|
[
id
,
uploader
.
sub
(
/Uploader\z/
,
''
).
underscor
e
]
}
end
end
def
find_lfs_object_ids
def
find_lfs_object_ids
...
...
changelogs/unreleased-ee/sh-geo-fix-snippet-downloads.yml
0 → 100644
View file @
37b623b0
---
title
:
Fix personal snippets not downloading in Geo secondaries
merge_request
:
author
:
type
:
fixed
spec/factories/uploads.rb
View file @
37b623b0
...
@@ -4,5 +4,10 @@ FactoryGirl.define do
...
@@ -4,5 +4,10 @@ FactoryGirl.define do
path
{
"uploads/-/system/project/avatar/avatar.jpg"
}
path
{
"uploads/-/system/project/avatar/avatar.jpg"
}
size
100
.
kilobytes
size
100
.
kilobytes
uploader
"AvatarUploader"
uploader
"AvatarUploader"
trait
:personal_snippet
do
model
{
build
(
:personal_snippet
)
}
uploader
"PersonalFileUploader"
end
end
end
end
end
spec/services/geo/file_download_service_spec.rb
View file @
37b623b0
...
@@ -75,6 +75,21 @@ describe Geo::FileDownloadService do
...
@@ -75,6 +75,21 @@ describe Geo::FileDownloadService do
end
end
end
end
context
'with a snippet'
do
let
(
:upload
)
{
create
(
:upload
,
:personal_snippet
)
}
subject
{
described_class
.
new
(
:personal_file
,
upload
.
id
)
}
it
'downloads the file'
do
allow_any_instance_of
(
Gitlab
::
ExclusiveLease
)
.
to
receive
(
:try_obtain
).
and_return
(
true
)
allow_any_instance_of
(
Gitlab
::
Geo
::
FileTransfer
)
.
to
receive
(
:download_from_primary
).
and_return
(
100
)
expect
{
subject
.
execute
}.
to
change
{
Geo
::
FileRegistry
.
count
}.
by
(
1
)
end
end
context
'with file upload'
do
context
'with file upload'
do
let
(
:project
)
{
create
(
:project
)
}
let
(
:project
)
{
create
(
:project
)
}
let
(
:upload
)
{
Upload
.
find_by
(
model:
project
,
uploader:
'FileUploader'
)
}
let
(
:upload
)
{
Upload
.
find_by
(
model:
project
,
uploader:
'FileUploader'
)
}
...
...
spec/workers/geo/file_download_dispatch_worker_spec.rb
View file @
37b623b0
...
@@ -57,7 +57,7 @@ describe Geo::FileDownloadDispatchWorker, :postgresql do
...
@@ -57,7 +57,7 @@ describe Geo::FileDownloadDispatchWorker, :postgresql do
# Test the case where we have:
# Test the case where we have:
#
#
# 1. A total of
8
files in the queue, and we can load a maximimum of 5 and send 2 at a time.
# 1. A total of
10
files in the queue, and we can load a maximimum of 5 and send 2 at a time.
# 2. We send 2, wait for 1 to finish, and then send again.
# 2. We send 2, wait for 1 to finish, and then send again.
it
'attempts to load a new batch without pending downloads'
do
it
'attempts to load a new batch without pending downloads'
do
stub_const
(
'Geo::BaseSchedulerWorker::DB_RETRIEVE_BATCH_SIZE'
,
5
)
stub_const
(
'Geo::BaseSchedulerWorker::DB_RETRIEVE_BATCH_SIZE'
,
5
)
...
@@ -67,15 +67,17 @@ describe Geo::FileDownloadDispatchWorker, :postgresql do
...
@@ -67,15 +67,17 @@ describe Geo::FileDownloadDispatchWorker, :postgresql do
create_list
(
:lfs_object
,
2
,
:with_file
)
create_list
(
:lfs_object
,
2
,
:with_file
)
create_list
(
:user
,
2
,
avatar:
avatar
)
create_list
(
:user
,
2
,
avatar:
avatar
)
create_list
(
:note
,
2
,
:with_attachment
)
create_list
(
:note
,
2
,
:with_attachment
)
create_list
(
:upload
,
2
,
:personal_snippet
)
create
(
:appearance
,
logo:
avatar
,
header_logo:
avatar
)
create
(
:appearance
,
logo:
avatar
,
header_logo:
avatar
)
expect
(
GeoFileDownloadWorker
).
to
receive
(
:perform_async
).
exactly
(
8
).
times
.
and_call_original
expect
(
GeoFileDownloadWorker
).
to
receive
(
:perform_async
).
exactly
(
10
).
times
.
and_call_original
# For
8 downloads, we expect three
database reloads:
# For
10 downloads, we expect four
database reloads:
# 1. Load the first batch of 5.
# 1. Load the first batch of 5.
# 2. 4 get sent out, 1 remains. This triggers another reload, which loads in the remaining 4.
# 2. 4 get sent out, 1 remains. This triggers another reload, which loads in the next 5.
# 3. Those 4 get sent out, and 1 remains.
# 3. Since the second reload filled the pipe with 4, we need to do a final reload to ensure
# 3. Since the second reload filled the pipe with 4, we need to do a final reload to ensure
# zero are left.
# zero are left.
expect
(
subject
).
to
receive
(
:load_pending_resources
).
exactly
(
3
).
times
.
and_call_original
expect
(
subject
).
to
receive
(
:load_pending_resources
).
exactly
(
4
).
times
.
and_call_original
Sidekiq
::
Testing
.
inline!
do
Sidekiq
::
Testing
.
inline!
do
subject
.
perform
subject
.
perform
...
...
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