From defe4f9bc3407cde4d5b1918778b0754ef7f4970 Mon Sep 17 00:00:00 2001 From: "Akihiko Odaki (@fn_aki@pawoo.net)" Date: Mon, 5 Jun 2017 00:13:37 +0900 Subject: [PATCH] Cover WebfingerResource more (#3560) --- spec/lib/webfinger_resource_spec.rb | 41 ++++++++++++++++++++++++++--- 1 file changed, 37 insertions(+), 4 deletions(-) diff --git a/spec/lib/webfinger_resource_spec.rb b/spec/lib/webfinger_resource_spec.rb index dfd23062f..3c3d263ef 100644 --- a/spec/lib/webfinger_resource_spec.rb +++ b/spec/lib/webfinger_resource_spec.rb @@ -2,14 +2,16 @@ require 'rails_helper' describe WebfingerResource do around do |example| - before = Rails.configuration.x.local_domain + before_local = Rails.configuration.x.local_domain + before_web = Rails.configuration.x.web_domain example.run - Rails.configuration.x.local_domain = before + Rails.configuration.x.local_domain = before_local + Rails.configuration.x.webdomain = before_web end describe '#username' do describe 'with a URL value' do - it 'raises with an unrecognized route' do + it 'raises with a route whose controller is not AccountsController' do resource = 'https://example.com/users/alice/other' expect { @@ -17,6 +19,21 @@ describe WebfingerResource do }.to raise_error(ActiveRecord::RecordNotFound) end + it 'raises with a route whose action is not show' do + resource = 'https://example.com/users/alice' + + recognized = Rails.application.routes.recognize_path(resource) + allow(recognized).to receive(:[]).with(:controller).and_return('accounts') + allow(recognized).to receive(:[]).with(:username).and_return('alice') + expect(recognized).to receive(:[]).with(:action).and_return('create') + + expect(Rails.application.routes).to receive(:recognize_path).with(resource).and_return(recognized).at_least(:once) + + expect { + WebfingerResource.new(resource).username + }.to raise_error(ActiveRecord::RecordNotFound) + end + it 'raises with a string that doesnt start with URL' do resource = 'website for http://example.com/users/alice/other' @@ -63,6 +80,14 @@ describe WebfingerResource do result = WebfingerResource.new(resource).username expect(result).to eq 'alice' end + + it 'finds username for a web domain' do + Rails.configuration.x.web_domain = 'example.com' + resource = 'alice@example.com' + + result = WebfingerResource.new(resource).username + expect(result).to eq 'alice' + end end describe 'with an acct value' do @@ -82,13 +107,21 @@ describe WebfingerResource do }.to raise_error(ActiveRecord::RecordNotFound) end - it 'finds the username for a local account' do + it 'finds the username for a local account if the domain is the local one' do Rails.configuration.x.local_domain = 'example.com' resource = 'acct:alice@example.com' result = WebfingerResource.new(resource).username expect(result).to eq 'alice' end + + it 'finds the username for a local account if the domain is the Web one' do + Rails.configuration.x.web_domain = 'example.com' + resource = 'acct:alice@example.com' + + result = WebfingerResource.new(resource).username + expect(result).to eq 'alice' + end end end end