db18993f65
Includes: - Model, factories, create service and controller actions - As usual, includes specs for everything - Builds UI (copy from PAT) - Add revoke action Closes #31591
45 lines
1.4 KiB
Ruby
45 lines
1.4 KiB
Ruby
require 'spec_helper'
|
|
|
|
describe DeployTokens::CreateService, :clean_gitlab_redis_shared_state do
|
|
let(:project) { create(:project) }
|
|
let(:user) { create(:user) }
|
|
let(:deploy_token_params) { attributes_for(:deploy_token) }
|
|
|
|
describe '#execute' do
|
|
subject { described_class.new(project, user, deploy_token_params) }
|
|
|
|
context 'when the deploy token is valid' do
|
|
it 'should create a new DeployToken' do
|
|
expect { subject.execute }.to change { DeployToken.count }.by(1)
|
|
end
|
|
|
|
it 'should assign the DeployToken to the project' do
|
|
subject.execute
|
|
|
|
expect(subject.project).to eq(project)
|
|
end
|
|
|
|
it 'should store the token on redis' do
|
|
subject.execute
|
|
redis_key = DeployToken.redis_shared_state_key(user.id)
|
|
|
|
expect(Gitlab::Redis::SharedState.with { |redis| redis.get(redis_key) }).not_to be_nil
|
|
end
|
|
end
|
|
|
|
context 'when the deploy token is invalid' do
|
|
let(:deploy_token_params) { attributes_for(:deploy_token, scopes: []) }
|
|
|
|
it 'it should not create a new DeployToken' do
|
|
expect { subject.execute }.not_to change { DeployToken.count }
|
|
end
|
|
|
|
it 'should not store the token on redis' do
|
|
subject.execute
|
|
redis_key = DeployToken.redis_shared_state_key(user.id)
|
|
|
|
expect(Gitlab::Redis::SharedState.with { |redis| redis.get(redis_key) }).to be_nil
|
|
end
|
|
end
|
|
end
|
|
end
|