Commit 88cadb53 authored by Grzegorz Bizon's avatar Grzegorz Bizon

Merge branch '14064-commit-status-on-any-pipelines' into 'master'

Make commit status created for any pipelines by default

Closes #32257 and #14064

See merge request gitlab-org/gitlab!17524
parents 08562d64 f65eda80
...@@ -217,6 +217,8 @@ module Ci ...@@ -217,6 +217,8 @@ module Ci
scope :for_sha, -> (sha) { where(sha: sha) } scope :for_sha, -> (sha) { where(sha: sha) }
scope :for_source_sha, -> (source_sha) { where(source_sha: source_sha) } scope :for_source_sha, -> (source_sha) { where(source_sha: source_sha) }
scope :for_sha_or_source_sha, -> (sha) { for_sha(sha).or(for_source_sha(sha)) } scope :for_sha_or_source_sha, -> (sha) { for_sha(sha).or(for_source_sha(sha)) }
scope :for_ref, -> (ref) { where(ref: ref) }
scope :for_id, -> (id) { where(id: id) }
scope :created_after, -> (time) { where('ci_pipelines.created_at > ?', time) } scope :created_after, -> (time) { where('ci_pipelines.created_at > ?', time) }
scope :triggered_by_merge_request, -> (merge_request) do scope :triggered_by_merge_request, -> (merge_request) do
......
---
title: Make commit status created for any pipelines
merge_request: 17524
author: Aufar Gilbran
type: changed
...@@ -58,7 +58,6 @@ module API ...@@ -58,7 +58,6 @@ module API
post ':id/statuses/:sha' do post ':id/statuses/:sha' do
authorize! :create_commit_status, user_project authorize! :create_commit_status, user_project
commit = @project.commit(params[:sha])
not_found! 'Commit' unless commit not_found! 'Commit' unless commit
# Since the CommitStatus is attached to Ci::Pipeline (in the future Pipeline) # Since the CommitStatus is attached to Ci::Pipeline (in the future Pipeline)
...@@ -68,14 +67,15 @@ module API ...@@ -68,14 +67,15 @@ module API
# If we don't receive it, we will attach the CommitStatus to # If we don't receive it, we will attach the CommitStatus to
# the first found branch on that commit # the first found branch on that commit
pipeline = all_matching_pipelines.first
ref = params[:ref] ref = params[:ref]
ref ||= pipeline&.ref
ref ||= @project.repository.branch_names_contains(commit.sha).first ref ||= @project.repository.branch_names_contains(commit.sha).first
not_found! 'References for commit' unless ref not_found! 'References for commit' unless ref
name = params[:name] || params[:context] || 'default' name = params[:name] || params[:context] || 'default'
pipeline = @project.pipeline_for(ref, commit.sha, params[:pipeline_id])
unless pipeline unless pipeline
pipeline = @project.ci_pipelines.create!( pipeline = @project.ci_pipelines.create!(
source: :external, source: :external,
...@@ -126,6 +126,20 @@ module API ...@@ -126,6 +126,20 @@ module API
end end
end end
# rubocop: enable CodeReuse/ActiveRecord # rubocop: enable CodeReuse/ActiveRecord
helpers do
def commit
strong_memoize(:commit) do
user_project.commit(params[:sha])
end
end
def all_matching_pipelines
pipelines = user_project.ci_pipelines.newest_first(sha: commit.sha)
pipelines = pipelines.for_ref(params[:ref]) if params[:ref]
pipelines = pipelines.for_id(params[:pipeline_id]) if params[:pipeline_id]
pipelines
end
end
end end
end end
end end
...@@ -125,25 +125,55 @@ describe API::CommitStatuses do ...@@ -125,25 +125,55 @@ describe API::CommitStatuses do
let(:post_url) { "/projects/#{project.id}/statuses/#{sha}" } let(:post_url) { "/projects/#{project.id}/statuses/#{sha}" }
context 'developer user' do context 'developer user' do
%w[pending running success failed canceled].each do |status| context 'uses only required parameters' do
context "for #{status}" do %w[pending running success failed canceled].each do |status|
context 'uses only required parameters' do context "for #{status}" do
it 'creates commit status' do context 'when pipeline for sha does not exists' do
post api(post_url, developer), params: { state: status } it 'creates commit status' do
post api(post_url, developer), params: { state: status }
expect(response).to have_gitlab_http_status(201)
expect(json_response['sha']).to eq(commit.id)
expect(json_response['status']).to eq(status)
expect(json_response['name']).to eq('default')
expect(json_response['ref']).not_to be_empty
expect(json_response['target_url']).to be_nil
expect(json_response['description']).to be_nil
if status == 'failed'
expect(CommitStatus.find(json_response['id'])).to be_api_failure
end
end
end
end
end
context 'when pipeline already exists for the specified sha' do
let!(:pipeline) { create(:ci_pipeline, project: project, sha: sha, ref: 'ref') }
let(:params) { { state: 'pending' } }
shared_examples_for 'creates a commit status for the existing pipeline' do
it do
expect do
post api(post_url, developer), params: params
end.not_to change { Ci::Pipeline.count }
job = pipeline.statuses.find_by_name(json_response['name'])
expect(response).to have_gitlab_http_status(201) expect(response).to have_gitlab_http_status(201)
expect(json_response['sha']).to eq(commit.id) expect(job.status).to eq('pending')
expect(json_response['status']).to eq(status)
expect(json_response['name']).to eq('default')
expect(json_response['ref']).not_to be_empty
expect(json_response['target_url']).to be_nil
expect(json_response['description']).to be_nil
if status == 'failed'
expect(CommitStatus.find(json_response['id'])).to be_api_failure
end
end end
end end
it_behaves_like 'creates a commit status for the existing pipeline'
context 'with pipeline for merge request' do
let!(:merge_request) { create(:merge_request, :with_detached_merge_request_pipeline, source_project: project) }
let!(:pipeline) { merge_request.all_pipelines.last }
let(:sha) { pipeline.sha }
it_behaves_like 'creates a commit status for the existing pipeline'
end
end end
end end
......
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