debian-mirror-gitlab/spec/serializers/test_suite_entity_spec.rb
2020-08-09 17:44:08 +05:30

77 lines
2.2 KiB
Ruby

# frozen_string_literal: true
require 'spec_helper'
RSpec.describe TestSuiteEntity do
let(:pipeline) { create(:ci_pipeline, :with_test_reports) }
let(:test_suite) { pipeline.test_reports.test_suites.each_value.first }
let(:user) { create(:user) }
let(:request) { double('request', current_user: user) }
subject { described_class.new(test_suite, request: request).as_json }
context 'when details option is not present' do
it 'does not expose suite error and test cases', :aggregate_failures do
expect(subject).not_to include(:test_cases)
expect(subject).not_to include(:suite_error)
end
end
context 'when details option is present' do
subject { described_class.new(test_suite, request: request, details: true).as_json }
it 'contains the suite name' do
expect(subject[:name]).to be_present
end
it 'contains the total time' do
expect(subject[:total_time]).to be_present
end
it 'contains the counts' do
expect(subject[:total_count]).to eq(4)
expect(subject[:success_count]).to eq(2)
expect(subject[:failed_count]).to eq(2)
expect(subject[:skipped_count]).to eq(0)
expect(subject[:error_count]).to eq(0)
end
it 'contains the test cases' do
expect(subject[:test_cases].count).to eq(4)
end
it 'contains an empty error message' do
expect(subject[:suite_error]).to be_nil
end
context 'with a suite error' do
before do
test_suite.set_suite_error('a really bad error')
end
it 'contains the suite name' do
expect(subject[:name]).to be_present
end
it 'contains the total time' do
expect(subject[:total_time]).to be_present
end
it 'returns all the counts as 0' do
expect(subject[:total_count]).to eq(0)
expect(subject[:success_count]).to eq(0)
expect(subject[:failed_count]).to eq(0)
expect(subject[:skipped_count]).to eq(0)
expect(subject[:error_count]).to eq(0)
end
it 'returns no test cases' do
expect(subject[:test_cases]).to be_empty
end
it 'returns a suite error' do
expect(subject[:suite_error]).to eq('a really bad error')
end
end
end
end