debian-mirror-gitlab/spec/models/postgresql/replication_slot_spec.rb

127 lines
3.7 KiB
Ruby
Raw Normal View History

2018-11-18 11:00:15 +05:30
# frozen_string_literal: true
require 'spec_helper'
2020-07-28 23:09:34 +05:30
RSpec.describe Postgresql::ReplicationSlot do
2022-01-26 12:08:38 +05:30
it { is_expected.to be_a Gitlab::Database::SharedModel }
2018-12-13 13:39:08 +05:30
describe '.in_use?' do
it 'returns true when replication slots are present' do
expect(described_class).to receive(:exists?).and_return(true)
expect(described_class.in_use?).to be_truthy
end
it 'returns false when replication slots are not present' do
expect(described_class.in_use?).to be_falsey
end
it 'returns false if the existence check is invalid' do
expect(described_class).to receive(:exists?).and_raise(ActiveRecord::StatementInvalid.new('PG::FeatureNotSupported'))
expect(described_class.in_use?).to be_falsey
end
end
2018-11-18 11:00:15 +05:30
describe '.lag_too_great?' do
2018-12-13 13:39:08 +05:30
before do
expect(described_class).to receive(:in_use?).and_return(true)
end
2021-09-04 01:27:46 +05:30
it 'does not raise an exception' do
expect { described_class.lag_too_great? }.not_to raise_error
end
2018-11-18 11:00:15 +05:30
it 'returns true when replication lag is too great' do
expect(described_class)
.to receive(:pluck)
.and_return([125.megabytes])
expect(described_class.lag_too_great?).to eq(true)
end
it 'returns false when more than one replicas is up to date enough' do
expect(described_class)
.to receive(:pluck)
.and_return([125.megabytes, 0.megabytes, 0.megabytes])
expect(described_class.lag_too_great?).to eq(false)
end
it 'returns false when replication lag is not too great' do
expect(described_class)
.to receive(:pluck)
.and_return([0.megabytes])
expect(described_class.lag_too_great?).to eq(false)
end
2019-09-30 21:07:59 +05:30
it 'returns false when there is a nil replication lag' do
expect(described_class)
.to receive(:pluck)
.and_return([0.megabytes, nil])
expect(described_class.lag_too_great?).to eq(false)
end
2018-11-18 11:00:15 +05:30
end
2021-10-27 15:23:28 +05:30
describe '#max_replication_slots' do
it 'returns the maximum number of replication slots' do
expect(described_class.max_replication_slots).to be >= 0
end
end
context 'with enough slots available' do
skip_examples = described_class.max_replication_slots <= described_class.count
before(:all) do
skip('max_replication_slots too small') if skip_examples
2022-01-26 12:08:38 +05:30
@current_slot_count = described_class
2021-10-27 15:23:28 +05:30
.connection
2022-01-26 12:08:38 +05:30
.select_value("SELECT COUNT(*) FROM pg_replication_slots")
2021-10-27 15:23:28 +05:30
2022-01-26 12:08:38 +05:30
@current_unused_count = described_class
2021-10-27 15:23:28 +05:30
.connection
2022-01-26 12:08:38 +05:30
.select_value("SELECT COUNT(*) FROM pg_replication_slots WHERE active = 'f';")
2021-10-27 15:23:28 +05:30
2022-01-26 12:08:38 +05:30
described_class
2021-10-27 15:23:28 +05:30
.connection
.execute("SELECT * FROM pg_create_physical_replication_slot('test_slot');")
end
after(:all) do
unless skip_examples
2022-01-26 12:08:38 +05:30
described_class
2021-10-27 15:23:28 +05:30
.connection
.execute("SELECT pg_drop_replication_slot('test_slot');")
end
end
describe '#slots_count' do
it 'returns the number of replication slots' do
expect(described_class.count).to eq(@current_slot_count + 1)
end
end
describe '#unused_slots_count' do
it 'returns the number of unused replication slots' do
expect(described_class.unused_slots_count).to eq(@current_unused_count + 1)
end
end
describe '#max_retained_wal' do
it 'returns the retained WAL size' do
expect(described_class.max_retained_wal).not_to be_nil
end
end
describe '#slots_retained_bytes' do
it 'returns the number of retained bytes' do
2022-08-27 11:52:29 +05:30
slot = described_class.slots_retained_bytes.find { |x| x['slot_name'] == 'test_slot' }
2021-10-27 15:23:28 +05:30
expect(slot).not_to be_nil
expect(slot['retained_bytes']).to be_nil
end
end
end
2018-11-18 11:00:15 +05:30
end