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

designs_finder_spec.rb « design_management « finders « spec - gitlab.com/gitlab-org/gitlab-foss.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
blob: 04bd0ad0a45e22f27f97d3c3f0e44ef551de31a7 (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
102
103
104
105
# frozen_string_literal: true

require 'spec_helper'

describe DesignManagement::DesignsFinder do
  include DesignManagementTestHelpers

  let_it_be(:user) { create(:user) }
  let_it_be(:project) { create(:project, :private) }
  let_it_be(:issue) { create(:issue, project: project) }
  let_it_be(:design1) { create(:design, :with_file, issue: issue, versions_count: 1) }
  let_it_be(:design2) { create(:design, :with_file, issue: issue, versions_count: 1) }
  let_it_be(:design3) { create(:design, :with_file, issue: issue, versions_count: 1) }
  let(:params) { {} }

  subject(:designs) { described_class.new(issue, user, params).execute }

  describe '#execute' do
    context 'when user can not read designs of an issue' do
      it 'returns no results' do
        is_expected.to be_empty
      end
    end

    context 'when user can read designs of an issue' do
      before do
        project.add_developer(user)
      end

      context 'when design management feature is disabled' do
        it 'returns no results' do
          is_expected.to be_empty
        end
      end

      context 'when design management feature is enabled' do
        before do
          enable_design_management
        end

        it 'returns the designs' do
          is_expected.to contain_exactly(design1, design2, design3)
        end

        context 'when argument is the ids of designs' do
          let(:params) { { ids: [design1.id] } }

          it { is_expected.to eq([design1]) }
        end

        context 'when argument is the filenames of designs' do
          let(:params) { { filenames: [design2.filename] } }

          it { is_expected.to eq([design2]) }
        end

        context 'when passed empty array' do
          context 'for filenames' do
            let(:params) { { filenames: [] } }

            it { is_expected.to be_empty }
          end

          context "for ids" do
            let(:params) { { ids: [] } }

            it { is_expected.to be_empty }
          end
        end

        describe 'returning designs that existed at a particular given version' do
          let(:all_versions) { issue.design_collection.versions.ordered }
          let(:first_version) { all_versions.last }
          let(:second_version) { all_versions.second }

          context 'when argument is the first version' do
            let(:params) { { visible_at_version: first_version } }

            it { is_expected.to eq([design1]) }
          end

          context 'when arguments are version and id' do
            context 'when id is absent at version' do
              let(:params) { { visible_at_version: first_version, ids: [design2.id] } }

              it { is_expected.to eq([]) }
            end

            context 'when id is present at version' do
              let(:params) { { visible_at_version: second_version, ids: [design2.id] } }

              it { is_expected.to eq([design2]) }
            end
          end

          context 'when argument is the second version' do
            let(:params) { { visible_at_version: second_version } }

            it { is_expected.to contain_exactly(design1, design2) }
          end
        end
      end
    end
  end
end