blob: ba201d93f529384305866d471508c66375274d5f (
plain)
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
|
# frozen_string_literal: true
require 'spec_helper'
RSpec.describe Gitlab::Database::AsyncForeignKeys::PostgresAsyncForeignKeyValidation, type: :model,
feature_category: :database do
it { is_expected.to be_a Gitlab::Database::SharedModel }
describe 'validations' do
let_it_be(:fk_validation) { create(:postgres_async_foreign_key_validation) }
let(:identifier_limit) { described_class::MAX_IDENTIFIER_LENGTH }
let(:last_error_limit) { described_class::MAX_LAST_ERROR_LENGTH }
subject { fk_validation }
it { is_expected.to validate_presence_of(:name) }
it { is_expected.to validate_uniqueness_of(:name) }
it { is_expected.to validate_length_of(:name).is_at_most(identifier_limit) }
it { is_expected.to validate_presence_of(:table_name) }
it { is_expected.to validate_length_of(:table_name).is_at_most(identifier_limit) }
it { is_expected.to validate_length_of(:last_error).is_at_most(last_error_limit) }
end
describe 'scopes' do
let!(:failed_validation) { create(:postgres_async_foreign_key_validation, attempts: 1) }
let!(:new_validation) { create(:postgres_async_foreign_key_validation) }
describe '.ordered' do
subject { described_class.ordered }
it { is_expected.to eq([new_validation, failed_validation]) }
end
end
describe '#handle_exception!' do
let_it_be_with_reload(:fk_validation) { create(:postgres_async_foreign_key_validation) }
let(:error) { instance_double(StandardError, message: 'Oups', backtrace: %w[this that]) }
subject { fk_validation.handle_exception!(error) }
it 'increases the attempts number' do
expect { subject }.to change { fk_validation.reload.attempts }.by(1)
end
it 'saves error details' do
subject
expect(fk_validation.reload.last_error).to eq("Oups\nthis\nthat")
end
end
end
|