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

resource_groups_spec.rb « ci « api « requests « spec - gitlab.com/gitlab-org/gitlab-foss.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
blob: 864c363e6d3bfe017e6ed3b0e92a6dab0596d0f0 (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
113
114
115
116
117
118
119
120
121
122
123
124
125
# frozen_string_literal: true

require 'spec_helper'

RSpec.describe API::Ci::ResourceGroups do
  let_it_be(:project) { create(:project) }
  let_it_be(:developer) { create(:user).tap { |u| project.add_developer(u) } }
  let_it_be(:reporter) { create(:user).tap { |u| project.add_reporter(u) } }

  let(:user) { developer }

  describe 'GET /projects/:id/resource_groups' do
    subject { get api("/projects/#{project.id}/resource_groups", user) }

    let!(:resource_groups) { create_list(:ci_resource_group, 3, project: project) }

    it 'returns all resource groups for this project', :aggregate_failures do
      subject

      expect(response).to have_gitlab_http_status(:ok)
      expect(response).to include_pagination_headers
      resource_groups.each_index do |i|
        expect(json_response[i]['id']).to eq(resource_groups[i].id)
        expect(json_response[i]['key']).to eq(resource_groups[i].key)
        expect(json_response[i]['process_mode']).to eq(resource_groups[i].process_mode)
        expect(Time.parse(json_response[i]['created_at'])).to be_like_time(resource_groups[i].created_at)
        expect(Time.parse(json_response[i]['updated_at'])).to be_like_time(resource_groups[i].updated_at)
      end
    end

    context 'when user is reporter' do
      let(:user) { reporter }

      it 'returns forbidden' do
        subject

        expect(response).to have_gitlab_http_status(:forbidden)
      end
    end
  end

  describe 'GET /projects/:id/resource_groups/:key' do
    subject { get api("/projects/#{project.id}/resource_groups/#{key}", user) }

    let!(:resource_group) { create(:ci_resource_group, project: project) }
    let(:key) { resource_group.key }

    it 'returns a resource group', :aggregate_failures do
      subject

      expect(response).to have_gitlab_http_status(:ok)
      expect(json_response['id']).to eq(resource_group.id)
      expect(json_response['key']).to eq(resource_group.key)
      expect(json_response['process_mode']).to eq(resource_group.process_mode)
      expect(Time.parse(json_response['created_at'])).to be_like_time(resource_group.created_at)
      expect(Time.parse(json_response['updated_at'])).to be_like_time(resource_group.updated_at)
    end

    context 'when user is reporter' do
      let(:user) { reporter }

      it 'returns forbidden' do
        subject

        expect(response).to have_gitlab_http_status(:forbidden)
      end
    end

    context 'when there is no corresponding resource group' do
      let(:key) { 'unknown' }

      it 'returns not found' do
        subject

        expect(response).to have_gitlab_http_status(:not_found)
      end
    end
  end

  describe 'PUT /projects/:id/resource_groups/:key' do
    subject { put api("/projects/#{project.id}/resource_groups/#{key}", user), params: params }

    let!(:resource_group) { create(:ci_resource_group, project: project) }
    let(:key) { resource_group.key }
    let(:params) { { process_mode: :oldest_first } }

    it 'changes the process mode of a resource group' do
      expect { subject }
        .to change { resource_group.reload.process_mode }.from('unordered').to('oldest_first')

      expect(response).to have_gitlab_http_status(:ok)
      expect(json_response['process_mode']).to eq('oldest_first')
    end

    context 'with invalid parameter' do
      let(:params) { { process_mode: :unknown } }

      it 'returns bad request' do
        subject

        expect(response).to have_gitlab_http_status(:bad_request)
      end
    end

    context 'when user is reporter' do
      let(:user) { reporter }

      it 'returns forbidden' do
        subject

        expect(response).to have_gitlab_http_status(:forbidden)
      end
    end

    context 'when there is no corresponding resource group' do
      let(:key) { 'unknown' }

      it 'returns not found' do
        subject

        expect(response).to have_gitlab_http_status(:not_found)
      end
    end
  end
end