Commit 6521a6ec authored by James Lopez's avatar James Lopez

Merge branch '231344-json-result-for-project-pipeline-create' into 'master'

Implement JSON response for project/pipelines create

See merge request gitlab-org/gitlab!39839
parents 8e1c405d 57753b7b
......@@ -63,12 +63,26 @@ class Projects::PipelinesController < Projects::ApplicationController
.new(project, current_user, create_params)
.execute(:web, ignore_skip_ci: true, save_on_errors: false)
respond_to do |format|
format.html do
if @pipeline.created_successfully?
redirect_to project_pipeline_path(project, @pipeline)
else
render 'new', status: :bad_request
end
end
format.json do
if @pipeline.created_successfully?
render json: PipelineSerializer
.new(project: project, current_user: current_user)
.represent(@pipeline),
status: :created
else
render json: @pipeline.errors, status: :bad_request
end
end
end
end
def show
Gitlab::QueryLimiting.whitelist('https://gitlab.com/gitlab-org/gitlab/-/issues/26657')
......
---
title: Implement JSON response for project/pipelines create
merge_request: 39839
author:
type: other
......@@ -763,6 +763,62 @@ RSpec.describe Projects::PipelinesController do
end
end
describe 'POST create.json' do
let(:project) { create(:project, :public, :repository) }
subject do
post :create, params: {
namespace_id: project.namespace,
project_id: project,
pipeline: { ref: 'master' }
},
format: :json
end
before do
project.add_developer(user)
project.project_feature.update(builds_access_level: feature)
end
context 'with a valid .gitlab-ci.yml file' do
before do
stub_ci_pipeline_yaml_file(YAML.dump({
test: {
stage: 'test',
script: 'echo'
}
}))
end
it 'creates a pipeline' do
expect { subject }.to change { project.ci_pipelines.count }.by(1)
expect(response).to have_gitlab_http_status(:created)
expect(json_response['id']).to eq(project.ci_pipelines.last.id)
end
end
context 'with an invalid .gitlab-ci.yml file' do
before do
stub_ci_pipeline_yaml_file(YAML.dump({
test: {
stage: 'invalid',
script: 'echo'
}
}))
end
it 'does not create a pipeline' do
expect { subject }.not_to change { project.ci_pipelines.count }
expect(response).to have_gitlab_http_status(:bad_request)
expect(json_response['base']).to include(
'test job: chosen stage does not exist; available stages are .pre, build, test, deploy, .post'
)
end
end
end
describe 'POST retry.json' do
let!(:pipeline) { create(:ci_pipeline, :failed, project: project) }
let!(:build) { create(:ci_build, :failed, pipeline: pipeline) }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment