Commit 1bf6be72 authored by Douglas Barbosa Alexandre's avatar Douglas Barbosa Alexandre

Merge branch 'mk/make-repo-sync-retries-more-resilient' into 'master'

Geo: Reduce frequency of redownload attempts

See merge request gitlab-org/gitlab!70329
parents 2a218504 f9bd2d7a
...@@ -6,7 +6,7 @@ class Geo::DesignRegistry < Geo::BaseRegistry ...@@ -6,7 +6,7 @@ class Geo::DesignRegistry < Geo::BaseRegistry
MODEL_CLASS = ::Project MODEL_CLASS = ::Project
MODEL_FOREIGN_KEY = :project_id MODEL_FOREIGN_KEY = :project_id
RETRIES_BEFORE_REDOWNLOAD = 5 RETRIES_BEFORE_REDOWNLOAD = 10
belongs_to :project belongs_to :project
...@@ -120,6 +120,6 @@ class Geo::DesignRegistry < Geo::BaseRegistry ...@@ -120,6 +120,6 @@ class Geo::DesignRegistry < Geo::BaseRegistry
def should_be_redownloaded? def should_be_redownloaded?
return true if force_to_redownload return true if force_to_redownload
retry_count > RETRIES_BEFORE_REDOWNLOAD retry_count.present? && retry_count > RETRIES_BEFORE_REDOWNLOAD && retry_count.odd?
end end
end end
...@@ -10,7 +10,7 @@ class Geo::ProjectRegistry < Geo::BaseRegistry ...@@ -10,7 +10,7 @@ class Geo::ProjectRegistry < Geo::BaseRegistry
MODEL_FOREIGN_KEY = :project_id MODEL_FOREIGN_KEY = :project_id
REGISTRY_TYPES = %i{repository wiki}.freeze REGISTRY_TYPES = %i{repository wiki}.freeze
RETRIES_BEFORE_REDOWNLOAD = 5 RETRIES_BEFORE_REDOWNLOAD = 10
sha_attribute :repository_verification_checksum_sha sha_attribute :repository_verification_checksum_sha
sha_attribute :repository_verification_checksum_mismatched sha_attribute :repository_verification_checksum_mismatched
...@@ -409,7 +409,9 @@ class Geo::ProjectRegistry < Geo::BaseRegistry ...@@ -409,7 +409,9 @@ class Geo::ProjectRegistry < Geo::BaseRegistry
ensure_valid_type!(type) ensure_valid_type!(type)
return true if public_send("force_to_redownload_#{type}") # rubocop:disable GitlabSecurity/PublicSend return true if public_send("force_to_redownload_#{type}") # rubocop:disable GitlabSecurity/PublicSend
retry_count(type) > RETRIES_BEFORE_REDOWNLOAD retries = retry_count(type)
retries > RETRIES_BEFORE_REDOWNLOAD && retries.odd?
end end
def verification_retry_count(type) def verification_retry_count(type)
......
...@@ -17,7 +17,7 @@ module Geo ...@@ -17,7 +17,7 @@ module Geo
LEASE_TIMEOUT = 8.hours LEASE_TIMEOUT = 8.hours
LEASE_KEY_PREFIX = 'geo_sync_ssf_service' LEASE_KEY_PREFIX = 'geo_sync_ssf_service'
RETRIES_BEFORE_REDOWNLOAD = 5 RETRIES_BEFORE_REDOWNLOAD = 10
def initialize(replicator) def initialize(replicator)
@replicator = replicator @replicator = replicator
...@@ -245,7 +245,9 @@ module Geo ...@@ -245,7 +245,9 @@ module Geo
def should_be_redownloaded? def should_be_redownloaded?
return true if registry.force_to_redownload return true if registry.force_to_redownload
registry.retry_count > RETRIES_BEFORE_REDOWNLOAD retries = registry.retry_count
retries.present? && retries > RETRIES_BEFORE_REDOWNLOAD && retries.odd?
end end
def reschedule_sync def reschedule_sync
......
...@@ -4,6 +4,7 @@ require 'spec_helper' ...@@ -4,6 +4,7 @@ require 'spec_helper'
RSpec.describe Geo::DesignRegistry, :geo do RSpec.describe Geo::DesignRegistry, :geo do
include ::EE::GeoHelpers include ::EE::GeoHelpers
using RSpec::Parameterized::TableSyntax
it_behaves_like 'a BulkInsertSafe model', Geo::DesignRegistry do it_behaves_like 'a BulkInsertSafe model', Geo::DesignRegistry do
let(:valid_items_for_bulk_insertion) do let(:valid_items_for_bulk_insertion) do
...@@ -266,25 +267,27 @@ RSpec.describe Geo::DesignRegistry, :geo do ...@@ -266,25 +267,27 @@ RSpec.describe Geo::DesignRegistry, :geo do
end end
describe '#should_be_redownloaded?' do describe '#should_be_redownloaded?' do
let_it_be(:design_registry) { create(:geo_design_registry) } where(:force_to_redownload, :retry_count, :expected) do
false | nil | false
context 'when force_to_redownload is false' do false | 0 | false
it 'returns false' do false | 1 | false
expect(design_registry.should_be_redownloaded?).to be false false | 10 | false
end false | 11 | true
false | 12 | false
it 'returns true when limit is exceeded' do false | 13 | true
design_registry.retry_count = Geo::DesignRegistry::RETRIES_BEFORE_REDOWNLOAD + 1 false | 14 | false
false | 101 | true
expect(design_registry.should_be_redownloaded?).to be true false | 102 | false
end true | nil | true
true | 0 | true
true | 11 | true
end end
context 'when force_to_redownload is true' do with_them do
it 'resets the state of the sync' do it "returns the expected boolean" do
design_registry.force_to_redownload = true registry = build(:geo_design_registry, retry_count: retry_count, force_to_redownload: force_to_redownload)
expect(design_registry.should_be_redownloaded?).to be true expect(registry.should_be_redownloaded?).to eq(expected)
end end
end end
end end
......
...@@ -1259,4 +1259,68 @@ RSpec.describe Geo::ProjectRegistry, :geo do ...@@ -1259,4 +1259,68 @@ RSpec.describe Geo::ProjectRegistry, :geo do
end end
end end
end end
describe 'should_be_redownloaded?' do
context 'when type is invalid' do
it 'raises ArgumentError' do
registry = build(:geo_project_registry)
expect do
registry.should_be_redownloaded?(:invalid_type)
end.to raise_error(ArgumentError)
end
end
context 'when type is repository' do
where(:force_to_redownload_repository, :repository_retry_count, :expected) do
false | nil | false
false | 0 | false
false | 1 | false
false | 10 | false
false | 11 | true
false | 12 | false
false | 13 | true
false | 14 | false
false | 101 | true
false | 102 | false
true | nil | true
true | 0 | true
true | 11 | true
end
with_them do
it "returns the expected boolean" do
registry = build(:geo_project_registry, repository_retry_count: repository_retry_count, force_to_redownload_repository: force_to_redownload_repository)
expect(registry.should_be_redownloaded?(:repository)).to eq(expected)
end
end
end
context 'when type is wiki' do
where(:force_to_redownload_wiki, :wiki_retry_count, :expected) do
false | nil | false
false | 0 | false
false | 1 | false
false | 10 | false
false | 11 | true
false | 12 | false
false | 13 | true
false | 14 | false
false | 101 | true
false | 102 | false
true | nil | true
true | 0 | true
true | 11 | true
end
with_them do
it "returns the expected boolean" do
registry = build(:geo_project_registry, wiki_retry_count: wiki_retry_count, force_to_redownload_wiki: force_to_redownload_wiki)
expect(registry.should_be_redownloaded?(:wiki)).to eq(expected)
end
end
end
end
end end
...@@ -5,6 +5,7 @@ require 'spec_helper' ...@@ -5,6 +5,7 @@ require 'spec_helper'
RSpec.describe Geo::FrameworkRepositorySyncService, :geo do RSpec.describe Geo::FrameworkRepositorySyncService, :geo do
include ::EE::GeoHelpers include ::EE::GeoHelpers
include ExclusiveLeaseHelpers include ExclusiveLeaseHelpers
using RSpec::Parameterized::TableSyntax
let_it_be(:primary) { create(:geo_node, :primary) } let_it_be(:primary) { create(:geo_node, :primary) }
let_it_be(:secondary) { create(:geo_node) } let_it_be(:secondary) { create(:geo_node) }
...@@ -327,4 +328,30 @@ RSpec.describe Geo::FrameworkRepositorySyncService, :geo do ...@@ -327,4 +328,30 @@ RSpec.describe Geo::FrameworkRepositorySyncService, :geo do
end end
end end
end end
describe '#should_be_redownloaded?' do
where(:force_to_redownload, :retry_count, :expected) do
false | nil | false
false | 0 | false
false | 1 | false
false | 10 | false
false | 11 | true
false | 12 | false
false | 13 | true
false | 14 | false
false | 101 | true
false | 102 | false
true | nil | true
true | 0 | true
true | 11 | true
end
with_them do
it "returns the expected boolean" do
registry.update!(retry_count: retry_count, force_to_redownload: force_to_redownload)
expect(subject.send(:should_be_redownloaded?)).to eq(expected)
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