debian-mirror-gitlab/spec/services/ci/track_failed_build_service_spec.rb

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

60 lines
1.7 KiB
Ruby
Raw Permalink Normal View History

2022-08-27 11:52:29 +05:30
# frozen_string_literal: true
require 'spec_helper'
2023-05-27 22:25:52 +05:30
RSpec.describe Ci::TrackFailedBuildService, feature_category: :continuous_integration do
2022-08-27 11:52:29 +05:30
let_it_be(:user) { create(:user) }
let_it_be(:project) { create(:project, :public) }
let_it_be(:pipeline) { create(:ci_pipeline, project: project, user: user) }
let_it_be(:exit_code) { 42 }
let_it_be(:failure_reason) { "script_failure" }
describe '#execute' do
context 'when a build has failed' do
let_it_be(:build) { create(:ci_build, :failed, :sast_report, pipeline: pipeline, user: user) }
subject { described_class.new(build: build, exit_code: exit_code, failure_reason: failure_reason) }
it 'tracks the build failed event', :snowplow do
response = subject.execute
expect(response.success?).to be true
2023-03-04 22:38:38 +05:30
context = {
schema: described_class::SCHEMA_URL,
data: {
build_id: build.id,
build_name: build.name,
build_artifact_types: ["sast"],
exit_code: exit_code,
failure_reason: failure_reason,
project: project.id
}
}
2022-08-27 11:52:29 +05:30
expect_snowplow_event(
category: 'ci::build',
action: 'failed',
2023-03-04 22:38:38 +05:30
context: [context],
2022-08-27 11:52:29 +05:30
user: user,
project: project.id)
end
end
context 'when a build has not failed' do
let_it_be(:build) { create(:ci_build, :success, :sast_report, pipeline: pipeline, user: user) }
subject { described_class.new(build: build, exit_code: nil, failure_reason: nil) }
it 'does not track the build failed event', :snowplow do
response = subject.execute
expect(response.error?).to be true
expect_no_snowplow_event
end
end
end
end