2019-02-15 15:39:39 +05:30
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2018-03-17 18:26:18 +05:30
|
|
|
require 'spec_helper'
|
|
|
|
|
|
|
|
describe Gitlab::BackgroundMigration::MigrateStageStatus, :migration, schema: 20170711145320 do
|
|
|
|
let(:projects) { table(:projects) }
|
|
|
|
let(:pipelines) { table(:ci_pipelines) }
|
|
|
|
let(:stages) { table(:ci_stages) }
|
|
|
|
let(:jobs) { table(:ci_builds) }
|
|
|
|
|
2019-02-15 15:39:39 +05:30
|
|
|
let(:statuses) do
|
|
|
|
{
|
|
|
|
created: 0,
|
|
|
|
pending: 1,
|
|
|
|
running: 2,
|
|
|
|
success: 3,
|
|
|
|
failed: 4,
|
|
|
|
canceled: 5,
|
|
|
|
skipped: 6,
|
|
|
|
manual: 7
|
|
|
|
}
|
|
|
|
end
|
2018-03-17 18:26:18 +05:30
|
|
|
|
|
|
|
before do
|
|
|
|
projects.create!(id: 1, name: 'gitlab1', path: 'gitlab1')
|
|
|
|
pipelines.create!(id: 1, project_id: 1, ref: 'master', sha: 'adf43c3a')
|
|
|
|
stages.create!(id: 1, pipeline_id: 1, project_id: 1, name: 'test', status: nil)
|
|
|
|
stages.create!(id: 2, pipeline_id: 1, project_id: 1, name: 'deploy', status: nil)
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when stage status is known' do
|
|
|
|
before do
|
|
|
|
create_job(project: 1, pipeline: 1, stage: 'test', status: 'success')
|
|
|
|
create_job(project: 1, pipeline: 1, stage: 'test', status: 'running')
|
|
|
|
create_job(project: 1, pipeline: 1, stage: 'deploy', status: 'failed')
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'sets a correct stage status' do
|
|
|
|
described_class.new.perform(1, 2)
|
|
|
|
|
2019-02-15 15:39:39 +05:30
|
|
|
expect(stages.first.status).to eq statuses[:running]
|
|
|
|
expect(stages.second.status).to eq statuses[:failed]
|
2018-03-17 18:26:18 +05:30
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when stage status is not known' do
|
|
|
|
it 'sets a skipped stage status' do
|
|
|
|
described_class.new.perform(1, 2)
|
|
|
|
|
2019-02-15 15:39:39 +05:30
|
|
|
expect(stages.first.status).to eq statuses[:skipped]
|
|
|
|
expect(stages.second.status).to eq statuses[:skipped]
|
2018-03-17 18:26:18 +05:30
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when stage status includes status of a retried job' do
|
|
|
|
before do
|
|
|
|
create_job(project: 1, pipeline: 1, stage: 'test', status: 'canceled')
|
|
|
|
create_job(project: 1, pipeline: 1, stage: 'deploy', status: 'failed', retried: true)
|
|
|
|
create_job(project: 1, pipeline: 1, stage: 'deploy', status: 'success')
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'sets a correct stage status' do
|
|
|
|
described_class.new.perform(1, 2)
|
|
|
|
|
2019-02-15 15:39:39 +05:30
|
|
|
expect(stages.first.status).to eq statuses[:canceled]
|
|
|
|
expect(stages.second.status).to eq statuses[:success]
|
2018-03-17 18:26:18 +05:30
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when some job in the stage is blocked / manual' do
|
|
|
|
before do
|
|
|
|
create_job(project: 1, pipeline: 1, stage: 'test', status: 'failed')
|
|
|
|
create_job(project: 1, pipeline: 1, stage: 'test', status: 'manual')
|
|
|
|
create_job(project: 1, pipeline: 1, stage: 'deploy', status: 'success', when: 'manual')
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'sets a correct stage status' do
|
|
|
|
described_class.new.perform(1, 2)
|
|
|
|
|
2019-02-15 15:39:39 +05:30
|
|
|
expect(stages.first.status).to eq statuses[:manual]
|
|
|
|
expect(stages.second.status).to eq statuses[:success]
|
2018-03-17 18:26:18 +05:30
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def create_job(project:, pipeline:, stage:, status:, **opts)
|
|
|
|
stages = { test: 1, build: 2, deploy: 3 }
|
|
|
|
|
|
|
|
jobs.create!(project_id: project, commit_id: pipeline,
|
|
|
|
stage_idx: stages[stage.to_sym], stage: stage,
|
|
|
|
status: status, **opts)
|
|
|
|
end
|
|
|
|
end
|