d092ed178f
When there is an unused replication slot, the replication lag function will return a nil value, resulting in "NoMethodError: undefined method `>=' for nil:NilClass" error. We now just ignore these nil values. Closes https://gitlab.com/gitlab-org/gitlab-ce/issues/63666
59 lines
1.7 KiB
Ruby
59 lines
1.7 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
require 'spec_helper'
|
|
|
|
describe Postgresql::ReplicationSlot, :postgresql do
|
|
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
|
|
|
|
describe '.lag_too_great?' do
|
|
before do
|
|
expect(described_class).to receive(:in_use?).and_return(true)
|
|
end
|
|
|
|
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
|
|
|
|
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
|
|
end
|
|
end
|