From 6c3b40b641ac80729113161d813d6a34e3bb4a6e Mon Sep 17 00:00:00 2001 From: Eric Mueller Date: Wed, 24 May 2023 08:55:37 -0400 Subject: [PATCH] consider a tool to 'fail' if there are messages, not if it thinks it failed when filtering messages based on changed-files, we don't want the tool to say it failed, but then supply zero messages. Instead, the pipeline should claim to have passed --- lib/quiet_quality/executors/pipeline.rb | 2 +- spec/quiet_quality/executors/pipeline_spec.rb | 18 ++++++++++++++---- 2 files changed, 15 insertions(+), 5 deletions(-) diff --git a/lib/quiet_quality/executors/pipeline.rb b/lib/quiet_quality/executors/pipeline.rb index c165f59..9afa221 100644 --- a/lib/quiet_quality/executors/pipeline.rb +++ b/lib/quiet_quality/executors/pipeline.rb @@ -15,7 +15,7 @@ def outcome end def failure? - outcome.failure? + messages.any? end def messages diff --git a/spec/quiet_quality/executors/pipeline_spec.rb b/spec/quiet_quality/executors/pipeline_spec.rb index 2f60858..b3d969c 100644 --- a/spec/quiet_quality/executors/pipeline_spec.rb +++ b/spec/quiet_quality/executors/pipeline_spec.rb @@ -13,9 +13,10 @@ let(:runner) { instance_double(QuietQuality::Tools::Rspec::Runner, invoke!: runner_outcome) } before { allow(QuietQuality::Tools::Rspec::Runner).to receive(:new).and_return(runner) } + let(:other_messages) { generate_messages(4, path: "path/other.rb") } let(:foo_message) { generate_message(path: "path/foo.rb", start_line: 3, stop_line: 7, body: "foo text") } let(:bar_message) { generate_message(path: "path/bar.rb", start_line: 8, stop_line: 12, body: "bar text") } - let(:parsed_messages) { QuietQuality::Messages.new(generate_messages(4) + [foo_message, bar_message]) } + let(:parsed_messages) { QuietQuality::Messages.new(other_messages + [foo_message, bar_message]) } let(:parser) { instance_double(QuietQuality::Tools::Rspec::Parser, messages: parsed_messages) } before { allow(QuietQuality::Tools::Rspec::Parser).to receive(:new).and_return(parser) } @@ -33,10 +34,19 @@ describe "#failure?" do subject(:failure?) { pipeline.failure? } - it { is_expected.to be_truthy } - context "when the runner succeeds" do - let(:runner_outcome) { build_success(tool_name, "fake output", "fake logging") } + context "when there are messages from the tool" do + let(:parsed_messages) { QuietQuality::Messages.new(other_messages + [foo_message, bar_message]) } + it { is_expected.to be_truthy } + + context "but they are all filtered" do + let(:parsed_messages) { QuietQuality::Messages.new(other_messages) } + it { is_expected.to be_falsey } + end + end + + context "when there are no messages from the tool" do + let(:parsed_messages) { empty_messages } it { is_expected.to be_falsey } end end