From 48cdd4b1ee0685674aa998d4daa295656d80ead3 Mon Sep 17 00:00:00 2001 From: Azul Date: Thu, 22 Sep 2016 11:07:47 +0200 Subject: feature: 502 on ConnectionErrors If one source raises a 502 and no other handler has any result we'll respond with a 502 - bad gateway. --- test/integration/dispatcher_test.rb | 20 ++++++++++++++++++++ 1 file changed, 20 insertions(+) (limited to 'test') diff --git a/test/integration/dispatcher_test.rb b/test/integration/dispatcher_test.rb index b3a50a0..4f13e6b 100644 --- a/test/integration/dispatcher_test.rb +++ b/test/integration/dispatcher_test.rb @@ -48,6 +48,20 @@ class Nickserver::DispatcherTest < Minitest::Test assert_response success end + def test_email_via_hkp_nicknym_unreachable + handle address: ['valid@email.tld'], headers: { "Host" => "http://nickserver.me" } + stub_nicknym_raises + hkp_source.expect :query, success, [Nickserver::EmailAddress] + assert_response success + end + + def test_email_via_hkp_nicknym_unreachable + handle address: ['valid@email.tld'], headers: { "Host" => "http://nickserver.me" } + stub_nicknym_raises + hkp_source.expect :query, nil, [Nickserver::EmailAddress] + assert_response response(status: 502, content: "HTTP::ConnectionError") + end + def test_email_via_nicknym handle address: ['valid@email.tld'], headers: { "Host" => "http://nickserver.me" } nicknym_source.expect :available_for?, true, [String] @@ -90,6 +104,12 @@ class Nickserver::DispatcherTest < Minitest::Test end end + def stub_nicknym_raises + def nicknym_source.available_for?(*_args) + raise HTTP::ConnectionError + end + end + def nicknym_source @nicknym_source ||= Minitest::Mock.new end -- cgit v1.2.3