summaryrefslogtreecommitdiff
path: root/spec/finders/ci/runner_jobs_finder_spec.rb
blob: 755b21ec08fa8ebfc3aa322f8742d83288cd40e1 (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
106
107
108
109
110
111
112
# frozen_string_literal: true

require 'spec_helper'

RSpec.describe Ci::RunnerJobsFinder do
  let(:project) { create(:project) }
  let(:runner) { create(:ci_runner, :instance) }
  let(:user) { create(:user) }
  let(:params) { {} }

  subject { described_class.new(runner, user, params).execute }

  before do
    project.add_developer(user)
  end

  describe '#execute' do
    context 'when params is empty' do
      let!(:job) { create(:ci_build, runner: runner, project: project) }
      let!(:job1) { create(:ci_build, project: project) }

      it 'returns all jobs assigned to Runner' do
        is_expected.to match_array(job)
        is_expected.not_to match_array(job1)
      end
    end

    context 'when the user has guest access' do
      it 'does not returns jobs the user does not have permission to see' do
        another_project = create(:project)
        job = create(:ci_build, runner: runner, project: another_project)

        another_project.add_guest(user)

        is_expected.not_to match_array(job)
      end
    end

    context 'when the user has permission to read all resources' do
      let(:user) { create(:user, :admin) }

      it 'returns all the jobs assigned to a runner' do
        jobs = create_list(:ci_build, 5, runner: runner, project: project)

        is_expected.to match_array(jobs)
      end
    end

    context 'when the user has different access levels in different projects' do
      it 'returns only the jobs the user has permission to see' do
        guest_project = create(:project)
        reporter_project = create(:project)

        _guest_jobs = create_list(:ci_build, 2, runner: runner, project: guest_project)
        reporter_jobs = create_list(:ci_build, 3, runner: runner, project: reporter_project)

        guest_project.add_guest(user)
        reporter_project.add_reporter(user)

        is_expected.to match_array(reporter_jobs)
      end
    end

    context 'when the user has reporter access level or greater' do
      it 'returns jobs assigned to the Runner that the user has accesss to' do
        jobs = create_list(:ci_build, 3, runner: runner, project: project)

        is_expected.to match_array(jobs)
      end
    end

    context 'when params contains status' do
      Ci::HasStatus::AVAILABLE_STATUSES.each do |target_status|
        context "when status is #{target_status}" do
          let(:params) { { status: target_status } }
          let!(:job) { create(:ci_build, runner: runner, project: project, status: target_status) }

          before do
            exception_status = Ci::HasStatus::AVAILABLE_STATUSES - [target_status]
            create(:ci_build, runner: runner, project: project, status: exception_status.first)
          end

          it 'returns matched job' do
            is_expected.to eq([job])
          end
        end
      end
    end

    context 'when order_by and sort are specified' do
      context 'when order_by id and sort is asc' do
        let(:params) { { order_by: 'id', sort: 'asc' } }
        let!(:jobs) { create_list(:ci_build, 2, runner: runner, project: project, user: create(:user)) }

        it 'sorts as id: :asc' do
          is_expected.to eq(jobs.sort_by(&:id))
        end
      end
    end

    context 'when order_by is specified and sort is not specified' do
      context 'when order_by id and sort is not specified' do
        let(:params) { { order_by: 'id' } }
        let!(:jobs) { create_list(:ci_build, 2, runner: runner, project: project, user: create(:user)) }

        it 'sorts as id: :desc' do
          is_expected.to eq(jobs.sort_by(&:id).reverse)
        end
      end
    end
  end
end