37 lines
1.5 KiB
Ruby
37 lines
1.5 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
require 'spec_helper'
|
|
|
|
RSpec.describe ProtectedBranch::PushAccessLevel do
|
|
it { is_expected.to validate_inclusion_of(:access_level).in_array([Gitlab::Access::MAINTAINER, Gitlab::Access::DEVELOPER, Gitlab::Access::NO_ACCESS]) }
|
|
|
|
describe 'associations' do
|
|
it { is_expected.to belong_to(:deploy_key) }
|
|
end
|
|
|
|
describe 'validations' do
|
|
it 'is not valid when a record exists with the same access level' do
|
|
protected_branch = create(:protected_branch)
|
|
create(:protected_branch_push_access_level, protected_branch: protected_branch)
|
|
level = build(:protected_branch_push_access_level, protected_branch: protected_branch)
|
|
|
|
expect(level).to be_invalid
|
|
end
|
|
|
|
it 'is not valid when a record exists with the same access level' do
|
|
protected_branch = create(:protected_branch)
|
|
deploy_key = create(:deploy_key, projects: [protected_branch.project])
|
|
create(:protected_branch_push_access_level, protected_branch: protected_branch, deploy_key: deploy_key)
|
|
level = build(:protected_branch_push_access_level, protected_branch: protected_branch, deploy_key: deploy_key)
|
|
|
|
expect(level).to be_invalid
|
|
end
|
|
|
|
it 'checks that a deploy key is enabled for the same project as the protected branch\'s' do
|
|
level = build(:protected_branch_push_access_level, deploy_key: create(:deploy_key))
|
|
|
|
expect { level.save! }.to raise_error
|
|
expect(level.errors.full_messages).to contain_exactly('Deploy key is not enabled for this project')
|
|
end
|
|
end
|
|
end
|