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
a6e469f9
Commit
a6e469f9
authored
Nov 22, 2018
by
Douglas Barbosa Alexandre
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Handle projects that needs re-verification
parent
c3e3b171
Changes
3
Show whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
56 additions
and
3 deletions
+56
-3
ee/app/workers/geo/repository_verification/primary/shard_worker.rb
...rkers/geo/repository_verification/primary/shard_worker.rb
+26
-1
ee/spec/factories/geo_nodes.rb
ee/spec/factories/geo_nodes.rb
+2
-0
ee/spec/workers/geo/repository_verification/primary/shard_worker_spec.rb
.../geo/repository_verification/primary/shard_worker_spec.rb
+28
-2
No files found.
ee/app/workers/geo/repository_verification/primary/shard_worker.rb
View file @
a6e469f9
...
...
@@ -52,7 +52,7 @@ module Geo
remaining_capacity
=
db_retrieve_batch_size
-
resources
.
size
return
resources
if
remaining_capacity
.
zero?
resources
+
find_
failed_project_ids
(
batch_size:
remaining_capacity
)
resources
+
find_
project_ids_to_reverify
(
batch_size:
remaining_capacity
)
end
# rubocop: disable CodeReuse/ActiveRecord
...
...
@@ -67,6 +67,13 @@ module Geo
end
# rubocop: enable CodeReuse/ActiveRecord
def
find_project_ids_to_reverify
(
batch_size
:)
failed_project_ids
=
find_failed_project_ids
(
batch_size:
batch_size
)
reverifiable_project_ids
=
find_reverifiable_projects_ids
(
batch_size:
batch_size
)
take_batch
(
failed_project_ids
,
reverifiable_project_ids
,
batch_size:
batch_size
)
end
def
find_failed_project_ids
(
batch_size
:)
repositories_ids
=
find_failed_repositories_ids
(
batch_size:
batch_size
)
wiki_ids
=
find_failed_wiki_ids
(
batch_size:
batch_size
)
...
...
@@ -85,6 +92,24 @@ module Geo
finder
.
find_failed_wikis
(
batch_size:
batch_size
).
pluck
(
:id
)
end
# rubocop: enable CodeReuse/ActiveRecord
# rubocop: disable CodeReuse/ActiveRecord
def
find_reverifiable_projects_ids
(
batch_size
:)
return
[]
unless
reverification_enabled?
jitter
=
(
minimum_reverification_interval
.
seconds
*
rand
(
15
))
/
100
interval
=
minimum_reverification_interval
.
ago
+
jitter
.
seconds
repository_ids
=
finder
.
find_reverifiable_repositories
(
interval:
interval
,
batch_size:
batch_size
).
pluck
(
:id
)
wiki_ids
=
finder
.
find_reverifiable_wikis
(
interval:
interval
,
batch_size:
batch_size
).
pluck
(
:id
)
take_batch
(
repository_ids
,
wiki_ids
,
batch_size:
batch_size
)
end
# rubocop: enable CodeReuse/ActiveRecord
def
minimum_reverification_interval
::
Gitlab
::
Geo
.
current_node
.
minimum_reverification_interval
.
days
end
end
end
end
...
...
ee/spec/factories/geo_nodes.rb
View file @
a6e469f9
...
...
@@ -12,6 +12,8 @@ FactoryBot.define do
trait
:primary
do
primary
true
minimum_reverification_interval
7
url
do
uri
=
URI
.
parse
(
"http://
#{
Gitlab
.
config
.
gitlab
.
host
}
:
#{
Gitlab
.
config
.
gitlab
.
relative_url_root
}
"
)
uri
.
port
=
Gitlab
.
config
.
gitlab
.
port
...
...
ee/spec/workers/geo/repository_verification/primary/shard_worker_spec.rb
View file @
a6e469f9
...
...
@@ -91,6 +91,28 @@ describe Geo::RepositoryVerification::Primary::ShardWorker, :postgresql, :clean_
subject
.
perform
(
shard_name
)
end
it
'performs Geo::RepositoryVerification::Primary::SingleWorker for projects where repository should be reverified'
do
project_to_be_reverified
=
create
(
:project
)
create
(
:repository_state
,
:repository_verified
,
:wiki_verified
,
project:
project_to_be_reverified
,
last_repository_verification_ran_at:
10
.
days
.
ago
)
expect
(
primary_singleworker
).
to
receive
(
:perform_async
).
with
(
project_to_be_reverified
.
id
)
subject
.
perform
(
shard_name
)
end
it
'performs Geo::RepositoryVerification::Primary::SingleWorker for projects where wiki should be reverified'
do
project_to_be_reverified
=
create
(
:project
)
create
(
:repository_state
,
:repository_verified
,
:wiki_verified
,
project:
project_to_be_reverified
,
last_wiki_verification_ran_at:
10
.
days
.
ago
)
expect
(
primary_singleworker
).
to
receive
(
:perform_async
).
with
(
project_to_be_reverified
.
id
)
subject
.
perform
(
shard_name
)
end
it
'does not perform Geo::RepositoryVerification::Primary::SingleWorker when shard becomes unhealthy'
do
create
(
:project
)
...
...
@@ -172,6 +194,8 @@ describe Geo::RepositoryVerification::Primary::ShardWorker, :postgresql, :clean_
let
(
:project_wiki_unverified
)
{
create
(
:repository_state
).
project
}
let
(
:project_repo_failed_wiki_verified
)
{
create
(
:repository_state
,
:repository_failed
,
:wiki_verified
).
project
}
let
(
:project_repo_verified_wiki_failed
)
{
create
(
:repository_state
,
:repository_verified
,
:wiki_failed
).
project
}
let
(
:project_repo_reverify
)
{
create
(
:repository_state
,
:repository_verified
,
:wiki_verified
,
last_repository_verification_ran_at:
10
.
days
.
ago
).
project
}
let
(
:project_wiki_reverify
)
{
create
(
:repository_state
,
:repository_verified
,
:wiki_verified
,
last_wiki_verification_ran_at:
10
.
days
.
ago
).
project
}
it
'handles multiple batches of projects needing verification'
do
expect
(
primary_singleworker
).
to
receive
(
:perform_async
).
with
(
project_repo_unverified
.
id
).
once
.
and_call_original
...
...
@@ -182,7 +206,7 @@ describe Geo::RepositoryVerification::Primary::ShardWorker, :postgresql, :clean_
end
end
it
'handles multiple batches of projects needing verification
, including failed repos
'
do
it
'handles multiple batches of projects needing verification'
do
expect
(
primary_singleworker
).
to
receive
(
:perform_async
).
with
(
project_repo_unverified
.
id
).
once
.
and_call_original
expect
(
primary_singleworker
).
to
receive
(
:perform_async
).
with
(
project_wiki_unverified
.
id
).
once
.
and_call_original
expect
(
primary_singleworker
).
to
receive
(
:perform_async
).
with
(
project_repo_verified
.
id
).
once
.
and_call_original
...
...
@@ -190,8 +214,10 @@ describe Geo::RepositoryVerification::Primary::ShardWorker, :postgresql, :clean_
expect
(
primary_singleworker
).
to
receive
(
:perform_async
).
with
(
project_both_failed
.
id
).
once
.
and_call_original
expect
(
primary_singleworker
).
to
receive
(
:perform_async
).
with
(
project_repo_failed_wiki_verified
.
id
).
once
.
and_call_original
expect
(
primary_singleworker
).
to
receive
(
:perform_async
).
with
(
project_repo_verified_wiki_failed
.
id
).
once
.
and_call_original
expect
(
primary_singleworker
).
to
receive
(
:perform_async
).
with
(
project_repo_reverify
.
id
).
once
.
and_call_original
expect
(
primary_singleworker
).
to
receive
(
:perform_async
).
with
(
project_wiki_reverify
.
id
).
once
.
and_call_original
8
.
times
do
10
.
times
do
Sidekiq
::
Testing
.
inline!
{
subject
.
perform
(
shard_name
)
}
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