about summary refs log tree commit diff
path: root/spec/lib
diff options
context:
space:
mode:
Diffstat (limited to 'spec/lib')
-rw-r--r--spec/lib/webfinger_resource_spec.rb41
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