diff options
author | Akihiko Odaki (@fn_aki@pawoo.net) <akihiko.odaki.4i@stu.hosei.ac.jp> | 2017-06-05 00:13:37 +0900 |
---|---|---|
committer | Eugen Rochko <eugen@zeonfederated.com> | 2017-06-04 17:13:37 +0200 |
commit | defe4f9bc3407cde4d5b1918778b0754ef7f4970 (patch) | |
tree | 5649577ee166b85b3980ced895a968a3ed500165 | |
parent | 943775fd9071d5c9c155aa10f6bad69ec8cc8758 (diff) |
Cover WebfingerResource more (#3560)
-rw-r--r-- | spec/lib/webfinger_resource_spec.rb | 41 |
1 files 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 |