summaryrefslogtreecommitdiff
path: root/spec/graphql/resolvers/design_management/design_resolver_spec.rb
blob: e33eaedf1673e1df6db8f65f80eaca0d5a3a63e9 (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
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
# frozen_string_literal: true

require 'spec_helper'

RSpec.describe Resolvers::DesignManagement::DesignResolver do
  include GraphqlHelpers
  include DesignManagementTestHelpers

  specify do
    expect(described_class).to have_nullable_graphql_type(::Types::DesignManagement::DesignType)
  end

  before do
    enable_design_management
  end

  describe '#resolve' do
    let_it_be(:issue) { create(:issue) }
    let_it_be(:project) { issue.project }
    let_it_be(:first_version) { create(:design_version) }
    let_it_be(:first_design) { create(:design, issue: issue, versions: [first_version]) }
    let_it_be(:current_user) { create(:user) }
    let_it_be(:design_on_other_issue) do
      create(:design, issue: create(:issue, project: project), versions: [create(:design_version)])
    end

    let(:args) { { id: GitlabSchema.id_from_object(first_design).to_s } }
    let(:gql_context) { { current_user: current_user } }

    before do
      project.add_developer(current_user)
    end

    context 'when the user cannot see designs' do
      let(:gql_context) { { current_user: create(:user) } }

      it 'returns nothing' do
        expect(resolve_design).to be_nil
      end
    end

    context 'when no argument has been passed' do
      let(:args) { {} }

      it 'raises an error' do
        expect { resolve_design }.to raise_error(::Gitlab::Graphql::Errors::ArgumentError, /must/)
      end
    end

    context 'when both arguments have been passed' do
      let(:args) { { filename: first_design.filename, id: GitlabSchema.id_from_object(first_design).to_s } }

      it 'raises an error' do
        expect { resolve_design }.to raise_error(::Gitlab::Graphql::Errors::ArgumentError, /may/)
      end
    end

    context 'by ID' do
      it 'returns the specified design' do
        expect(resolve_design).to eq(first_design)
      end

      context 'the ID belongs to a design on another issue' do
        let(:args) { { id: global_id_of(design_on_other_issue) } }

        it 'returns nothing' do
          expect(resolve_design).to be_nil
        end
      end

      context 'the ID does not belong to a design at all' do
        let(:args) { { id: global_id_of(issue) } }
        let(:msg) { /does not represent an instance of DesignManagement::Design/ }

        it 'complains meaningfully' do
          expect { resolve_design }.to raise_error(msg)
        end
      end
    end

    context 'by filename' do
      let(:args) { { filename: first_design.filename } }

      it 'returns the specified design' do
        expect(resolve_design).to eq(first_design)
      end

      context 'the filename belongs to a design on another issue' do
        let(:args) { { filename: design_on_other_issue.filename } }

        it 'returns nothing' do
          expect(resolve_design).to be_nil
        end
      end
    end
  end

  def resolve_design
    resolve(described_class, obj: issue.design_collection, args: args, ctx: gql_context)
  end
end