commit: defe4f9bc3407cde4d5b1918778b0754ef7f4970
parent: 943775fd9071d5c9c155aa10f6bad69ec8cc8758
Author: Akihiko Odaki (@fn_aki@pawoo.net) <akihiko.odaki.4i@stu.hosei.ac.jp>
Date: Mon, 5 Jun 2017 00:13:37 +0900
Cover WebfingerResource more (#3560)
Diffstat:
1 file changed, 37 insertions(+), 4 deletions(-)
diff --git 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