Welcome to mirror list, hosted at ThFree Co, Russian Federation.

design_at_version_resolver_spec.rb « design_management « resolvers « graphql « spec - gitlab.com/gitlab-org/gitlab-foss.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
blob: 4bdef49499c58d5841d3fcea307ef28c10cd7ed0 (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
# frozen_string_literal: true

require 'spec_helper'

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

  let_it_be(:issue) { create(:issue) }
  let_it_be(:project) { issue.project }
  let_it_be(:user) { create(:user) }
  let_it_be(:design_a) { create(:design, issue: issue) }
  let_it_be(:version_a) { create(:design_version, issue: issue, created_designs: [design_a]) }

  let(:current_user) { user }
  let(:object) { issue.design_collection }
  let(:global_id) { GitlabSchema.id_from_object(design_at_version).to_s }

  let(:design_at_version) { ::DesignManagement::DesignAtVersion.new(design: design_a, version: version_a) }

  let(:resource_not_available) { ::Gitlab::Graphql::Errors::ResourceNotAvailable }

  before do
    enable_design_management
    project.add_developer(user)
  end

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

      it 'raises ResourceNotAvailable' do
        expect { resolve_design }.to raise_error(resource_not_available)
      end
    end

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

    context 'the ID belongs to a design on another issue' do
      let(:other_dav) do
        create(:design_at_version, issue: create(:issue, project: project))
      end

      let(:global_id) { global_id_of(other_dav) }

      it 'raises ResourceNotAvailable' do
        expect { resolve_design }.to raise_error(resource_not_available)
      end

      context 'the current object does not constrain the issue' do
        let(:object) { nil }

        it 'returns the object' do
          expect(resolve_design).to eq(other_dav)
        end
      end
    end
  end

  private

  def resolve_design
    args = { id: global_id }
    ctx = { current_user: current_user }
    eager_resolve(described_class, obj: object, args: args, ctx: ctx)
  end
end