1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75
|
# frozen_string_literal: true
require 'spec_helper'
RSpec.describe SystemCheck::App::TableTruncateCheck, feature_category: :cell do
context 'when running on single databases' do
before do
skip_if_database_exists(:ci)
end
describe '#skip?' do
subject { described_class.new.skip? }
it { is_expected.to eq(true) }
end
end
context 'when running on multiple databases' do
let(:needs_truncation) { true }
before do
skip_if_shared_database(:ci)
allow_next_instances_of(Gitlab::Database::TablesTruncate, 2) do |instance|
allow(instance).to receive(:needs_truncation?).and_return(needs_truncation)
end
end
describe '#skip?' do
subject { described_class.new.skip? }
it { is_expected.to eq(false) }
end
describe '#check?' do
subject { described_class.new.check? }
context 'when TableTruncate returns false' do
let(:needs_truncation) { false }
it { is_expected.to eq(true) }
end
context 'when TableTruncate returns true' do
let(:needs_truncation) { true }
it { is_expected.to eq(false) }
end
end
describe '#show_error' do
let(:needs_truncation) { true }
let(:checker) { described_class.new }
before do
checker.check?
end
subject(:show_error) { checker.show_error }
it 'outputs error information' do
expected = %r{
Try\sfixing\sit:\s+
sudo\s-u\s.+?\s-H\sbundle\sexec\srake\sgitlab:db:truncate_legacy_tables:main\s
gitlab:db:truncate_legacy_tables:ci\s+
For\smore\sinformation\ssee:\s+
doc/development/database/multiple_databases.md\sin\ssection\s'Truncating\stables'\s+
Please\sfix\sthe\serror\sabove\sand\srerun\sthe\schecks.\s+
}x
expect { show_error }.to output(expected).to_stdout
end
end
end
end
|