blob: 1706fcf76ae5ba2739f0f41107f5d48f6f1040a1 (
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
|
# frozen_string_literal: true
require 'spec_helper'
RSpec.describe ContainerRegistry::Protection::Rule, type: :model, feature_category: :container_registry do
it_behaves_like 'having unique enum values'
describe 'relationships' do
it { is_expected.to belong_to(:project).inverse_of(:container_registry_protection_rules) }
end
describe 'enums' do
it {
is_expected.to(
define_enum_for(:push_protected_up_to_access_level)
.with_values(
developer: Gitlab::Access::DEVELOPER,
maintainer: Gitlab::Access::MAINTAINER,
owner: Gitlab::Access::OWNER
)
.with_prefix(:push_protected_up_to)
)
}
it {
is_expected.to(
define_enum_for(:delete_protected_up_to_access_level)
.with_values(
developer: Gitlab::Access::DEVELOPER,
maintainer: Gitlab::Access::MAINTAINER,
owner: Gitlab::Access::OWNER
)
.with_prefix(:delete_protected_up_to)
)
}
end
describe 'validations' do
subject { build(:container_registry_protection_rule) }
describe '#repository_path_pattern' do
it { is_expected.to validate_presence_of(:repository_path_pattern) }
it { is_expected.to validate_length_of(:repository_path_pattern).is_at_most(255) }
end
describe '#delete_protected_up_to_access_level' do
it { is_expected.to validate_presence_of(:delete_protected_up_to_access_level) }
end
describe '#push_protected_up_to_access_level' do
it { is_expected.to validate_presence_of(:push_protected_up_to_access_level) }
end
end
end
|