summaryrefslogtreecommitdiff
path: root/spec/graphql/resolvers/terraform/states_resolver_spec.rb
blob: 012c74ce398773df84d5a283f82990346c499a13 (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
# frozen_string_literal: true

require 'spec_helper'

RSpec.describe Resolvers::Terraform::StatesResolver do
  include GraphqlHelpers

  it { expect(described_class).to have_nullable_graphql_type(Types::Terraform::StateType.connection_type) }
  it { expect(described_class.null).to be_truthy }

  describe '#resolve' do
    let_it_be(:project) { create(:project) }

    let_it_be(:production_state) { create(:terraform_state, project: project) }
    let_it_be(:staging_state) { create(:terraform_state, project: project) }
    let_it_be(:other_state) { create(:terraform_state) }

    let(:ctx) { Hash(current_user: user) }
    let(:user) { create(:user, developer_projects: [project]) }

    subject { resolve(described_class, obj: project, ctx: ctx) }

    it 'returns states associated with the agent' do
      expect(subject).to contain_exactly(production_state, staging_state)
    end

    context 'user does not have permission' do
      let(:user) { create(:user) }

      it { is_expected.to be_empty }
    end
  end
end

RSpec.describe Resolvers::Terraform::StatesResolver.single do
  it { expect(described_class).to be < Resolvers::Terraform::StatesResolver }

  describe 'arguments' do
    subject { described_class.arguments[argument] }

    describe 'name' do
      let(:argument) { 'name' }

      it do
        expect(subject).to be_present
        expect(subject.type).to be_kind_of GraphQL::Schema::NonNull
        expect(subject.type.unwrap).to eq GraphQL::Types::String
        expect(subject.description).to be_present
      end
    end
  end
end