pipelines_controller_spec.rb 6.37 KB
Newer Older
1 2 3
require 'spec_helper'

describe Projects::PipelinesController do
4 5
  include ApiHelpers

6 7
  set(:user) { create(:user) }
  set(:project) { create(:project, :public, :repository) }
8
  let(:feature) { ProjectFeature::DISABLED }
9 10

  before do
11 12
    stub_not_protect_default_branch
    project.add_developer(user)
13
    project.project_feature.update(builds_access_level: feature)
14

15 16 17
    sign_in(user)
  end

18 19
  describe 'GET index.json' do
    before do
20 21 22 23
      %w(pending running created success).each_with_index do |status, index|
        sha = project.commit("HEAD~#{index}")
        create(:ci_empty_pipeline, status: status, project: project, sha: sha)
      end
24 25 26 27
    end

    subject do
      get :index, namespace_id: project.namespace, project_id: project, format: :json
28 29 30
    end

    it 'returns JSON with serialized pipelines' do
31 32
      subject

33
      expect(response).to have_gitlab_http_status(:ok)
34
      expect(response).to match_response_schema('pipeline')
35 36

      expect(json_response).to include('pipelines')
37 38 39 40 41
      expect(json_response['pipelines'].count).to eq 4
      expect(json_response['count']['all']).to eq 4
      expect(json_response['count']['running']).to eq 1
      expect(json_response['count']['pending']).to eq 1
      expect(json_response['count']['finished']).to eq 1
42
    end
43 44 45

    context 'when performing gitaly calls', :request_store do
      it 'limits the Gitaly requests' do
46
        expect { subject }.to change { Gitlab::GitalyClient.get_request_count }.by(3)
47 48
      end
    end
49 50
  end

51
  describe 'GET show JSON' do
52
    let(:pipeline) { create(:ci_pipeline_with_one_job, project: project) }
53 54 55 56

    it 'returns the pipeline' do
      get_pipeline_json

57
      expect(response).to have_gitlab_http_status(:ok)
58 59 60 61 62
      expect(json_response).not_to be_an(Array)
      expect(json_response['id']).to be(pipeline.id)
      expect(json_response['details']).to have_key 'stages'
    end

63
    context 'when the pipeline has multiple stages and groups', :request_store do
64 65 66 67 68 69 70
      before do
        create_build('build', 0, 'build')
        create_build('test', 1, 'rspec 0')
        create_build('deploy', 2, 'production')
        create_build('post deploy', 3, 'pages 0')
      end

71
      let(:project) { create(:project, :repository) }
72 73 74 75
      let(:pipeline) do
        create(:ci_empty_pipeline, project: project, user: user, sha: project.commit.id)
      end

76 77 78
      it 'does not perform N + 1 queries' do
        control_count = ActiveRecord::QueryRecorder.new { get_pipeline_json }.count

79 80 81 82 83 84
        create_build('test', 1, 'rspec 1')
        create_build('test', 1, 'spinach 0')
        create_build('test', 1, 'spinach 1')
        create_build('test', 1, 'audit')
        create_build('post deploy', 3, 'pages 1')
        create_build('post deploy', 3, 'pages 2')
85

86 87
        new_count = ActiveRecord::QueryRecorder.new { get_pipeline_json }.count
        expect(new_count).to be_within(12).of(control_count)
88 89 90 91 92 93
      end
    end

    def get_pipeline_json
      get :show, namespace_id: project.namespace, project_id: project, id: pipeline, format: :json
    end
94 95 96 97

    def create_build(stage, stage_idx, name)
      create(:ci_build, pipeline: pipeline, stage: stage, stage_idx: stage_idx, name: name)
    end
98 99
  end

100
  describe 'GET stages.json' do
101 102
    let(:pipeline) { create(:ci_pipeline, project: project) }

103 104 105 106 107 108 109 110
    context 'when accessing existing stage' do
      before do
        create(:ci_build, pipeline: pipeline, stage: 'build')

        get_stage('build')
      end

      it 'returns html source for stage dropdown' do
111
        expect(response).to have_gitlab_http_status(:ok)
112 113 114 115 116 117 118 119 120 121
        expect(response).to render_template('projects/pipelines/_stage')
        expect(json_response).to include('html')
      end
    end

    context 'when accessing unknown stage' do
      before do
        get_stage('test')
      end

122
      it 'responds with not found' do
123
        expect(response).to have_gitlab_http_status(:not_found)
124
      end
125 126
    end

127
    def get_stage(name)
128 129
      get :stage, namespace_id: project.namespace,
                  project_id: project,
130 131 132 133
                  id: pipeline.id,
                  stage: name,
                  format: :json
    end
134
  end
Shinya Maeda's avatar
Shinya Maeda committed
135 136

  describe 'GET status.json' do
137 138
    let(:pipeline) { create(:ci_pipeline, project: project) }
    let(:status) { pipeline.detailed_status(double('user')) }
Shinya Maeda's avatar
Shinya Maeda committed
139

140 141 142 143 144 145
    before do
      get :status, namespace_id: project.namespace,
                   project_id: project,
                   id: pipeline.id,
                   format: :json
    end
Shinya Maeda's avatar
Shinya Maeda committed
146

147
    it 'return a detailed pipeline status in json' do
148
      expect(response).to have_gitlab_http_status(:ok)
149 150 151
      expect(json_response['text']).to eq status.text
      expect(json_response['label']).to eq status.label
      expect(json_response['icon']).to eq status.icon
152
      expect(json_response['favicon']).to match_asset_path("/assets/ci_favicons/#{status.favicon}.ico")
Shinya Maeda's avatar
Shinya Maeda committed
153 154
    end
  end
155 156 157 158 159 160 161 162 163 164 165 166

  describe 'POST retry.json' do
    let!(:pipeline) { create(:ci_pipeline, :failed, project: project) }
    let!(:build) { create(:ci_build, :failed, pipeline: pipeline) }

    before do
      post :retry, namespace_id: project.namespace,
                   project_id: project,
                   id: pipeline.id,
                   format: :json
    end

167 168
    context 'when builds are enabled' do
      let(:feature) { ProjectFeature::ENABLED }
169

170
      it 'retries a pipeline without returning any content' do
171
        expect(response).to have_gitlab_http_status(:no_content)
172 173 174 175 176 177
        expect(build.reload).to be_retried
      end
    end

    context 'when builds are disabled' do
      it 'fails to retry pipeline' do
178
        expect(response).to have_gitlab_http_status(:not_found)
179
      end
180 181 182 183 184 185
    end
  end

  describe 'POST cancel.json' do
    let!(:pipeline) { create(:ci_pipeline, project: project) }
    let!(:build) { create(:ci_build, :running, pipeline: pipeline) }
186

187 188 189 190 191 192 193
    before do
      post :cancel, namespace_id: project.namespace,
                    project_id: project,
                    id: pipeline.id,
                    format: :json
    end

194 195
    context 'when builds are enabled' do
      let(:feature) { ProjectFeature::ENABLED }
196

197
      it 'cancels a pipeline without returning any content' do
198
        expect(response).to have_gitlab_http_status(:no_content)
199 200 201 202 203 204
        expect(pipeline.reload).to be_canceled
      end
    end

    context 'when builds are disabled' do
      it 'fails to retry pipeline' do
205
        expect(response).to have_gitlab_http_status(:not_found)
206
      end
207 208
    end
  end
209
end