blob: ca98c2597a29bd4e377dcc9efd9881c8eac64d0d (
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
53
54
55
56
57
58
59
60
61
62
63
64
65
|
# frozen_string_literal: true
# This shared example requires the following variables
# issuable_link
# issuable
# issuable_class
# issuable_link_factory
RSpec.shared_examples 'issuable link' do
describe 'Associations' do
it { is_expected.to belong_to(:source).class_name(issuable.class.name) }
it { is_expected.to belong_to(:target).class_name(issuable.class.name) }
end
describe 'Validation' do
subject { issuable_link }
it { is_expected.to validate_presence_of(:source) }
it { is_expected.to validate_presence_of(:target) }
it do
is_expected.to validate_uniqueness_of(:source)
.scoped_to(:target_id)
.with_message(/already related/)
end
it 'is not valid if an opposite link already exists' do
issuable_link = create_issuable_link(subject.target, subject.source)
expect(issuable_link).to be_invalid
expect(issuable_link.errors[:source]).to include("is already related to this #{issuable.class.name.downcase}")
end
context 'when it relates to itself' do
context 'when target is nil' do
it 'does not invalidate object with self relation error' do
issuable_link = create_issuable_link(issuable, nil)
issuable_link.valid?
expect(issuable_link.errors[:source]).to be_empty
end
end
context 'when source and target are present' do
it 'invalidates object' do
issuable_link = create_issuable_link(issuable, issuable)
expect(issuable_link).to be_invalid
expect(issuable_link.errors[:source]).to include('cannot be related to itself')
end
end
end
def create_issuable_link(source, target)
build(issuable_link_factory, source: source, target: target)
end
end
describe '.link_type' do
it { is_expected.to define_enum_for(:link_type).with_values(relates_to: 0, blocks: 1) }
it 'provides the "related" as default link_type' do
expect(issuable_link.link_type).to eq 'relates_to'
end
end
end
|