diff options
-rw-r--r-- | lib/nickserver/email_address.rb | 6 | ||||
-rw-r--r-- | lib/nickserver/nicknym/source.rb | 14 | ||||
-rw-r--r-- | lib/nickserver/request_handlers/leap_email_handler.rb | 36 | ||||
-rw-r--r-- | test/support/request_handler_test_helper.rb | 6 | ||||
-rw-r--r-- | test/unit/adapters/celluloid_http_test.rb | 11 | ||||
-rw-r--r-- | test/unit/email_address_test.rb | 1 | ||||
-rw-r--r-- | test/unit/nicknym/source_test.rb | 33 | ||||
-rw-r--r-- | test/unit/request_handlers/leap_email_handler_test.rb | 41 |
8 files changed, 143 insertions, 5 deletions
diff --git a/lib/nickserver/email_address.rb b/lib/nickserver/email_address.rb index 2b3f2c2..c5d5df7 100644 --- a/lib/nickserver/email_address.rb +++ b/lib/nickserver/email_address.rb @@ -30,7 +30,11 @@ module Nickserver end def domain?(domain) - address.end_with? "@#{domain}" + domain == self.domain + end + + def domain + address.split('@')[1] end def to_s diff --git a/lib/nickserver/nicknym/source.rb b/lib/nickserver/nicknym/source.rb new file mode 100644 index 0000000..1be0c2a --- /dev/null +++ b/lib/nickserver/nicknym/source.rb @@ -0,0 +1,14 @@ +require 'nickserver/source' + +module Nickserver + module Nicknym + class Source < Nickserver::Source + + def available_for?(domain) + status, _body = adapter.get "https://#{domain}/provider.json" + status == 200 + end + + end + end +end diff --git a/lib/nickserver/request_handlers/leap_email_handler.rb b/lib/nickserver/request_handlers/leap_email_handler.rb new file mode 100644 index 0000000..548bc8a --- /dev/null +++ b/lib/nickserver/request_handlers/leap_email_handler.rb @@ -0,0 +1,36 @@ +require 'nickserver/email_address' +require 'nickserver/nicknym/source' + +module Nickserver + module RequestHandlers + class LeapEmailHandler < Base + + def handle + source.query(email) if request.email && remote_email? && nicknym_email? + end + + protected + + def source + @source ||= Nicknym::Source.new + end + + def remote_email? + !email.domain?(domain) + end + + def nicknym_email? + source.available_for?(email.domain) + end + + def email + @email ||= EmailAddress.new(request.email) + end + + def domain + Config.domain || request.domain + end + + end + end +end diff --git a/test/support/request_handler_test_helper.rb b/test/support/request_handler_test_helper.rb index 3ca89ba..dd6940d 100644 --- a/test/support/request_handler_test_helper.rb +++ b/test/support/request_handler_test_helper.rb @@ -15,9 +15,9 @@ module RequestHandlerTestHelper end def source_expecting_query_for(*query_args) - source = Minitest::Mock.new - source.expect :query, 'response', query_args - source + @source ||= Minitest::Mock.new + @source.expect :query, 'response', query_args + @source end def assert_responds_with_error(msg, opts) diff --git a/test/unit/adapters/celluloid_http_test.rb b/test/unit/adapters/celluloid_http_test.rb index 4381b8f..68b9606 100644 --- a/test/unit/adapters/celluloid_http_test.rb +++ b/test/unit/adapters/celluloid_http_test.rb @@ -13,7 +13,16 @@ class Nickserver::Adapters::CelluloidHttpTest < Minitest::Test super end - def test_successful_request + def test_request_without_query + url = 'http://url.to' + stub_http_request(:get, url) + .to_return status: 200, body: 'body' + status, body = adapter.get url + assert_equal 200, status + assert_equal 'body', body + end + + def test_successful_request_with_query url = 'http://url.to' stub_http_request(:get, url) .with(query: {key: :value}) diff --git a/test/unit/email_address_test.rb b/test/unit/email_address_test.rb index 6d57a8c..6aecef7 100644 --- a/test/unit/email_address_test.rb +++ b/test/unit/email_address_test.rb @@ -5,6 +5,7 @@ class EmailAddressTest < Minitest::Test def test_domain nick = Nickserver::EmailAddress.new 'nick@test.me' + assert_equal 'test.me', nick.domain assert nick.domain?('test.me') assert !nick.domain?('est.me') end diff --git a/test/unit/nicknym/source_test.rb b/test/unit/nicknym/source_test.rb new file mode 100644 index 0000000..586dc0e --- /dev/null +++ b/test/unit/nicknym/source_test.rb @@ -0,0 +1,33 @@ +require 'test_helper' +require 'nickserver/nicknym/source' + +class NicknymSourceTest < Minitest::Test + + def test_initialization + assert source + end + + def test_available_for_domain + adapter.expect :get, [200, 'dummy body'], + ['https://leap_powered.tld/provider.json'] + assert source.available_for?('leap_powered.tld') + adapter.verify + end + + def test_not_available_for_domain + adapter.expect :get, [404, nil], + ['https://remote.tld/provider.json'] + assert !source.available_for?('remote.tld') + adapter.verify + end + + protected + + def source + Nickserver::Nicknym::Source.new(adapter) + end + + def adapter + @adapter ||= Minitest::Mock.new + end +end diff --git a/test/unit/request_handlers/leap_email_handler_test.rb b/test/unit/request_handlers/leap_email_handler_test.rb new file mode 100644 index 0000000..fadb914 --- /dev/null +++ b/test/unit/request_handlers/leap_email_handler_test.rb @@ -0,0 +1,41 @@ +require 'test_helper' +require 'support/request_handler_test_helper' +require 'nickserver/request_handlers/leap_email_handler' + +class LeapEmailHandlerTest < MiniTest::Test + include RequestHandlerTestHelper + + def test_no_email + assert_refuses + end + + def test_local_email + assert_refuses email: 'me@local.tld', domain: 'local.tld' + end + + def test_remote_email + source ||= Minitest::Mock.new + source.expect :available_for?, false, ['remote.tld'] + source_class.stub :new, source do + assert_refuses email: 'me@remote.tld', domain: 'local.tld' + end + end + + def test_nicknym_email + @source ||= Minitest::Mock.new + @source.expect :available_for?, true, ['nicknym.tld'] + assert_queries_for Nickserver::EmailAddress do + assert_handles email: 'me@nicknym.tld', domain: 'local.tld' + end + end + + protected + + def handler + Nickserver::RequestHandlers::LeapEmailHandler + end + + def source_class + Nickserver::Nicknym::Source + end +end |