debian-mirror-gitlab/spec/serializers/test_reports_comparer_entity_spec.rb

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

73 lines
3.3 KiB
Ruby
Raw Normal View History

2019-12-21 20:55:43 +05:30
# frozen_string_literal: true
2018-11-18 11:00:15 +05:30
require 'spec_helper'
2020-07-28 23:09:34 +05:30
RSpec.describe TestReportsComparerEntity do
2018-11-18 11:00:15 +05:30
include TestReportsHelper
let(:entity) { described_class.new(comparer) }
let(:comparer) { Gitlab::Ci::Reports::TestReportsComparer.new(base_reports, head_reports) }
2022-08-13 15:12:31 +05:30
let(:base_reports) { Gitlab::Ci::Reports::TestReport.new }
let(:head_reports) { Gitlab::Ci::Reports::TestReport.new }
2018-11-18 11:00:15 +05:30
describe '#as_json' do
subject { entity.as_json }
context 'when head and base reports include two test suites' do
context 'when the status of head report is success' do
before do
base_reports.get_suite('rspec').add_test_case(create_test_case_rspec_success)
base_reports.get_suite('junit').add_test_case(create_test_case_java_success)
head_reports.get_suite('rspec').add_test_case(create_test_case_rspec_success)
head_reports.get_suite('junit').add_test_case(create_test_case_java_success)
end
it 'contains correct compared test reports details' do
expect(subject[:status]).to eq('success')
2020-03-13 15:44:24 +05:30
expect(subject[:summary]).to include(total: 2, resolved: 0, failed: 0, errored: 0)
2018-11-18 11:00:15 +05:30
expect(subject[:suites].first[:name]).to eq('rspec')
expect(subject[:suites].first[:status]).to eq('success')
expect(subject[:suites].second[:name]).to eq('junit')
expect(subject[:suites].second[:status]).to eq('success')
end
end
context 'when the status of head report is failed' do
before do
base_reports.get_suite('rspec').add_test_case(create_test_case_rspec_success)
base_reports.get_suite('junit').add_test_case(create_test_case_java_success)
head_reports.get_suite('rspec').add_test_case(create_test_case_rspec_success)
head_reports.get_suite('junit').add_test_case(create_test_case_java_failed)
end
it 'contains correct compared test reports details' do
expect(subject[:status]).to eq('failed')
2020-03-13 15:44:24 +05:30
expect(subject[:summary]).to include(total: 2, resolved: 0, failed: 1, errored: 0)
2018-11-18 11:00:15 +05:30
expect(subject[:suites].first[:name]).to eq('rspec')
expect(subject[:suites].first[:status]).to eq('success')
expect(subject[:suites].second[:name]).to eq('junit')
expect(subject[:suites].second[:status]).to eq('failed')
end
end
context 'when the status of head report is resolved' do
before do
base_reports.get_suite('rspec').add_test_case(create_test_case_rspec_success)
base_reports.get_suite('junit').add_test_case(create_test_case_java_failed)
head_reports.get_suite('rspec').add_test_case(create_test_case_rspec_success)
2019-09-30 21:07:59 +05:30
head_reports.get_suite('junit').add_test_case(create_test_case_java_success)
2018-11-18 11:00:15 +05:30
end
it 'contains correct compared test reports details' do
expect(subject[:status]).to eq('success')
2020-03-13 15:44:24 +05:30
expect(subject[:summary]).to include(total: 2, resolved: 1, failed: 0, errored: 0)
2018-11-18 11:00:15 +05:30
expect(subject[:suites].first[:name]).to eq('rspec')
expect(subject[:suites].first[:status]).to eq('success')
expect(subject[:suites].second[:name]).to eq('junit')
expect(subject[:suites].second[:status]).to eq('success')
end
end
end
end
end