From 2da3657410637ead22c0a36b1c75c9ac952278f2 Mon Sep 17 00:00:00 2001 From: Beth Skurrie Date: Fri, 28 Feb 2020 09:39:20 +1100 Subject: [PATCH] fix: gracefully handle badge redirects when the pact is not found --- lib/pact_broker/badges/service.rb | 1 + spec/lib/pact_broker/badges/service_spec.rb | 57 +++++++++++++-------- 2 files changed, 37 insertions(+), 21 deletions(-) diff --git a/lib/pact_broker/badges/service.rb b/lib/pact_broker/badges/service.rb index 17781bb6a..a9b3da790 100644 --- a/lib/pact_broker/badges/service.rb +++ b/lib/pact_broker/badges/service.rb @@ -39,6 +39,7 @@ def clear_cache private def badge_title pact, label, initials + return 'pact not found' if pact.nil? title = case (label || '').downcase when 'consumer' then prepare_name(pact.consumer_name, initials) when 'provider' then prepare_name(pact.provider_name, initials) diff --git a/spec/lib/pact_broker/badges/service_spec.rb b/spec/lib/pact_broker/badges/service_spec.rb index ce3e47b25..054994abd 100644 --- a/spec/lib/pact_broker/badges/service_spec.rb +++ b/spec/lib/pact_broker/badges/service_spec.rb @@ -3,31 +3,46 @@ module PactBroker module Badges - module Service - describe "#pact_verification_badge" do - let(:pacticipant_name) { "Foo-Bar_Thing Service" } - let(:pact) { double("pact", consumer_name: "Foo-Bar", provider_name: "Thing_Blah") } - let(:label) { nil } - let(:initials) { false } - let(:pseudo_branch_verification_status) { :success } - let(:logger) { double('logger').as_null_object } - let(:expected_url) { "https://img.shields.io/badge/#{expected_left_text}-#{expected_right_text}-#{expected_color}.svg" } - let(:expected_color) { "brightgreen" } - let(:expected_right_text) { "verified" } - let(:expected_left_text) { "foo--bar%2fthing__blah%20pact" } - let(:response_status) { 200 } - let!(:http_request) do - stub_request(:get, expected_url).to_return(:status => response_status, :body => "svg") - end + describe Service do + let(:pacticipant_name) { "Foo-Bar_Thing Service" } + let(:pact) { double("pact", consumer_name: "Foo-Bar", provider_name: "Thing_Blah") } + let(:label) { nil } + let(:initials) { false } + let(:pseudo_branch_verification_status) { :success } + let(:logger) { double('logger').as_null_object } + let(:expected_url) { "https://img.shields.io/badge/#{expected_left_text}-#{expected_right_text}-#{expected_color}.svg" } + let(:expected_color) { "brightgreen" } + let(:expected_right_text) { "verified" } + let(:expected_left_text) { "foo--bar%2fthing__blah%20pact" } + let(:response_status) { 200 } + let!(:http_request) do + stub_request(:get, expected_url).to_return(:status => response_status, :body => "svg") + end + + subject { PactBroker::Badges::Service.pact_verification_badge pact, label, initials, pseudo_branch_verification_status } - subject { PactBroker::Badges::Service.pact_verification_badge pact, label, initials, pseudo_branch_verification_status } + let(:pact_verification_badge_url) { PactBroker::Badges::Service.pact_verification_badge_url(pact, label, initials, pseudo_branch_verification_status) } - let(:pact_verification_badge_url) { PactBroker::Badges::Service.pact_verification_badge_url(pact, label, initials, pseudo_branch_verification_status) } + before do + Service.clear_cache + allow(Service).to receive(:logger).and_return(logger) + end - before do - Service.clear_cache - allow(Service).to receive(:logger).and_return(logger) + describe "pact_verification_badge_url" do + context "with the pact is nil" do + let(:pact) { nil } + let(:expected_left_text) { "pact%20not%20found" } + let(:expected_right_text) { "unknown" } + let(:expected_color) { "lightgrey" } + let(:pseudo_branch_verification_status) { :never } + + it "returns a link to a 'pact not found' badge" do + expect(pact_verification_badge_url).to eq URI(expected_url) + end end + end + + describe "#pact_verification_badge" do it "returns the svg file" do expect(subject).to eq "svg"