require 'spec_helper' describe Projects::PipelinesController do include ApiHelpers let(:user) { create(:user) } let(:project) { create(:empty_project, :public) } before do project.add_developer(user) sign_in(user) end describe 'GET index.json' do before do create(:ci_empty_pipeline, status: 'pending', project: project) create(:ci_empty_pipeline, status: 'running', project: project) create(:ci_empty_pipeline, status: 'created', project: project) create(:ci_empty_pipeline, status: 'success', project: project) get :index, namespace_id: project.namespace, project_id: project, format: :json end it 'returns JSON with serialized pipelines' do expect(response).to have_http_status(:ok) expect(response).to match_response_schema('pipeline') expect(json_response).to include('pipelines') 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 end end describe 'GET show JSON' do let!(:pipeline) { create(:ci_pipeline_with_one_job, project: project) } it 'returns the pipeline' do get_pipeline_json expect(response).to have_http_status(:ok) 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 context 'when the pipeline has multiple jobs' do it 'does not perform N + 1 queries' do control_count = ActiveRecord::QueryRecorder.new { get_pipeline_json }.count create(:ci_build, pipeline: pipeline) # The plus 2 is needed to group and sort expect { get_pipeline_json }.not_to exceed_query_limit(control_count + 2) end end def get_pipeline_json get :show, namespace_id: project.namespace, project_id: project, id: pipeline, format: :json end end describe 'GET stages.json' do let(:pipeline) { create(:ci_pipeline, project: project) } 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 expect(response).to have_http_status(:ok) 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 it 'responds with not found' do expect(response).to have_http_status(:not_found) end end def get_stage(name) get :stage, namespace_id: project.namespace, project_id: project, id: pipeline.id, stage: name, format: :json end end describe 'GET status.json' do let(:pipeline) { create(:ci_pipeline, project: project) } let(:status) { pipeline.detailed_status(double('user')) } before do get :status, namespace_id: project.namespace, project_id: project, id: pipeline.id, format: :json end it 'return a detailed pipeline status in json' do expect(response).to have_http_status(:ok) expect(json_response['text']).to eq status.text expect(json_response['label']).to eq status.label expect(json_response['icon']).to eq status.icon expect(json_response['favicon']).to eq "/assets/ci_favicons/#{status.favicon}.ico" end end 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 it 'retries a pipeline without returning any content' do expect(response).to have_http_status(:no_content) expect(build.reload).to be_retried end end describe 'POST cancel.json' do let!(:pipeline) { create(:ci_pipeline, project: project) } let!(:build) { create(:ci_build, :running, pipeline: pipeline) } before do post :cancel, namespace_id: project.namespace, project_id: project, id: pipeline.id, format: :json end it 'cancels a pipeline without returning any content' do expect(response).to have_http_status(:no_content) expect(pipeline.reload).to be_canceled end end end