Commit faf31fa1 authored by Rémy Coutable's avatar Rémy Coutable

Merge branch '3919-fix-project-mirror-data-scheduling-specs' into 'master'

Project mirror data scheduling specs no longer rely on be_within to have the correct interval.

Closes #3919

See merge request gitlab-org/gitlab-ee!3263
parents 5e5ae80f bf52e20d
...@@ -49,7 +49,6 @@ describe ProjectMirrorData, type: :model do ...@@ -49,7 +49,6 @@ describe ProjectMirrorData, type: :model do
let(:mirror_data) { create(:project, :mirror, :import_finished).mirror_data } let(:mirror_data) { create(:project, :mirror, :import_finished).mirror_data }
let!(:timestamp) { Time.now } let!(:timestamp) { Time.now }
let!(:jitter) { 2.seconds } let!(:jitter) { 2.seconds }
let(:interval) { 2.minutes }
before do before do
allow_any_instance_of(ProjectMirrorData).to receive(:rand).and_return(jitter) allow_any_instance_of(ProjectMirrorData).to receive(:rand).and_return(jitter)
...@@ -62,9 +61,7 @@ describe ProjectMirrorData, type: :model do ...@@ -62,9 +61,7 @@ describe ProjectMirrorData, type: :model do
context 'when retry count is 0' do context 'when retry count is 0' do
it 'applies transition successfully' do it 'applies transition successfully' do
expect do expect_next_execution_timestamp(mirror_data, timestamp + 26.minutes)
mirror_data.set_next_execution_timestamp!
end.to change { mirror_data.next_execution_timestamp }.to be_within(interval).of(timestamp + 26.minutes)
end end
end end
...@@ -73,9 +70,7 @@ describe ProjectMirrorData, type: :model do ...@@ -73,9 +70,7 @@ describe ProjectMirrorData, type: :model do
mirror_data.retry_count = 2 mirror_data.retry_count = 2
mirror_data.increment_retry_count! mirror_data.increment_retry_count!
expect do expect_next_execution_timestamp(mirror_data, timestamp + 78.minutes)
mirror_data.set_next_execution_timestamp!
end.to change { mirror_data.next_execution_timestamp }.to be_within(interval).of(timestamp + 79.minutes)
end end
end end
end end
...@@ -83,28 +78,27 @@ describe ProjectMirrorData, type: :model do ...@@ -83,28 +78,27 @@ describe ProjectMirrorData, type: :model do
context 'when boundaries are surpassed' do context 'when boundaries are surpassed' do
let!(:mirror_jitter) { 30.seconds } let!(:mirror_jitter) { 30.seconds }
before do
allow(Gitlab::Mirror).to receive(:rand).and_return(mirror_jitter)
end
context 'when base delay is lower than mirror min_delay' do context 'when base delay is lower than mirror min_delay' do
before do before do
allow_any_instance_of(Gitlab::Mirror).to receive(:rand).and_return(mirror_jitter)
mirror_data.last_update_started_at = timestamp - 1.second mirror_data.last_update_started_at = timestamp - 1.second
end end
context 'when resetting retry count' do context 'when resetting retry count' do
it 'applies transition successfully' do it 'applies transition successfully' do
expect do expect_next_execution_timestamp(mirror_data, timestamp + 15.minutes + mirror_jitter)
mirror_data.set_next_execution_timestamp!
end.to change { mirror_data.next_execution_timestamp }.to be_within(interval).of(timestamp + 15.minutes)
end end
end end
context 'when incrementing retry count' do context 'when incrementing retry count' do
it 'applies transition successfully' do it 'applies transition successfully' do
mirror_data.retry_count = 2 mirror_data.retry_count = 3
mirror_data.increment_retry_count! mirror_data.increment_retry_count!
expect do expect_next_execution_timestamp(mirror_data, timestamp + 62.minutes)
mirror_data.set_next_execution_timestamp!
end.to change { mirror_data.next_execution_timestamp }.to be_within(interval).of(timestamp + 45.minutes)
end end
end end
end end
...@@ -113,15 +107,12 @@ describe ProjectMirrorData, type: :model do ...@@ -113,15 +107,12 @@ describe ProjectMirrorData, type: :model do
let(:max_timestamp) { timestamp + current_application_settings.mirror_max_delay.minutes } let(:max_timestamp) { timestamp + current_application_settings.mirror_max_delay.minutes }
before do before do
allow_any_instance_of(Gitlab::Mirror).to receive(:rand).and_return(mirror_jitter)
mirror_data.last_update_started_at = timestamp - 1.hour mirror_data.last_update_started_at = timestamp - 1.hour
end end
context 'when resetting retry count' do context 'when resetting retry count' do
it 'applies transition successfully' do it 'applies transition successfully' do
expect do expect_next_execution_timestamp(mirror_data, max_timestamp + mirror_jitter)
mirror_data.set_next_execution_timestamp!
end.to change { mirror_data.next_execution_timestamp }.to be_within(interval).of(max_timestamp + mirror_jitter)
end end
end end
...@@ -130,12 +121,18 @@ describe ProjectMirrorData, type: :model do ...@@ -130,12 +121,18 @@ describe ProjectMirrorData, type: :model do
mirror_data.retry_count = 2 mirror_data.retry_count = 2
mirror_data.increment_retry_count! mirror_data.increment_retry_count!
expect do expect_next_execution_timestamp(mirror_data, max_timestamp + mirror_jitter)
mirror_data.set_next_execution_timestamp!
end.to change { mirror_data.next_execution_timestamp }.to be_within(interval).of(max_timestamp + mirror_jitter)
end end
end end
end end
end end
def expect_next_execution_timestamp(mirror_data, new_timestamp)
Timecop.freeze(timestamp) do
expect do
mirror_data.set_next_execution_timestamp!
end.to change { mirror_data.next_execution_timestamp }.to eq(new_timestamp)
end
end
end end
end end
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment