summaryrefslogtreecommitdiff
path: root/spec/services/ci/build_report_result_service_spec.rb
blob: c5238b7f5e0034e4150849e903106c5e1ec0557e (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
# frozen_string_literal: true

require 'spec_helper'

RSpec.describe Ci::BuildReportResultService do
  describe '#execute', :clean_gitlab_redis_shared_state do
    subject(:build_report_result) { described_class.new.execute(build) }

    context 'when build is finished' do
      let(:build) { create(:ci_build, :success, :test_reports) }

      it 'creates a build report result entry', :aggregate_failures do
        expect { build_report_result }.to change { Ci::BuildReportResult.count }.by(1)
        expect(build_report_result.tests_name).to eq("test")
        expect(build_report_result.tests_success).to eq(2)
        expect(build_report_result.tests_failed).to eq(2)
        expect(build_report_result.tests_errored).to eq(0)
        expect(build_report_result.tests_skipped).to eq(0)
        expect(build_report_result.tests_duration).to eq(0.010284)
      end

      it 'tracks unique test cases parsed' do
        build_report_result

        unique_test_cases_parsed = Gitlab::UsageDataCounters::HLLRedisCounter.unique_events(
          event_names: described_class::EVENT_NAME,
          start_date: 2.weeks.ago,
          end_date: 2.weeks.from_now
        )
        expect(unique_test_cases_parsed).to eq(4)
      end

      context 'and build has test report parsing errors' do
        let(:build) { create(:ci_build, :success, :broken_test_reports) }

        it 'creates a build report result entry with suite error', :aggregate_failures do
          expect { build_report_result }.to change { Ci::BuildReportResult.count }.by(1)
          expect(build_report_result.tests_name).to eq("test")
          expect(build_report_result.tests_success).to eq(0)
          expect(build_report_result.tests_failed).to eq(0)
          expect(build_report_result.tests_errored).to eq(0)
          expect(build_report_result.tests_skipped).to eq(0)
          expect(build_report_result.tests_duration).to eq(0)
          expect(build_report_result.suite_error).to be_present
        end

        it 'does not track unique test cases parsed' do
          build_report_result

          unique_test_cases_parsed = Gitlab::UsageDataCounters::HLLRedisCounter.unique_events(
            event_names: described_class::EVENT_NAME,
            start_date: 2.weeks.ago,
            end_date: 2.weeks.from_now
          )
          expect(unique_test_cases_parsed).to eq(0)
        end
      end

      context 'when data has already been persisted' do
        it 'raises an error and do not persist the same data twice' do
          expect { 2.times { described_class.new.execute(build) } }.to raise_error(ActiveRecord::RecordNotUnique)

          expect(Ci::BuildReportResult.count).to eq(1)
        end
      end
    end

    context 'when build is running and test report does not exist' do
      let(:build) { create(:ci_build, :running) }

      it 'does not persist data' do
        subject

        expect(Ci::BuildReportResult.count).to eq(0)
      end
    end
  end
end