From 24ce8f4c2052b12ed336078e7bac21863ac169f0 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?D=C3=A1vid=20Hal=C3=A1sz?= Date: Wed, 31 Jul 2019 22:43:44 +0200 Subject: [PATCH] Don't load BinaryBlobParts when determining if MiqReportResult is blank Fixes https://bugzilla.redhat.com/show_bug.cgi?id=1725142 --- app/models/miq_report_result.rb | 11 ++++++++++- spec/models/miq_report_result_spec.rb | 19 +++++++++++++++++++ 2 files changed, 29 insertions(+), 1 deletion(-) diff --git a/app/models/miq_report_result.rb b/app/models/miq_report_result.rb index a513e3c72365..9aa09a69e9e7 100644 --- a/app/models/miq_report_result.rb +++ b/app/models/miq_report_result.rb @@ -73,7 +73,16 @@ def status if miq_task miq_task.human_status else - report_results.blank? ? "Error" : "Complete" + report_results_blank? ? "Error" : "Complete" + end + end + + # This method doesn't run through all binary blob parts to determine if it has any + def report_results_blank? + if binary_blob + binary_blob.parts.zero? + elsif report.kind_of?(MiqReport) + report.blank? end end diff --git a/spec/models/miq_report_result_spec.rb b/spec/models/miq_report_result_spec.rb index d7262e1c5d95..5a94345371cc 100644 --- a/spec/models/miq_report_result_spec.rb +++ b/spec/models/miq_report_result_spec.rb @@ -190,6 +190,25 @@ end end + describe '#report_results_blank?' do + let(:report_result) { FactoryBot.create(:miq_report_result) } + subject { report_result.report_result_blank? } + + context 'report has a binary blob' do + let(:binary_blob) { FactoryBot.create(:binary_blob) } + before { report_result.binary_blob = binary_blob } + + context 'binary blob is empty' do + it { is_expected.to be_truthy } + end + + context 'binary blob has parts' do + before { binary_blob.data = "foo" } + it { is_expected.to be_falsey } + end + end + end + describe "serializing and deserializing report results" do it "can serialize and deserialize an MiqReport" do report = FactoryBot.build(:miq_report)