61 lines
1.6 KiB
Ruby
61 lines
1.6 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
require 'spec_helper'
|
|
|
|
RSpec.describe Mutations::Terraform::State::Unlock do
|
|
let_it_be(:user) { create(:user) }
|
|
let_it_be(:state) { create(:terraform_state, :locked) }
|
|
|
|
let(:mutation) do
|
|
described_class.new(
|
|
object: double,
|
|
context: { current_user: user },
|
|
field: double
|
|
)
|
|
end
|
|
|
|
it { expect(described_class.graphql_name).to eq('TerraformStateUnlock') }
|
|
it { expect(described_class).to require_graphql_authorizations(:admin_terraform_state) }
|
|
|
|
describe '#resolve' do
|
|
let(:global_id) { state.to_global_id }
|
|
|
|
subject { mutation.resolve(id: global_id) }
|
|
|
|
context 'user does not have permission' do
|
|
it 'raises an error', :aggregate_failures do
|
|
expect { subject }.to raise_error(Gitlab::Graphql::Errors::ResourceNotAvailable)
|
|
expect(state.reload).to be_locked
|
|
end
|
|
end
|
|
|
|
context 'user has permission' do
|
|
before do
|
|
state.project.add_maintainer(user)
|
|
end
|
|
|
|
it 'unlocks the state', :aggregate_failures do
|
|
expect(subject).to eq(errors: [])
|
|
expect(state.reload).not_to be_locked
|
|
end
|
|
|
|
context 'state is already unlocked' do
|
|
let(:state) { create(:terraform_state) }
|
|
|
|
it 'does not modify the state' do
|
|
expect(subject).to eq(errors: [])
|
|
expect(state.reload).not_to be_locked
|
|
end
|
|
end
|
|
end
|
|
|
|
context 'with invalid params' do
|
|
let(:global_id) { user.to_global_id }
|
|
|
|
it 'raises an error', :aggregate_failures do
|
|
expect { subject }.to raise_error(Gitlab::Graphql::Errors::ResourceNotAvailable)
|
|
expect(state.reload).to be_locked
|
|
end
|
|
end
|
|
end
|
|
end
|