104 lines
3.2 KiB
Ruby
104 lines
3.2 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
require 'spec_helper'
|
|
|
|
require_migration!
|
|
|
|
RSpec.describe BackfillStageEventHash, schema: 20210730103808 do
|
|
let(:namespaces) { table(:namespaces) }
|
|
let(:projects) { table(:projects) }
|
|
let(:labels) { table(:labels) }
|
|
let(:group_stages) { table(:analytics_cycle_analytics_group_stages) }
|
|
let(:project_stages) { table(:analytics_cycle_analytics_project_stages) }
|
|
let(:group_value_streams) { table(:analytics_cycle_analytics_group_value_streams) }
|
|
let(:project_value_streams) { table(:analytics_cycle_analytics_project_value_streams) }
|
|
let(:stage_event_hashes) { table(:analytics_cycle_analytics_stage_event_hashes) }
|
|
|
|
let(:issue_created) { 1 }
|
|
let(:issue_closed) { 3 }
|
|
let(:issue_label_removed) { 9 }
|
|
let(:unknown_stage_event) { -1 }
|
|
|
|
let(:namespace) { namespaces.create!(name: 'ns', path: 'ns', type: 'Group') }
|
|
let(:project) { projects.create!(name: 'project', path: 'project', namespace_id: namespace.id) }
|
|
let(:group_label) { labels.create!(title: 'label', type: 'GroupLabel', group_id: namespace.id) }
|
|
let(:group_value_stream) { group_value_streams.create!(name: 'group vs', group_id: namespace.id) }
|
|
let(:project_value_stream) { project_value_streams.create!(name: 'project vs', project_id: project.id) }
|
|
|
|
let(:group_stage_1) do
|
|
group_stages.create!(
|
|
name: 'stage 1',
|
|
group_id: namespace.id,
|
|
start_event_identifier: issue_created,
|
|
end_event_identifier: issue_closed,
|
|
group_value_stream_id: group_value_stream.id
|
|
)
|
|
end
|
|
|
|
let(:group_stage_2) do
|
|
group_stages.create!(
|
|
name: 'stage 2',
|
|
group_id: namespace.id,
|
|
start_event_identifier: issue_created,
|
|
end_event_identifier: issue_label_removed,
|
|
end_event_label_id: group_label.id,
|
|
group_value_stream_id: group_value_stream.id
|
|
)
|
|
end
|
|
|
|
let(:project_stage_1) do
|
|
project_stages.create!(
|
|
name: 'stage 1',
|
|
project_id: project.id,
|
|
start_event_identifier: issue_created,
|
|
end_event_identifier: issue_closed,
|
|
project_value_stream_id: project_value_stream.id
|
|
)
|
|
end
|
|
|
|
let(:invalid_group_stage) do
|
|
group_stages.create!(
|
|
name: 'stage 3',
|
|
group_id: namespace.id,
|
|
start_event_identifier: issue_created,
|
|
end_event_identifier: unknown_stage_event,
|
|
group_value_stream_id: group_value_stream.id
|
|
)
|
|
end
|
|
|
|
describe '#up' do
|
|
it 'populates stage_event_hash_id column' do
|
|
group_stage_1
|
|
group_stage_2
|
|
project_stage_1
|
|
|
|
migrate!
|
|
|
|
group_stage_1.reload
|
|
group_stage_2.reload
|
|
project_stage_1.reload
|
|
|
|
expect(group_stage_1.stage_event_hash_id).not_to be_nil
|
|
expect(group_stage_2.stage_event_hash_id).not_to be_nil
|
|
expect(project_stage_1.stage_event_hash_id).not_to be_nil
|
|
|
|
expect(stage_event_hashes.count).to eq(2) # group_stage_1 and project_stage_1 has the same hash
|
|
end
|
|
|
|
it 'runs without problem without stages' do
|
|
expect { migrate! }.not_to raise_error
|
|
end
|
|
|
|
context 'when invalid event identifier is discovered' do
|
|
it 'removes the stage' do
|
|
group_stage_1
|
|
invalid_group_stage
|
|
|
|
expect { migrate! }.not_to change { group_stage_1 }
|
|
|
|
expect(group_stages.find_by_id(invalid_group_stage.id)).to eq(nil)
|
|
end
|
|
end
|
|
end
|
|
end
|