diff options
author | Shinya Maeda <shinya@gitlab.com> | 2018-08-03 09:13:39 +0300 |
---|---|---|
committer | Shinya Maeda <shinya@gitlab.com> | 2018-08-03 09:13:39 +0300 |
commit | 85af3ea21a5a772cb22756190268ba3f921a6400 (patch) | |
tree | 4231bb48df2693c9600b5c5b7dabb9bae41c1d3e /spec/services | |
parent | 1f53cf7cf0cb53b5d69ab141fa9020356e62027e (diff) |
Added unique identifier to calculate_reactive_cache. Decoupled comparison logic to service. Fixed N+1 select queries.
Diffstat (limited to 'spec/services')
-rw-r--r-- | spec/services/ci/compare_test_reports_service_spec.rb | 55 |
1 files changed, 55 insertions, 0 deletions
diff --git a/spec/services/ci/compare_test_reports_service_spec.rb b/spec/services/ci/compare_test_reports_service_spec.rb new file mode 100644 index 00000000000..6278774f446 --- /dev/null +++ b/spec/services/ci/compare_test_reports_service_spec.rb @@ -0,0 +1,55 @@ +require 'spec_helper' + +describe Ci::CompareTestReportsService do + let(:service) { described_class.new(project) } + let(:project) { create(:project, :repository) } + let(:merge_request) { create(:merge_request, source_project: project) } + + describe '#execute' do + subject { service.execute(base_pipeline.iid, head_pipeline.iid) } + + let!(:base_pipeline) do + create(:ci_pipeline, + :success, + project: merge_request.source_project, + ref: merge_request.source_branch, + sha: merge_request.diff_base_sha).tap do |pipeline| + merge_request.update!(head_pipeline_id: pipeline.id) + create(:ci_build, name: 'rspec', pipeline: pipeline, project: project) + end + end + + let!(:head_pipeline) do + create(:ci_pipeline, + :success, + project: merge_request.source_project, + ref: merge_request.source_branch, + sha: merge_request.diff_head_sha).tap do |pipeline| + merge_request.update!(head_pipeline_id: pipeline.id) + create(:ci_build, name: 'rspec', pipeline: pipeline, project: project) + end + end + + context 'when head pipeline has test reports' do + before do + create(:ci_job_artifact, :junit, job: head_pipeline.builds.first, project: project) + end + + it 'returns status and data' do + expect(subject[:status]).to eq(:parsed) + expect(subject[:data]).to match_schema('entities/test_reports_comparer') + end + end + + context 'when head pipeline has corrupted test reports' do + before do + create(:ci_job_artifact, :junit_with_corrupted_data, job: head_pipeline.builds.first, project: project) + end + + it 'returns status and error message' do + expect(subject[:status]).to eq(:error) + expect(subject[:status_reason]).to eq('Failed to parse XML') + end + end + end +end |