summaryrefslogtreecommitdiff
path: root/spec/serializers/test_suite_entity_spec.rb
diff options
context:
space:
mode:
Diffstat (limited to 'spec/serializers/test_suite_entity_spec.rb')
-rw-r--r--spec/serializers/test_suite_entity_spec.rb56
1 files changed, 33 insertions, 23 deletions
diff --git a/spec/serializers/test_suite_entity_spec.rb b/spec/serializers/test_suite_entity_spec.rb
index bd88d235013..83d3086ea6b 100644
--- a/spec/serializers/test_suite_entity_spec.rb
+++ b/spec/serializers/test_suite_entity_spec.rb
@@ -2,36 +2,46 @@
require 'spec_helper'
-describe TestSuiteEntity do
- let(:pipeline) { create(:ci_pipeline, :with_test_reports) }
+RSpec.describe TestSuiteEntity do
+ let(:pipeline) { create(:ci_pipeline, :with_test_reports) }
let(:test_suite) { pipeline.test_reports.test_suites.each_value.first }
- let(:entity) { described_class.new(test_suite) }
+ let(:user) { create(:user) }
+ let(:request) { double('request', current_user: user) }
- describe '#as_json' do
- subject(:as_json) { entity.as_json }
+ 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(as_json[:name]).to be_present
+ expect(subject[:name]).to be_present
end
it 'contains the total time' do
- expect(as_json[:total_time]).to be_present
+ expect(subject[:total_time]).to be_present
end
it 'contains the counts' do
- expect(as_json[:total_count]).to eq(4)
- expect(as_json[:success_count]).to eq(2)
- expect(as_json[:failed_count]).to eq(2)
- expect(as_json[:skipped_count]).to eq(0)
- expect(as_json[:error_count]).to eq(0)
+ 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(as_json[:test_cases].count).to eq(4)
+ expect(subject[:test_cases].count).to eq(4)
end
it 'contains an empty error message' do
- expect(as_json[:suite_error]).to be_nil
+ expect(subject[:suite_error]).to be_nil
end
context 'with a suite error' do
@@ -40,27 +50,27 @@ describe TestSuiteEntity do
end
it 'contains the suite name' do
- expect(as_json[:name]).to be_present
+ expect(subject[:name]).to be_present
end
it 'contains the total time' do
- expect(as_json[:total_time]).to be_present
+ expect(subject[:total_time]).to be_present
end
it 'returns all the counts as 0' do
- expect(as_json[:total_count]).to eq(0)
- expect(as_json[:success_count]).to eq(0)
- expect(as_json[:failed_count]).to eq(0)
- expect(as_json[:skipped_count]).to eq(0)
- expect(as_json[:error_count]).to eq(0)
+ 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(as_json[:test_cases]).to be_empty
+ expect(subject[:test_cases]).to be_empty
end
it 'returns a suite error' do
- expect(as_json[:suite_error]).to eq('a really bad error')
+ expect(subject[:suite_error]).to eq('a really bad error')
end
end
end