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
acd9bc83
Commit
acd9bc83
authored
Mar 09, 2017
by
Tiago Botelho
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
adds more options to global minimum mirror sync time
parent
f2f5cb67
Changes
7
Hide whitespace changes
Inline
Side-by-side
Showing
7 changed files
with
382 additions
and
215 deletions
+382
-215
lib/gitlab/mirror.rb
lib/gitlab/mirror.rb
+22
-7
spec/features/projects/mirror_spec.rb
spec/features/projects/mirror_spec.rb
+11
-33
spec/lib/gitlab/mirror_spec.rb
spec/lib/gitlab/mirror_spec.rb
+190
-27
spec/models/application_setting_spec.rb
spec/models/application_setting_spec.rb
+18
-32
spec/workers/update_all_mirrors_worker_spec.rb
spec/workers/update_all_mirrors_worker_spec.rb
+59
-47
spec/workers/update_all_remote_mirrors_worker.rb
spec/workers/update_all_remote_mirrors_worker.rb
+0
-69
spec/workers/update_all_remote_mirrors_worker_spec.rb
spec/workers/update_all_remote_mirrors_worker_spec.rb
+82
-0
No files found.
lib/gitlab/mirror.rb
View file @
acd9bc83
...
...
@@ -4,26 +4,38 @@ module Gitlab
FIFTEEN
=
15
HOURLY
=
60
DAILY
=
1440
THREE
=
180
SIX
=
360
TWELVE
=
720
DAILY
=
1440
INTERVAL_BEFORE_FIFTEEN
=
14
.
minutes
SYNC_TIME_TO_CRON
=
{
FIFTEEN
=>
"*/15 * * * *"
,
HOURLY
=>
"0 * * * *"
,
DAILY
=>
"0 0 * * *"
THREE
=>
"0 */3 * * *"
,
SIX
=>
"0 */6 * * *"
,
TWELVE
=>
"0 */12 * * *"
,
DAILY
=>
"0 0 * * *"
,
}.
freeze
SYNC_TIME_OPTIONS
=
{
"Update every 15 minutes"
=>
FIFTEEN
,
"Update hourly"
=>
HOURLY
,
"Update every day"
=>
DAILY
,
"Update every 15 minutes"
=>
FIFTEEN
,
"Update hourly"
=>
HOURLY
,
"Update every three hours"
=>
THREE
,
"Update every six hours"
=>
SIX
,
"Update every twelve hours"
=>
TWELVE
,
"Update every day"
=>
DAILY
,
}.
freeze
class
<<
self
def
sync_times
sync_times
=
[
FIFTEEN
]
sync_times
<<
DAILY
if
at_beginning_of_day?
sync_times
<<
TWELVE
if
at_beginning_of_hour?
(
12
)
sync_times
<<
SIX
if
at_beginning_of_hour?
(
6
)
sync_times
<<
THREE
if
at_beginning_of_hour?
(
3
)
sync_times
<<
HOURLY
if
at_beginning_of_hour?
sync_times
...
...
@@ -59,11 +71,14 @@ module Gitlab
DateTime
.
now
.
between?
(
start_at
,
end_at
)
end
def
at_beginning_of_hour?
def
at_beginning_of_hour?
(
hour_mark
=
nil
)
start_at
=
DateTime
.
now
.
at_beginning_of_hour
end_at
=
start_at
+
INTERVAL_BEFORE_FIFTEEN
DateTime
.
now
.
between?
(
start_at
,
end_at
)
between_interval
=
DateTime
.
now
.
between?
(
start_at
,
end_at
)
return
between_interval
unless
hour_mark
between_interval
&&
DateTime
.
now
.
hour
%
hour_mark
==
0
end
end
end
...
...
spec/features/projects/mirror_spec.rb
View file @
acd9bc83
...
...
@@ -21,39 +21,17 @@ feature 'Project mirror', feature: true do
end
describe
'synchronization times'
do
describe
'daily minimum mirror sync_time'
do
before
do
stub_application_setting
(
minimum_mirror_sync_time:
Gitlab
::
Mirror
::
DAILY
)
visit
namespace_project_mirror_path
(
project
.
namespace
,
project
)
end
it
'shows the correct selector options'
do
expect
(
page
).
to
have_selector
(
'.project-mirror-sync-time > option'
,
count:
1
)
expect
(
page
).
to
have_selector
(
'.remote-mirror-sync-time > option'
,
count:
1
)
end
end
describe
'hourly minimum mirror sync_time'
do
before
do
stub_application_setting
(
minimum_mirror_sync_time:
Gitlab
::
Mirror
::
HOURLY
)
visit
namespace_project_mirror_path
(
project
.
namespace
,
project
)
end
it
'shows the correct selector options'
do
expect
(
page
).
to
have_selector
(
'.project-mirror-sync-time > option'
,
count:
2
)
expect
(
page
).
to
have_selector
(
'.remote-mirror-sync-time > option'
,
count:
2
)
end
end
describe
'fifteen minimum mirror sync_time'
do
before
do
stub_application_setting
(
minimum_mirror_sync_time:
Gitlab
::
Mirror
::
FIFTEEN
)
visit
namespace_project_mirror_path
(
project
.
namespace
,
project
)
end
it
'shows the correct selector options'
do
expect
(
page
).
to
have_selector
(
'.project-mirror-sync-time > option'
,
count:
3
)
expect
(
page
).
to
have_selector
(
'.remote-mirror-sync-time > option'
,
count:
3
)
Gitlab
::
Mirror
::
SYNC_TIME_TO_CRON
.
keys
.
reverse
.
each_with_index
do
|
sync_time
,
index
|
describe
"
#{
sync_time
}
minimum mirror sync time"
do
before
do
stub_application_setting
(
minimum_mirror_sync_time:
sync_time
)
visit
namespace_project_mirror_path
(
project
.
namespace
,
project
)
end
it
'shows the correct selector options'
do
expect
(
page
).
to
have_selector
(
'.project-mirror-sync-time > option'
,
count:
index
+
1
)
expect
(
page
).
to
have_selector
(
'.remote-mirror-sync-time > option'
,
count:
index
+
1
)
end
end
end
end
...
...
spec/lib/gitlab/mirror_spec.rb
View file @
acd9bc83
...
...
@@ -4,27 +4,67 @@ describe Gitlab::Mirror do
before
{
Sidekiq
::
Logging
.
logger
=
nil
}
describe
'#sync_times'
do
before
{
Timecop
.
freeze
(
DateTime
.
now
.
change
(
time
))
}
describe
'every fifteen minutes'
do
let!
(
:time
)
{
{
hour:
1
,
min:
15
}
}
it
'returns only fifteen minutes'
do
times
=
[
Gitlab
::
Mirror
::
FIFTEEN
]
expect
(
Gitlab
::
Mirror
.
sync_times
).
to
match_array
(
times
)
end
end
describe
'at beginning of hour'
do
before
{
Timecop
.
freeze
(
DateTime
.
now
.
at_beginning_of_hour
)
}
let!
(
:time
)
{
{
hour:
1
}
}
it
'returns only fifteen and hourly sync_times'
do
expect
(
Gitlab
::
Mirror
.
sync_times
).
to
contain_exactly
(
Gitlab
::
Mirror
::
FIFTEEN
,
Gitlab
::
Mirror
::
HOURLY
)
times
=
[
Gitlab
::
Mirror
::
FIFTEEN
,
Gitlab
::
Mirror
::
HOURLY
]
expect
(
Gitlab
::
Mirror
.
sync_times
).
to
match_array
(
times
)
end
end
describe
'at beginning of day'
do
before
{
Timecop
.
freeze
(
DateTime
.
now
.
at_beginning_of_day
)
}
describe
'at beginning of th hour'
do
describe
'three'
do
let!
(
:time
)
{
{
hour:
3
}
}
it
'returns daily hourly and fifteen sync_times'
do
expect
(
Gitlab
::
Mirror
.
sync_times
).
to
contain_exactly
(
Gitlab
::
Mirror
::
DAILY
,
Gitlab
::
Mirror
::
HOURLY
,
Gitlab
::
Mirror
::
FIFTEEN
)
it
'returns only fifteen hourly and three hour sync_times'
do
times
=
[
Gitlab
::
Mirror
::
FIFTEEN
,
Gitlab
::
Mirror
::
HOURLY
,
Gitlab
::
Mirror
::
THREE
]
expect
(
Gitlab
::
Mirror
.
sync_times
).
to
match_array
(
times
)
end
end
describe
'six'
do
let!
(
:time
)
{
{
hour:
6
}
}
it
'returns only fifteen, hourly, three and six hour sync_times'
do
times
=
[
Gitlab
::
Mirror
::
FIFTEEN
,
Gitlab
::
Mirror
::
HOURLY
,
Gitlab
::
Mirror
::
THREE
,
Gitlab
::
Mirror
::
SIX
]
expect
(
Gitlab
::
Mirror
.
sync_times
).
to
match_array
(
times
)
end
end
describe
'twelve'
do
let!
(
:time
)
{
{
hour:
12
}
}
it
'returns only fifteen, hourly, three, six and twelve hour sync_times'
do
times
=
[
Gitlab
::
Mirror
::
FIFTEEN
,
Gitlab
::
Mirror
::
HOURLY
,
Gitlab
::
Mirror
::
THREE
,
Gitlab
::
Mirror
::
SIX
,
Gitlab
::
Mirror
::
TWELVE
]
expect
(
Gitlab
::
Mirror
.
sync_times
).
to
match_array
(
times
)
end
end
end
describe
'
every fifteen minutes
'
do
before
{
Timecop
.
freeze
(
DateTime
.
now
.
at_beginning_of_hour
+
15
.
minutes
)
}
describe
'
at beginning of day
'
do
let!
(
:time
)
{
{
hour:
0
}
}
it
'returns only fifteen minutes'
do
expect
(
Gitlab
::
Mirror
.
sync_times
).
to
contain_exactly
(
Gitlab
::
Mirror
::
FIFTEEN
)
it
'returns daily hourly and fifteen sync_times'
do
times
=
[
Gitlab
::
Mirror
::
FIFTEEN
,
Gitlab
::
Mirror
::
HOURLY
,
Gitlab
::
Mirror
::
THREE
,
Gitlab
::
Mirror
::
SIX
,
Gitlab
::
Mirror
::
TWELVE
,
Gitlab
::
Mirror
::
DAILY
]
expect
(
Gitlab
::
Mirror
.
sync_times
).
to
match_array
(
times
)
end
end
...
...
@@ -32,8 +72,11 @@ describe Gitlab::Mirror do
end
describe
'#configure_cron_jobs!'
do
let
(
:daily_cron
)
{
Gitlab
::
Mirror
::
SYNC_TIME_TO_CRON
[
Gitlab
::
Mirror
::
DAILY
]
}
let
(
:hourly_cron
)
{
Gitlab
::
Mirror
::
SYNC_TIME_TO_CRON
[
Gitlab
::
Mirror
::
HOURLY
]
}
let
(
:daily_cron
)
{
Gitlab
::
Mirror
::
SYNC_TIME_TO_CRON
[
Gitlab
::
Mirror
::
DAILY
]
}
let
(
:twelve_cron
)
{
Gitlab
::
Mirror
::
SYNC_TIME_TO_CRON
[
Gitlab
::
Mirror
::
TWELVE
]
}
let
(
:six_cron
)
{
Gitlab
::
Mirror
::
SYNC_TIME_TO_CRON
[
Gitlab
::
Mirror
::
SIX
]
}
let
(
:three_cron
)
{
Gitlab
::
Mirror
::
SYNC_TIME_TO_CRON
[
Gitlab
::
Mirror
::
THREE
]
}
let
(
:hourly_cron
)
{
Gitlab
::
Mirror
::
SYNC_TIME_TO_CRON
[
Gitlab
::
Mirror
::
HOURLY
]
}
let
(
:fifteen_cron
)
{
Gitlab
::
Mirror
::
SYNC_TIME_TO_CRON
[
Gitlab
::
Mirror
::
FIFTEEN
]
}
describe
'with jobs already running'
do
...
...
@@ -55,14 +98,50 @@ describe Gitlab::Mirror do
end
end
describe
'with twelve hour minimum_mirror_sync_time'
do
before
{
setup_mirrors_cron_job
(
Gitlab
::
Mirror
::
DAILY
,
Gitlab
::
Mirror
::
TWELVE
)
}
it
'changes cron of update_all_mirrors_worker to every twelve hours'
do
expect
{
Gitlab
::
Mirror
.
configure_cron_jobs!
}.
to
change
{
Sidekiq
::
Cron
::
Job
.
find
(
"update_all_mirrors_worker"
).
cron
}.
from
(
daily_cron
).
to
(
twelve_cron
)
end
it
'changes cron of update_all_remote_mirrors_worker to every twelve hours'
do
expect
{
Gitlab
::
Mirror
.
configure_cron_jobs!
}.
to
change
{
Sidekiq
::
Cron
::
Job
.
find
(
"update_all_remote_mirrors_worker"
).
cron
}.
from
(
daily_cron
).
to
(
twelve_cron
)
end
end
describe
'with six hour minimum_mirror_sync_time'
do
before
{
setup_mirrors_cron_job
(
Gitlab
::
Mirror
::
DAILY
,
Gitlab
::
Mirror
::
SIX
)
}
it
'changes cron of update_all_mirrors_worker to every six hours'
do
expect
{
Gitlab
::
Mirror
.
configure_cron_jobs!
}.
to
change
{
Sidekiq
::
Cron
::
Job
.
find
(
"update_all_mirrors_worker"
).
cron
}.
from
(
daily_cron
).
to
(
six_cron
)
end
it
'changes cron of update_all_remote_mirrors_worker to every six hours'
do
expect
{
Gitlab
::
Mirror
.
configure_cron_jobs!
}.
to
change
{
Sidekiq
::
Cron
::
Job
.
find
(
"update_all_remote_mirrors_worker"
).
cron
}.
from
(
daily_cron
).
to
(
six_cron
)
end
end
describe
'with three hour minimum_mirror_sync_time'
do
before
{
setup_mirrors_cron_job
(
Gitlab
::
Mirror
::
DAILY
,
Gitlab
::
Mirror
::
THREE
)
}
it
'changes cron of update_all_mirrors_worker to every three hours'
do
expect
{
Gitlab
::
Mirror
.
configure_cron_jobs!
}.
to
change
{
Sidekiq
::
Cron
::
Job
.
find
(
"update_all_mirrors_worker"
).
cron
}.
from
(
daily_cron
).
to
(
three_cron
)
end
it
'changes cron of update_all_remote_mirrors_worker to every three hours'
do
expect
{
Gitlab
::
Mirror
.
configure_cron_jobs!
}.
to
change
{
Sidekiq
::
Cron
::
Job
.
find
(
"update_all_remote_mirrors_worker"
).
cron
}.
from
(
daily_cron
).
to
(
three_cron
)
end
end
describe
'with hourly minimum_mirror_sync_time'
do
before
{
setup_mirrors_cron_job
(
Gitlab
::
Mirror
::
DAILY
,
Gitlab
::
Mirror
::
HOURLY
)
}
it
'changes cron of update_all_mirrors_worker to
dai
ly'
do
it
'changes cron of update_all_mirrors_worker to
hour
ly'
do
expect
{
Gitlab
::
Mirror
.
configure_cron_jobs!
}.
to
change
{
Sidekiq
::
Cron
::
Job
.
find
(
"update_all_mirrors_worker"
).
cron
}.
from
(
daily_cron
).
to
(
hourly_cron
)
end
it
'changes cron of update_all_remote_mirrors_worker to
dai
ly'
do
it
'changes cron of update_all_remote_mirrors_worker to
hour
ly'
do
expect
{
Gitlab
::
Mirror
.
configure_cron_jobs!
}.
to
change
{
Sidekiq
::
Cron
::
Job
.
find
(
"update_all_remote_mirrors_worker"
).
cron
}.
from
(
daily_cron
).
to
(
hourly_cron
)
end
end
...
...
@@ -100,6 +179,48 @@ describe Gitlab::Mirror do
end
end
describe
'with twelve hours minimum_mirror_sync_time'
do
before
{
allow_any_instance_of
(
ApplicationSetting
).
to
receive
(
:minimum_mirror_sync_time
).
and_return
(
Gitlab
::
Mirror
::
TWELVE
)
}
it
'creates update_all_mirrors_worker with cron of every twelve hours sync_time'
do
expect
{
Gitlab
::
Mirror
.
configure_cron_jobs!
}.
to
change
{
Sidekiq
::
Cron
::
Job
.
find
(
"update_all_mirrors_worker"
)
}.
from
(
nil
).
to
(
Sidekiq
::
Cron
::
Job
)
expect
(
Sidekiq
::
Cron
::
Job
.
find
(
"update_all_mirrors_worker"
).
cron
).
to
eq
(
twelve_cron
)
end
it
'creates update_all_remote_mirrors_worker with cron of every twelve hours sync_time'
do
expect
{
Gitlab
::
Mirror
.
configure_cron_jobs!
}.
to
change
{
Sidekiq
::
Cron
::
Job
.
find
(
"update_all_remote_mirrors_worker"
)
}.
from
(
nil
).
to
(
Sidekiq
::
Cron
::
Job
)
expect
(
Sidekiq
::
Cron
::
Job
.
find
(
"update_all_remote_mirrors_worker"
).
cron
).
to
eq
(
twelve_cron
)
end
end
describe
'with six hours minimum_mirror_sync_time'
do
before
{
allow_any_instance_of
(
ApplicationSetting
).
to
receive
(
:minimum_mirror_sync_time
).
and_return
(
Gitlab
::
Mirror
::
SIX
)
}
it
'creates update_all_mirrors_worker with cron of every six hours sync_time'
do
expect
{
Gitlab
::
Mirror
.
configure_cron_jobs!
}.
to
change
{
Sidekiq
::
Cron
::
Job
.
find
(
"update_all_mirrors_worker"
)
}.
from
(
nil
).
to
(
Sidekiq
::
Cron
::
Job
)
expect
(
Sidekiq
::
Cron
::
Job
.
find
(
"update_all_mirrors_worker"
).
cron
).
to
eq
(
six_cron
)
end
it
'creates update_all_remote_mirrors_worker with cron of every six hours sync_time'
do
expect
{
Gitlab
::
Mirror
.
configure_cron_jobs!
}.
to
change
{
Sidekiq
::
Cron
::
Job
.
find
(
"update_all_remote_mirrors_worker"
)
}.
from
(
nil
).
to
(
Sidekiq
::
Cron
::
Job
)
expect
(
Sidekiq
::
Cron
::
Job
.
find
(
"update_all_remote_mirrors_worker"
).
cron
).
to
eq
(
six_cron
)
end
end
describe
'with three hours minimum_mirror_sync_time'
do
before
{
allow_any_instance_of
(
ApplicationSetting
).
to
receive
(
:minimum_mirror_sync_time
).
and_return
(
Gitlab
::
Mirror
::
THREE
)
}
it
'creates update_all_mirrors_worker with cron of every three hours sync_time'
do
expect
{
Gitlab
::
Mirror
.
configure_cron_jobs!
}.
to
change
{
Sidekiq
::
Cron
::
Job
.
find
(
"update_all_mirrors_worker"
)
}.
from
(
nil
).
to
(
Sidekiq
::
Cron
::
Job
)
expect
(
Sidekiq
::
Cron
::
Job
.
find
(
"update_all_mirrors_worker"
).
cron
).
to
eq
(
three_cron
)
end
it
'creates update_all_remote_mirrors_worker with cron of every three hours sync_time'
do
expect
{
Gitlab
::
Mirror
.
configure_cron_jobs!
}.
to
change
{
Sidekiq
::
Cron
::
Job
.
find
(
"update_all_remote_mirrors_worker"
)
}.
from
(
nil
).
to
(
Sidekiq
::
Cron
::
Job
)
expect
(
Sidekiq
::
Cron
::
Job
.
find
(
"update_all_remote_mirrors_worker"
).
cron
).
to
eq
(
three_cron
)
end
end
describe
'with hourly minimum_mirror_sync_time'
do
before
{
allow_any_instance_of
(
ApplicationSetting
).
to
receive
(
:minimum_mirror_sync_time
).
and_return
(
Gitlab
::
Mirror
::
HOURLY
)
}
...
...
@@ -130,19 +251,19 @@ describe Gitlab::Mirror do
describe
'#at_beginning_of_day?'
do
it
'returns true if at beginning_of_day'
do
Timecop
.
freeze
(
DateTime
.
now
.
at_
beginning_of_day
)
Timecop
.
freeze
(
DateTime
.
now
.
beginning_of_day
)
expect
(
Gitlab
::
Mirror
.
at_beginning_of_day?
).
to
be
true
end
it
'returns false if at beginning of hour'
do
Timecop
.
freeze
(
DateTime
.
now
.
at_
beginning_of_hour
)
Timecop
.
freeze
(
DateTime
.
now
.
beginning_of_hour
)
expect
(
Gitlab
::
Mirror
.
at_beginning_of_day?
).
to
be
false
end
it
'returns false in every 15 minute mark'
do
Timecop
.
freeze
(
DateTime
.
now
.
at_
beginning_of_hour
+
15
.
minutes
)
Timecop
.
freeze
(
DateTime
.
now
.
beginning_of_hour
+
15
.
minutes
)
expect
(
Gitlab
::
Mirror
.
at_beginning_of_day?
).
to
be
false
end
...
...
@@ -151,22 +272,64 @@ describe Gitlab::Mirror do
end
describe
'#at_beginning_of_hour?'
do
it
'returns true if at beginning of day'
do
Timecop
.
freeze
(
DateTime
.
now
.
at_beginning_of_day
)
before
{
Timecop
.
freeze
(
DateTime
.
now
.
change
(
time
))
}
expect
(
Gitlab
::
Mirror
.
at_beginning_of_day?
).
to
be
true
end
describe
'without hour mark'
do
describe
'at beginning of day'
do
let!
(
:time
)
{
{
hour:
0
}
}
it
{
expect
(
Gitlab
::
Mirror
.
at_beginning_of_hour?
).
to
be
true
}
end
describe
'at beginning of hour'
do
let!
(
:time
)
{
{
hour:
1
}
}
it
{
expect
(
Gitlab
::
Mirror
.
at_beginning_of_hour?
).
to
be
true
}
end
it
'returns true if
at beginning of hour'
do
Timecop
.
freeze
(
DateTime
.
now
.
at_beginning_of_hour
)
describe
'
at beginning of hour'
do
let!
(
:time
)
{
{
hour:
1
,
min:
15
}
}
expect
(
Gitlab
::
Mirror
.
at_beginning_of_hour?
).
to
be
true
it
{
expect
(
Gitlab
::
Mirror
.
at_beginning_of_hour?
).
to
be
false
}
end
end
it
'returns false in every 15 minute mark'
do
Timecop
.
freeze
(
DateTime
.
now
.
at_beginning_of_hour
+
15
.
minutes
)
describe
'with hour mark'
do
describe
'three'
do
let!
(
:time
)
{
{
hour:
3
}
}
it
{
expect
(
Gitlab
::
Mirror
.
at_beginning_of_hour?
(
3
)).
to
be
true
}
describe
'with another hour'
do
let!
(
:time
)
{
{
hour:
4
}
}
it
{
expect
(
Gitlab
::
Mirror
.
at_beginning_of_hour?
(
3
)).
to
be
false
}
end
end
describe
'six'
do
let!
(
:time
)
{
{
hour:
6
}
}
it
{
expect
(
Gitlab
::
Mirror
.
at_beginning_of_hour?
(
6
)).
to
be
true
}
describe
'with another hour'
do
let!
(
:time
)
{
{
hour:
4
}
}
it
{
expect
(
Gitlab
::
Mirror
.
at_beginning_of_hour?
(
6
)).
to
be
false
}
end
end
describe
'twelve'
do
let!
(
:time
)
{
{
hour:
12
}
}
it
{
expect
(
Gitlab
::
Mirror
.
at_beginning_of_hour?
(
12
)).
to
be
true
}
expect
(
Gitlab
::
Mirror
.
at_beginning_of_hour?
).
to
be
false
describe
'with another hour'
do
let!
(
:time
)
{
{
hour:
4
}
}
it
{
expect
(
Gitlab
::
Mirror
.
at_beginning_of_hour?
(
12
)).
to
be
false
}
end
end
end
after
{
Timecop
.
return
}
...
...
spec/models/application_setting_spec.rb
View file @
acd9bc83
...
...
@@ -82,52 +82,38 @@ describe ApplicationSetting, models: true do
end
context
"update minimum_mirror_sync_time"
do
sync_times
=
Gitlab
::
Mirror
::
SYNC_TIME_TO_CRON
.
keys
before
do
Sidekiq
::
Logging
.
logger
=
nil
Gitlab
::
Mirror
::
SYNC_TIME_TO_CRON
.
key
s
.
each
do
|
sync_time
|
sync_time
s
.
each
do
|
sync_time
|
create
(
:project
,
:mirror
,
sync_time:
sync_time
)
create
(
:project
,
:remote_mirror
,
sync_time:
sync_time
)
end
end
context
'with daily sync_time'
do
let
(
:sync_time
)
{
Gitlab
::
Mirror
::
DAILY
}
it
'updates minimum_mirror_sync_time to daily and updates cron jobs'
do
expect_any_instance_of
(
ApplicationSetting
).
to
receive
(
:update_mirror_cron_jobs
).
and_call_original
expect
(
Gitlab
::
Mirror
).
to
receive
(
:configure_cron_jobs!
)
setting
.
update_attributes
(
minimum_mirror_sync_time:
sync_time
)
end
sync_times
.
drop
(
1
).
each_with_index
do
|
sync_time
,
index
|
context
"with
#{
sync_time
}
sync_time"
do
subject
{
setting
.
update_attributes
(
minimum_mirror_sync_time:
sync_time
)
}
it
'updates every mirror to the current minimum_mirror_sync_time'
do
expect
{
setting
.
update_attributes
(
minimum_mirror_sync_time:
sync_time
)
}.
to
change
{
Project
.
mirror
.
where
(
'sync_time < ?'
,
sync_time
).
count
}.
from
(
2
).
to
(
0
)
end
it
'updates every remote mirror to the current minimum_mirror_sync_time'
do
expect
{
setting
.
update_attributes
(
minimum_mirror_sync_time:
sync_time
)
}.
to
change
{
RemoteMirror
.
where
(
'sync_time < ?'
,
sync_time
).
count
}.
from
(
2
).
to
(
0
)
end
end
it
"updates minimum mirror sync time to
#{
sync_time
}
"
do
expect_any_instance_of
(
ApplicationSetting
).
to
receive
(
:update_mirror_cron_jobs
).
and_call_original
expect
(
Gitlab
::
Mirror
).
to
receive
(
:configure_cron_jobs!
)
context
'with hourly sync time'
do
let
(
:sync_time
)
{
Gitlab
::
Mirror
::
HOURLY
}
it
'updates minimum_mirror_sync_time to daily and updates cron jobs'
do
expect_any_instance_of
(
ApplicationSetting
).
to
receive
(
:update_mirror_cron_jobs
).
and_call_original
expect
(
Gitlab
::
Mirror
).
to
receive
(
:configure_cron_jobs!
)
setting
.
update_attributes
(
minimum_mirror_sync_time:
sync_time
)
end
subject
end
it
'updates every mirror to the current minimum_mirror_sync_time'
do
expect
{
setting
.
update_attributes
(
minimum_mirror_sync_time:
sync_time
)
}.
to
change
{
Project
.
mirror
.
where
(
'sync_time < ?'
,
sync_time
).
count
}.
from
(
1
).
to
(
0
)
end
it
'updates every mirror to the current minimum_mirror_sync_time'
do
expect
{
subject
}.
to
change
{
Project
.
mirror
.
where
(
'sync_time < ?'
,
sync_time
).
count
}.
from
(
index
+
1
).
to
(
0
)
end
it
'updates every remote mirror to the current minimum_mirror_sync_time'
do
expect
{
setting
.
update_attributes
(
minimum_mirror_sync_time:
sync_time
)
}.
to
change
{
RemoteMirror
.
where
(
'sync_time < ?'
,
sync_time
).
count
}.
from
(
1
).
to
(
0
)
it
'updates every remote mirror to the current minimum_mirror_sync_time'
do
expect
{
subject
}.
to
change
{
RemoteMirror
.
where
(
'sync_time < ?'
,
sync_time
).
count
}.
from
(
index
+
1
).
to
(
0
)
end
end
end
# fifteen is a special case so we isolate it
context
'with default fifteen sync time'
do
let
(
:sync_time
)
{
Gitlab
::
Mirror
::
FIFTEEN
}
...
...
spec/workers/update_all_mirrors_worker_spec.rb
View file @
acd9bc83
require
'rails_helper'
describe
UpdateAllMirrorsWorker
do
subject
(
:worker
)
{
described_class
.
new
}
before
{
allow_any_instance_of
(
Gitlab
::
ExclusiveLease
).
to
receive
(
:try_obtain
).
and_return
(
true
)
}
describe
'#perform'
do
let
(
:worker
)
{
described_class
.
new
}
let!
(
:mirror1
)
{
create
(
:empty_project
,
:mirror
,
sync_time:
Gitlab
::
Mirror
::
FIFTEEN
)
}
let!
(
:mirror2
)
{
create
(
:empty_project
,
:mirror
,
sync_time:
Gitlab
::
Mirror
::
HOURLY
)
}
let!
(
:mirror3
)
{
create
(
:empty_project
,
:mirror
,
sync_time:
Gitlab
::
Mirror
::
DAILY
)
}
let!
(
:mirror4
)
{
create
(
:empty_project
,
:mirror
)
}
let!
(
:fifteen_mirror
)
{
create
(
:empty_project
,
:mirror
,
sync_time:
Gitlab
::
Mirror
::
FIFTEEN
)
}
let!
(
:hourly_mirror
)
{
create
(
:empty_project
,
:mirror
,
sync_time:
Gitlab
::
Mirror
::
HOURLY
)
}
let!
(
:three_mirror
)
{
create
(
:empty_project
,
:mirror
,
sync_time:
Gitlab
::
Mirror
::
THREE
)
}
let!
(
:six_mirror
)
{
create
(
:empty_project
,
:mirror
,
sync_time:
Gitlab
::
Mirror
::
SIX
)
}
let!
(
:twelve_mirror
)
{
create
(
:empty_project
,
:mirror
,
sync_time:
Gitlab
::
Mirror
::
TWELVE
)
}
let!
(
:daily_mirror
)
{
create
(
:empty_project
,
:mirror
,
sync_time:
Gitlab
::
Mirror
::
DAILY
)
}
let!
(
:outdated_mirror
)
{
create
(
:empty_project
,
:mirror
)
}
it
'fails stuck mirrors'
do
expect
(
worker
).
to
receive
(
:fail_stuck_mirrors!
)
...
...
@@ -16,76 +20,88 @@ describe UpdateAllMirrorsWorker do
worker
.
perform
end
it
'does not execute if cannot get the lease'
do
allow_any_instance_of
(
Gitlab
::
ExclusiveLease
).
to
receive
(
:try_obtain
).
and_return
(
false
)
create
(
:empty_project
,
:mirror
)
expect
(
worker
).
not_to
receive
(
:fail_stuck_mirrors!
)
worker
.
perform
end
describe
'sync_time'
do
def
expect_worker_to_
updat
e_mirrors
(
mirrors
)
def
expect_worker_to_
enqueu
e_mirrors
(
mirrors
)
mirrors
.
each
do
|
mirror
|
expect
(
worker
).
to
receive
(
:rand
).
with
((
mirror
.
sync_time
/
2
).
minutes
).
and_return
(
mirror
.
sync_time
/
2
)
expect
(
RepositoryUpdateMirrorDispatchWorker
).
to
receive
(
:perform_in
).
with
(
mirror
.
sync_time
/
2
,
mirror
.
id
)
end
worker
.
perform
end
def
setup
(
time
)
before
do
time
=
DateTime
.
now
.
change
(
time_params
)
Timecop
.
freeze
(
time
)
mirror4
.
update_attributes
(
mirror_last_successful_update_at:
time
-
(
Gitlab
::
Mirror
::
DAILY
+
5
).
minutes
)
outdated_mirror
.
update_attributes
(
mirror_last_successful_update_at:
time
-
(
Gitlab
::
Mirror
::
DAILY
+
5
).
minutes
)
end
describe
'fifteen'
do
let
(
:mirrors
)
{
[
mirror1
,
mirror4
]
}
before
{
setup
(
DateTime
.
now
.
beginning_of_hour
+
15
.
minutes
)
}
let!
(
:time_params
)
{
{
hour:
1
,
min:
15
}
}
let
(
:mirrors
)
{
[
fifteen_mirror
,
outdated_mirror
]
}
it
'enqueues a job on mirrored projects'
do
expect_worker_to_update_mirrors
(
mirrors
)
worker
.
perform
end
it
{
expect_worker_to_enqueue_mirrors
(
mirrors
)
}
end
describe
'hourly'
do
let
(
:mirrors
)
{
[
mirror1
,
mirror2
,
mirror4
]
}
before
{
setup
(
DateTime
.
now
.
beginning_of_hour
)
}
it
'enqueues a job on mirrored projects'
do
expect_worker_to_update_mirrors
(
mirrors
)
let!
(
:time_params
)
{
{
hour:
1
}
}
let
(
:mirrors
)
{
[
fifteen_mirror
,
hourly_mirror
,
outdated_mirror
]
}
worker
.
perform
end
it
{
expect_worker_to_enqueue_mirrors
(
mirrors
)
}
end
describe
'daily'
do
let
(
:mirrors
)
{
[
mirror1
,
mirror2
,
mirror3
,
mirror4
]
}
describe
'three'
do
let!
(
:time_params
)
{
{
hour:
3
}
}
let
(
:mirrors
)
{
[
fifteen_mirror
,
hourly_mirror
,
three_mirror
,
outdated_mirror
]
}
before
{
setup
(
DateTime
.
now
.
beginning_of_day
)
}
it
{
expect_worker_to_enqueue_mirrors
(
mirrors
)
}
end
it
'enqueues a job on mirrored projects'
do
expect_worker_to_update_mirrors
(
mirrors
)
describe
'six'
do
let!
(
:time_params
)
{
{
hour:
6
}
}
let
(
:mirrors
)
{
[
fifteen_mirror
,
hourly_mirror
,
three_mirror
,
six_mirror
,
outdated_mirror
]
}
worker
.
perform
end
it
{
expect_worker_to_enqueue_mirrors
(
mirrors
)
}
end
after
{
Timecop
.
return
}
end
describe
'twelve'
do
let!
(
:time_params
)
{
{
hour:
12
}
}
let
(
:mirrors
)
{
[
fifteen_mirror
,
hourly_mirror
,
three_mirror
,
six_mirror
,
twelve_mirror
,
outdated_mirror
]
}
it
'does not execute if cannot get the lease'
do
allow_any_instance_of
(
Gitlab
::
ExclusiveLease
).
to
receive
(
:try_obtain
).
and_return
(
false
)
it
{
expect_worker_to_enqueue_mirrors
(
mirrors
)
}
end
create
(
:empty_project
,
:mirror
)
describe
'daily'
do
let!
(
:time_params
)
{
{
hour:
0
}
}
let
(
:mirrors
)
{
[
fifteen_mirror
,
hourly_mirror
,
three_mirror
,
six_mirror
,
twelve_mirror
,
daily_mirror
,
outdated_mirror
]
}
expect
(
worker
).
not_to
receive
(
:fail_stuck_mirrors!
)
it
{
expect_worker_to_enqueue_mirrors
(
mirrors
)
}
end
worker
.
perform
after
{
Timecop
.
return
}
end
end
describe
'#fail_stuck_mirrors!'
do
delegate
:fail_stuck_mirrors!
,
to: :worker
it
'ignores records that are not mirrors'
do
create
(
:empty_project
,
:import_started
,
mirror_last_update_at:
12
.
hours
.
ago
)
expect_any_instance_of
(
Project
).
not_to
receive
(
:import_fail
)
perform
fail_stuck_mirrors!
end
it
'ignores records without in-progress import'
do
...
...
@@ -93,7 +109,7 @@ describe UpdateAllMirrorsWorker do
expect_any_instance_of
(
Project
).
not_to
receive
(
:import_fail
)
perform
fail_stuck_mirrors!
end
it
'ignores records with recently updated mirrors'
do
...
...
@@ -101,13 +117,13 @@ describe UpdateAllMirrorsWorker do
expect_any_instance_of
(
Project
).
not_to
receive
(
:import_fail
)
perform
fail_stuck_mirrors!
end
it
'transitions stuck mirrors to a failed state'
do
project
=
create
(
:empty_project
,
:mirror
,
mirror_last_update_at:
12
.
hours
.
ago
)
perform
fail_stuck_mirrors!
project
.
reload
expect
(
project
).
to
be_import_failed
...
...
@@ -116,14 +132,10 @@ describe UpdateAllMirrorsWorker do
it
'updates the import_error message'
do
project
=
create
(
:empty_project
,
:mirror
,
mirror_last_update_at:
12
.
hours
.
ago
)
perform
fail_stuck_mirrors!
project
.
reload
expect
(
project
.
import_error
).
to
eq
'The mirror update took too long to complete.'
end
def
perform
described_class
.
new
.
fail_stuck_mirrors!
end
end
end
spec/workers/update_all_remote_mirrors_worker.rb
deleted
100644 → 0
View file @
f2f5cb67
require
'rails_helper'
describe
UpdateAllRemoteMirrorsWorker
do
let
(
:worker
)
{
described_class
.
new
}
describe
"#perform"
do
let!
(
:mirror1
)
{
create
(
:project
,
:remote_mirror
,
sync_time:
Gitlab
::
Mirror
::
FIFTEEN
)
}
let!
(
:mirror2
)
{
create
(
:project
,
:remote_mirror
,
sync_time:
Gitlab
::
Mirror
::
HOURLY
)
}
let!
(
:mirror3
)
{
create
(
:project
,
:remote_mirror
,
sync_time:
Gitlab
::
Mirror
::
DAILY
)
}
let!
(
:mirror4
)
{
create
(
:project
,
:remote_mirror
,
sync_time:
Gitlab
::
Mirror
::
DAILY
)
}
it
'fails stuck mirrors'
do
expect
(
worker
).
to
receive
(
:fail_stuck_mirrors!
)
worker
.
perform
end
describe
'sync time'
do
def
expect_worker_to_update_mirrors
(
mirrors
)
mirrors
.
each
do
|
mirror
|
expect
(
RepositoryUpdateRemoteMirrorWorker
).
to
receive
(
:perform_async
).
with
(
mirror
.
id
)
end
end
def
setup
(
time
)
Timecop
.
freeze
(
time
)
mirror4
.
remote_mirrors
.
first
.
update_attributes
(
last_successful_update_at:
time
-
(
Gitlab
::
Mirror
::
DAILY
+
5
).
minutes
)
end
describe
'fifteen'
do
let
(
:mirrors
)
{
[
mirror1
,
mirror4
]
}
before
{
setup
(
DateTime
.
now
.
beginning_of_hour
+
15
.
minutes
)
}
it
'enqueues a job on remote mirrored projects'
do
expect_worker_to_update_mirrors
(
mirrors
)
worker
.
perform
end
end
describe
"hourly"
do
let
(
:mirrors
)
{
[
mirror1
,
mirror2
,
mirror4
]
}
before
{
setup
(
DateTime
.
now
.
beginning_of_hour
)
}
it
'enqueues a job on remote mirrored projects'
do
expect_worker_to_update_mirrors
(
mirrors
)
worker
.
perform
end
end
describe
"daily"
do
let
(
:mirrors
)
{
[
mirror1
,
mirror2
,
mirror3
,
mirror4
]
}
before
{
setup
(
DateTime
.
now
.
beginning_of_day
)
}
it
'enqueues a job on remote mirrored projects'
do
expect_worker_to_update_mirrors
(
mirrors
)
worker
.
perform
end
end
after
{
Timecop
.
return
}
end
end
end
spec/workers/update_all_remote_mirrors_worker_spec.rb
0 → 100644
View file @
acd9bc83
require
'rails_helper'
describe
UpdateAllRemoteMirrorsWorker
do
subject
(
:worker
)
{
described_class
.
new
}
describe
"#perform"
do
let!
(
:fifteen_mirror
)
{
create
(
:project
,
:remote_mirror
,
sync_time:
Gitlab
::
Mirror
::
FIFTEEN
)
}
let!
(
:hourly_mirror
)
{
create
(
:project
,
:remote_mirror
,
sync_time:
Gitlab
::
Mirror
::
HOURLY
)
}
let!
(
:three_mirror
)
{
create
(
:project
,
:remote_mirror
,
sync_time:
Gitlab
::
Mirror
::
THREE
)
}
let!
(
:six_mirror
)
{
create
(
:project
,
:remote_mirror
,
sync_time:
Gitlab
::
Mirror
::
SIX
)
}
let!
(
:twelve_mirror
)
{
create
(
:project
,
:remote_mirror
,
sync_time:
Gitlab
::
Mirror
::
TWELVE
)
}
let!
(
:daily_mirror
)
{
create
(
:project
,
:remote_mirror
,
sync_time:
Gitlab
::
Mirror
::
DAILY
)
}
let!
(
:outdated_mirror
)
{
create
(
:project
,
:remote_mirror
)
}
it
'fails stuck mirrors'
do
expect
(
worker
).
to
receive
(
:fail_stuck_mirrors!
)
worker
.
perform
end
describe
'sync time'
do
def
expect_worker_to_enqueue_mirrors
(
mirrors
)
mirrors
.
each
do
|
mirror
|
expect
(
RepositoryUpdateRemoteMirrorWorker
).
to
receive
(
:perform_async
).
with
(
mirror
.
id
)
end
worker
.
perform
end
before
do
time
=
DateTime
.
now
.
change
(
time_params
)
Timecop
.
freeze
(
time
)
outdated_mirror
.
remote_mirrors
.
first
.
update_attributes
(
last_successful_update_at:
time
-
(
Gitlab
::
Mirror
::
DAILY
+
5
).
minutes
)
end
describe
'fifteen'
do
let!
(
:time_params
)
{
{
hour:
1
,
min:
15
}
}
let
(
:mirrors
)
{
[
fifteen_mirror
,
outdated_mirror
]
}
it
{
expect_worker_to_enqueue_mirrors
(
mirrors
)
}
end
describe
"hourly"
do
let!
(
:time_params
)
{
{
hour:
1
}
}
let
(
:mirrors
)
{
[
fifteen_mirror
,
hourly_mirror
,
outdated_mirror
]
}
it
{
expect_worker_to_enqueue_mirrors
(
mirrors
)
}
end
describe
"three"
do
let!
(
:time_params
)
{
{
hour:
3
}
}
let
(
:mirrors
)
{
[
fifteen_mirror
,
hourly_mirror
,
three_mirror
,
outdated_mirror
]
}
it
{
expect_worker_to_enqueue_mirrors
(
mirrors
)
}
end
describe
"six"
do
let!
(
:time_params
)
{
{
hour:
6
}
}
let
(
:mirrors
)
{
[
fifteen_mirror
,
hourly_mirror
,
three_mirror
,
six_mirror
,
outdated_mirror
]
}
it
{
expect_worker_to_enqueue_mirrors
(
mirrors
)
}
end
describe
"twelve"
do
let!
(
:time_params
)
{
{
hour:
12
}
}
let
(
:mirrors
)
{
[
fifteen_mirror
,
hourly_mirror
,
three_mirror
,
six_mirror
,
twelve_mirror
,
outdated_mirror
]
}
it
{
expect_worker_to_enqueue_mirrors
(
mirrors
)
}
end
describe
"daily"
do
let!
(
:time_params
)
{
{
hour:
0
}
}
let
(
:mirrors
)
{
[
fifteen_mirror
,
hourly_mirror
,
three_mirror
,
six_mirror
,
twelve_mirror
,
daily_mirror
,
outdated_mirror
]
}
it
{
expect_worker_to_enqueue_mirrors
(
mirrors
)
}
end
after
{
Timecop
.
return
}
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