Commit 8bfe94c0 authored by Mike Kozono's avatar Mike Kozono

Fix Package File verification status in rake tasks

Add test the verification count methods.
parent 44621b2c
...@@ -377,8 +377,8 @@ class GeoNodeStatus < ApplicationRecord ...@@ -377,8 +377,8 @@ class GeoNodeStatus < ApplicationRecord
def self.add_attr_in_percentage_for_replicable_classes def self.add_attr_in_percentage_for_replicable_classes
Gitlab::Geo::REPLICATOR_CLASSES.each do |replicator| Gitlab::Geo::REPLICATOR_CLASSES.each do |replicator|
replicable = replicator.replicable_name_plural replicable = replicator.replicable_name_plural
attr_in_percentage "#{replicable}_checksummed", "#{replicable}_checksummed_count", "#{replicable}_count"
attr_in_percentage "#{replicable}_synced", "#{replicable}_synced_count", "#{replicable}_registry_count" attr_in_percentage "#{replicable}_synced", "#{replicable}_synced_count", "#{replicable}_registry_count"
attr_in_percentage "#{replicable}_verified", "#{replicable}_verified_count", "#{replicable}_registry_count"
end end
end end
...@@ -402,8 +402,8 @@ class GeoNodeStatus < ApplicationRecord ...@@ -402,8 +402,8 @@ class GeoNodeStatus < ApplicationRecord
public_send("#{replicator_class.replicable_name_plural}_synced_in_percentage") # rubocop:disable GitlabSecurity/PublicSend public_send("#{replicator_class.replicable_name_plural}_synced_in_percentage") # rubocop:disable GitlabSecurity/PublicSend
end end
def checksummed_in_percentage_for(replicator_class) def verified_in_percentage_for(replicator_class)
public_send("#{replicator_class.replicable_name_plural}_checksummed_in_percentage") # rubocop:disable GitlabSecurity/PublicSend public_send("#{replicator_class.replicable_name_plural}_verified_in_percentage") # rubocop:disable GitlabSecurity/PublicSend
end end
def count_for(replicator_class) def count_for(replicator_class)
......
...@@ -35,7 +35,7 @@ module Gitlab ...@@ -35,7 +35,7 @@ module Gitlab
print_design_repositories_status print_design_repositories_status
print_replicators_status print_replicators_status
print_repositories_checked_status print_repositories_checked_status
print_replicators_checked_status print_replicators_verification_status
print_sync_settings print_sync_settings
print_db_replication_lag print_db_replication_lag
...@@ -57,7 +57,7 @@ module Gitlab ...@@ -57,7 +57,7 @@ module Gitlab
print_design_repositories_status print_design_repositories_status
print_replicators_status print_replicators_status
print_repositories_checked_status print_repositories_checked_status
print_replicators_checked_status print_replicators_verification_status
end end
def replication_verification_complete? def replication_verification_complete?
...@@ -104,7 +104,7 @@ module Gitlab ...@@ -104,7 +104,7 @@ module Gitlab
status.push current_node_status.synced_in_percentage_for(replicator_class) status.push current_node_status.synced_in_percentage_for(replicator_class)
if replicator_class.verification_enabled? if replicator_class.verification_enabled?
status.push current_node_status.checksummed_in_percentage_for(replicator_class) status.push current_node_status.verified_in_percentage_for(replicator_class)
end end
end end
end end
...@@ -301,14 +301,14 @@ module Gitlab ...@@ -301,14 +301,14 @@ module Gitlab
end end
end end
def print_replicators_checked_status def print_replicators_verification_status
verifiable_replicator_classes = Gitlab::Geo.enabled_replicator_classes.select(&:verification_enabled?) verifiable_replicator_classes = Gitlab::Geo.verification_enabled_replicator_classes
verifiable_replicator_classes.each do |replicator_class| verifiable_replicator_classes.each do |replicator_class|
print "#{replicator_class.replicable_title_plural} Checked: ".rjust(GEO_STATUS_COLUMN_WIDTH) print "#{replicator_class.replicable_title_plural} Verified: ".rjust(GEO_STATUS_COLUMN_WIDTH)
show_failed_value(replicator_class.checksum_failed_count) show_failed_value(replicator_class.verification_failed_count)
print "#{replicator_class.checksummed_count}/#{replicator_class.registry_count} " print "#{replicator_class.verified_count}/#{replicator_class.registry_count} "
puts using_percentage(current_node_status.checksummed_in_percentage_for(replicator_class)) puts using_percentage(current_node_status.verified_in_percentage_for(replicator_class))
end end
end end
......
...@@ -48,36 +48,44 @@ ...@@ -48,36 +48,44 @@
"wikis_checksummed_in_percentage", "wikis_checksummed_in_percentage",
"merge_request_diffs_count", "merge_request_diffs_count",
"merge_request_diffs_checksum_failed_count", "merge_request_diffs_checksum_failed_count",
"merge_request_diffs_checksummed_in_percentage",
"merge_request_diffs_checksummed_count", "merge_request_diffs_checksummed_count",
"merge_request_diffs_registry_count", "merge_request_diffs_registry_count",
"merge_request_diffs_failed_count", "merge_request_diffs_failed_count",
"merge_request_diffs_synced_count", "merge_request_diffs_synced_count",
"merge_request_diffs_synced_in_percentage", "merge_request_diffs_synced_in_percentage",
"merge_request_diffs_verification_failed_count",
"merge_request_diffs_verified_count",
"merge_request_diffs_verified_in_percentage",
"package_files_count", "package_files_count",
"package_files_checksum_failed_count", "package_files_checksum_failed_count",
"package_files_checksummed_in_percentage",
"package_files_checksummed_count", "package_files_checksummed_count",
"package_files_registry_count", "package_files_registry_count",
"package_files_failed_count", "package_files_failed_count",
"package_files_synced_count", "package_files_synced_count",
"package_files_synced_in_percentage", "package_files_synced_in_percentage",
"package_files_verification_failed_count",
"package_files_verified_count",
"package_files_verified_in_percentage",
"terraform_state_versions_count", "terraform_state_versions_count",
"terraform_state_versions_checksum_failed_count", "terraform_state_versions_checksum_failed_count",
"terraform_state_versions_checksummed_in_percentage",
"terraform_state_versions_checksummed_count", "terraform_state_versions_checksummed_count",
"terraform_state_versions_registry_count", "terraform_state_versions_registry_count",
"terraform_state_versions_failed_count", "terraform_state_versions_failed_count",
"terraform_state_versions_synced_count", "terraform_state_versions_synced_count",
"terraform_state_versions_synced_in_percentage", "terraform_state_versions_synced_in_percentage",
"terraform_state_versions_verification_failed_count",
"terraform_state_versions_verified_count",
"terraform_state_versions_verified_in_percentage",
"snippet_repositories_count", "snippet_repositories_count",
"snippet_repositories_checksum_failed_count", "snippet_repositories_checksum_failed_count",
"snippet_repositories_checksummed_in_percentage",
"snippet_repositories_checksummed_count", "snippet_repositories_checksummed_count",
"snippet_repositories_registry_count", "snippet_repositories_registry_count",
"snippet_repositories_failed_count", "snippet_repositories_failed_count",
"snippet_repositories_synced_count", "snippet_repositories_synced_count",
"snippet_repositories_synced_in_percentage", "snippet_repositories_synced_in_percentage",
"snippet_repositories_verification_failed_count",
"snippet_repositories_verified_count",
"snippet_repositories_verified_in_percentage",
"repositories_verified_count", "repositories_verified_count",
"repositories_verification_failed_count", "repositories_verification_failed_count",
"repositories_verified_in_percentage", "repositories_verified_in_percentage",
...@@ -166,7 +174,9 @@ ...@@ -166,7 +174,9 @@
"merge_request_diffs_failed_count": { "type": ["integer", "null"] }, "merge_request_diffs_failed_count": { "type": ["integer", "null"] },
"merge_request_diffs_synced_count": { "type": ["integer", "null"] }, "merge_request_diffs_synced_count": { "type": ["integer", "null"] },
"merge_request_diffs_synced_in_percentage": { "type": "string" }, "merge_request_diffs_synced_in_percentage": { "type": "string" },
"merge_request_diffs_checksummed_in_percentage": { "type": "string" }, "merge_request_diffs_verification_failed_count": { "type": ["integer", "null"] },
"merge_request_diffs_verified_count": { "type": ["integer", "null"] },
"merge_request_diffs_verified_in_percentage": { "type": "string" },
"package_files_count": { "type": ["integer", "null"] }, "package_files_count": { "type": ["integer", "null"] },
"package_files_checksummed_count": { "type": ["integer", "null"] }, "package_files_checksummed_count": { "type": ["integer", "null"] },
"package_files_checksum_failed_count": { "type": ["integer", "null"] }, "package_files_checksum_failed_count": { "type": ["integer", "null"] },
...@@ -174,7 +184,9 @@ ...@@ -174,7 +184,9 @@
"package_files_failed_count": { "type": ["integer", "null"] }, "package_files_failed_count": { "type": ["integer", "null"] },
"package_files_synced_count": { "type": ["integer", "null"] }, "package_files_synced_count": { "type": ["integer", "null"] },
"package_files_synced_in_percentage": { "type": "string" }, "package_files_synced_in_percentage": { "type": "string" },
"package_files_checksummed_in_percentage": { "type": "string" }, "package_files_verification_failed_count": { "type": ["integer", "null"] },
"package_files_verified_count": { "type": ["integer", "null"] },
"package_files_verified_in_percentage": { "type": "string" },
"terraform_state_versions_count": { "type": ["integer", "null"] }, "terraform_state_versions_count": { "type": ["integer", "null"] },
"terraform_state_versions_checksummed_count": { "type": ["integer", "null"] }, "terraform_state_versions_checksummed_count": { "type": ["integer", "null"] },
"terraform_state_versions_checksum_failed_count": { "type": ["integer", "null"] }, "terraform_state_versions_checksum_failed_count": { "type": ["integer", "null"] },
...@@ -182,7 +194,9 @@ ...@@ -182,7 +194,9 @@
"terraform_state_versions_failed_count": { "type": ["integer", "null"] }, "terraform_state_versions_failed_count": { "type": ["integer", "null"] },
"terraform_state_versions_synced_count": { "type": ["integer", "null"] }, "terraform_state_versions_synced_count": { "type": ["integer", "null"] },
"terraform_state_versions_synced_in_percentage": { "type": "string" }, "terraform_state_versions_synced_in_percentage": { "type": "string" },
"terraform_state_versions_checksummed_in_percentage": { "type": "string" }, "terraform_state_versions_verification_failed_count": { "type": ["integer", "null"] },
"terraform_state_versions_verified_count": { "type": ["integer", "null"] },
"terraform_state_versions_verified_in_percentage": { "type": "string" },
"snippet_repositories_count": { "type": ["integer", "null"] }, "snippet_repositories_count": { "type": ["integer", "null"] },
"snippet_repositories_checksummed_count": { "type": ["integer", "null"] }, "snippet_repositories_checksummed_count": { "type": ["integer", "null"] },
"snippet_repositories_checksum_failed_count": { "type": ["integer", "null"] }, "snippet_repositories_checksum_failed_count": { "type": ["integer", "null"] },
...@@ -190,7 +204,9 @@ ...@@ -190,7 +204,9 @@
"snippet_repositories_failed_count": { "type": ["integer", "null"] }, "snippet_repositories_failed_count": { "type": ["integer", "null"] },
"snippet_repositories_synced_count": { "type": ["integer", "null"] }, "snippet_repositories_synced_count": { "type": ["integer", "null"] },
"snippet_repositories_synced_in_percentage": { "type": "string" }, "snippet_repositories_synced_in_percentage": { "type": "string" },
"snippet_repositories_checksummed_in_percentage": { "type": "string" }, "snippet_repositories_verification_failed_count": { "type": ["integer", "null"] },
"snippet_repositories_verified_count": { "type": ["integer", "null"] },
"snippet_repositories_verified_in_percentage": { "type": "string" },
"repositories_verified_count": { "type": ["integer", "null"] }, "repositories_verified_count": { "type": ["integer", "null"] },
"repositories_verification_failed_count": { "type": ["integer", "null"] }, "repositories_verification_failed_count": { "type": ["integer", "null"] },
"repositories_verified_in_percentage": { "type": "string" }, "repositories_verified_in_percentage": { "type": "string" },
......
...@@ -36,9 +36,8 @@ RSpec.describe Gitlab::Geo::GeoNodeStatusCheck do ...@@ -36,9 +36,8 @@ RSpec.describe Gitlab::Geo::GeoNodeStatusCheck do
end end
context 'replicators' do context 'replicators' do
let(:replicators) { Gitlab::Geo.enabled_replicator_classes }
context 'replication' do context 'replication' do
let(:replicators) { Gitlab::Geo.enabled_replicator_classes }
let(:checks) do let(:checks) do
replicators.map { |k| /#{k.replicable_title_plural}:/ } replicators.map { |k| /#{k.replicable_title_plural}:/ }
end end
...@@ -51,8 +50,9 @@ RSpec.describe Gitlab::Geo::GeoNodeStatusCheck do ...@@ -51,8 +50,9 @@ RSpec.describe Gitlab::Geo::GeoNodeStatusCheck do
end end
context 'verification' do context 'verification' do
let(:replicators) { Gitlab::Geo.verification_enabled_replicator_classes }
let(:checks) do let(:checks) do
replicators.map { |k| /#{k.replicable_title_plural} Checked:/ } replicators.map { |k| /#{k.replicable_title_plural} Verified:/ }
end end
context 'when verification is enabled' do context 'when verification is enabled' do
......
...@@ -1200,15 +1200,18 @@ RSpec.describe GeoNodeStatus, :geo do ...@@ -1200,15 +1200,18 @@ RSpec.describe GeoNodeStatus, :geo do
end end
context 'verification' do context 'verification' do
context 'on the primary' do
let(:checksummed_count_method) { "#{replicable_name}_checksummed_count" } let(:checksummed_count_method) { "#{replicable_name}_checksummed_count" }
let(:checksum_failed_count_method) { "#{replicable_name}_checksum_failed_count" } let(:checksum_failed_count_method) { "#{replicable_name}_checksum_failed_count" }
let(:checksummed_in_percentage_method) { "#{replicable_name}_checksummed_in_percentage" }
before do
stub_current_geo_node(primary)
end
context 'when verification is enabled' do context 'when verification is enabled' do
before do before do
skip "#{replicator.model} does not include the VerificationState concern yet" unless replicator.model.respond_to?(:verification_state) skip "#{replicator.model} does not include the VerificationState concern yet" unless replicator.model.respond_to?(:verification_state)
stub_current_geo_node(primary)
allow(replicator).to receive(:verification_enabled?).and_return(true) allow(replicator).to receive(:verification_enabled?).and_return(true)
end end
...@@ -1230,12 +1233,6 @@ RSpec.describe GeoNodeStatus, :geo do ...@@ -1230,12 +1233,6 @@ RSpec.describe GeoNodeStatus, :geo do
expect(subject.send(checksum_failed_count_method)).to eq(1) expect(subject.send(checksum_failed_count_method)).to eq(1)
end end
end end
describe '#<replicable_name>_checksummed_in_percentage' do
it 'returns the right percentage' do
expect(subject.send(checksummed_in_percentage_method)).to be_within(0.01).of(66.67)
end
end
end end
context 'when there are no replicables' do context 'when there are no replicables' do
...@@ -1250,18 +1247,11 @@ RSpec.describe GeoNodeStatus, :geo do ...@@ -1250,18 +1247,11 @@ RSpec.describe GeoNodeStatus, :geo do
expect(subject.send(checksum_failed_count_method)).to eq(0) expect(subject.send(checksum_failed_count_method)).to eq(0)
end end
end end
describe '#<replicable_name>_checksummed_in_percentage' do
it 'returns 0' do
expect(subject.send(checksummed_in_percentage_method)).to eq(0)
end
end
end end
end end
context 'when verification is disabled' do context 'when verification is disabled' do
before do before do
stub_current_geo_node(primary)
allow(replicator).to receive(:verification_enabled?).and_return(false) allow(replicator).to receive(:verification_enabled?).and_return(false)
end end
...@@ -1276,10 +1266,93 @@ RSpec.describe GeoNodeStatus, :geo do ...@@ -1276,10 +1266,93 @@ RSpec.describe GeoNodeStatus, :geo do
expect(subject.send(checksum_failed_count_method)).to be_nil expect(subject.send(checksum_failed_count_method)).to be_nil
end end
end end
end
end
context 'on the secondary' do
let(:verified_count_method) { "#{replicable_name}_verified_count" }
let(:verification_failed_count_method) { "#{replicable_name}_verification_failed_count" }
let(:verified_in_percentage_method) { "#{replicable_name}_verified_in_percentage" }
before do
stub_current_geo_node(secondary)
end
context 'when verification is enabled' do
before do
skip "#{replicator.registry_class} does not include the VerificationState concern yet" unless replicator.registry_class.respond_to?(:verification_state)
allow(replicator).to receive(:verification_enabled?).and_return(true)
end
context 'when there are replicables' do
before do
create(model_factory, :verification_succeeded)
create(model_factory, :verification_succeeded)
create(model_factory, :verification_failed)
end
describe '#<replicable_name>_verified_count' do
it 'returns the right number of checksummed replicables' do
expect(subject.send(verified_count_method)).to eq(2)
end
end
describe '#<replicable_name>_verification_failed_count' do
it 'returns the right number of failed replicables' do
expect(subject.send(verification_failed_count_method)).to eq(1)
end
end
describe '#<replicable_name>_verified_in_percentage' do
it 'returns the right percentage' do
expect(subject.send(verified_in_percentage_method)).to be_within(0.01).of(66.67)
end
end
end
describe '#<replicable_name>_checksummed_in_percentage' do context 'when there are no replicables' do
describe '#<replicable_name>_verified_count' do
it 'returns 0' do
expect(subject.send(verified_count_method)).to eq(0)
end
end
describe '#<replicable_name>_verification_failed_count' do
it 'returns 0' do it 'returns 0' do
expect(subject.send(checksummed_in_percentage_method)).to eq(0) expect(subject.send(verification_failed_count_method)).to eq(0)
end
end
describe '#<replicable_name>_verified_in_percentage' do
it 'returns 0' do
expect(subject.send(verified_in_percentage_method)).to eq(0)
end
end
end
end
context 'when verification is disabled' do
before do
allow(replicator).to receive(:verification_enabled?).and_return(false)
end
describe '#<replicable_name>_verified_count' do
it 'returns nil' do
expect(subject.send(verified_count_method)).to be_nil
end
end
describe '#<replicable_name>_verification_failed_count' do
it 'returns nil' do
expect(subject.send(verification_failed_count_method)).to be_nil
end
end
describe '#<replicable_name>_verified_in_percentage' do
it 'returns 0' do
expect(subject.send(verified_in_percentage_method)).to eq(0)
end
end end
end end
end end
......
...@@ -364,7 +364,7 @@ RSpec.describe 'geo rake tasks', :geo do ...@@ -364,7 +364,7 @@ RSpec.describe 'geo rake tasks', :geo do
/Repositories Checked: /, /Repositories Checked: /,
/Last event ID seen from primary: /, /Last event ID seen from primary: /,
/Last status report was: / /Last status report was: /
] + Gitlab::Geo.enabled_replicator_classes.map { |k| /#{k.replicable_title_plural} Checked:/ } + ] + Gitlab::Geo.verification_enabled_replicator_classes.map { |k| /#{k.replicable_title_plural} Verified:/ } +
Gitlab::Geo.enabled_replicator_classes.map { |k| /#{k.replicable_title_plural}:/ } Gitlab::Geo.enabled_replicator_classes.map { |k| /#{k.replicable_title_plural}:/ }
checks.each do |text| checks.each do |text|
......
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