summaryrefslogtreecommitdiff
path: root/spec/graphql/resolvers/clusters/agent_tokens_resolver_spec.rb
blob: 866f4ce7b5a083d14750e0cc41b0151c570bf77e (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
# frozen_string_literal: true

require 'spec_helper'

RSpec.describe Resolvers::Clusters::AgentTokensResolver do
  include GraphqlHelpers

  it { expect(described_class.type).to eq(Types::Clusters::AgentTokenType) }
  it { expect(described_class.null).to be_truthy }
  it { expect(described_class.arguments.keys).to contain_exactly('status') }

  describe '#resolve' do
    let(:agent) { create(:cluster_agent) }
    let(:user) { create(:user, developer_projects: [agent.project]) }
    let(:ctx) { Hash(current_user: user) }

    let!(:matching_token1) { create(:cluster_agent_token, agent: agent, last_used_at: 5.days.ago) }
    let!(:matching_token2) { create(:cluster_agent_token, agent: agent, last_used_at: 2.days.ago) }
    let!(:other_token) { create(:cluster_agent_token) }

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

    it 'returns tokens associated with the agent, ordered by last_used_at' do
      expect(subject).to eq([matching_token2, matching_token1])
    end

    context 'token status is specified' do
      let!(:revoked_token) { create(:cluster_agent_token, :revoked, agent: agent) }

      subject { resolve(described_class, obj: agent, ctx: ctx, args: { status: 'revoked' }) }

      it { is_expected.to contain_exactly(revoked_token) }
    end

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

      before do
        agent.project.add_reporter(user)
      end

      it { is_expected.to be_empty }
    end
  end
end