]> source.dussan.org Git - redmine.git/commitdiff
Adding OpenID mock and test. #699
authorEric Davis <edavis@littlestreamsoftware.com>
Wed, 11 Feb 2009 19:07:18 +0000 (19:07 +0000)
committerEric Davis <edavis@littlestreamsoftware.com>
Wed, 11 Feb 2009 19:07:18 +0000 (19:07 +0000)
git-svn-id: svn+ssh://rubyforge.org/var/svn/redmine/trunk@2444 e93f8b46-1217-0410-a6f0-8f06a7374b81

test/functional/account_controller_test.rb
test/mocks/open_id_authentication_mock.rb [new file with mode: 0644]
test/test_helper.rb

index 4d96a3f3b72a2bf40bfe28193cb563ca2eef9c56..8de6f64b51b4c6d1a21a41ff8ba40c137b1b9586 100644 (file)
@@ -64,6 +64,20 @@ class AccountControllerTest < Test::Unit::TestCase
                :content => /Invalid user or password/
   end
   
+  def test_login_with_openid
+    post :login, :openid_url => 'http://openid.example.com/good_user'
+    assert_redirected_to 'my/page'
+  end
+
+  def test_login_with_openid_with_new_user_created
+
+  end
+  
+  
+  def test_login_with_openid_with_new_user_with_conflict
+    
+  end
+  
   def test_autologin
     Setting.autologin = "7"
     Token.delete_all
diff --git a/test/mocks/open_id_authentication_mock.rb b/test/mocks/open_id_authentication_mock.rb
new file mode 100644 (file)
index 0000000..cca1e9e
--- /dev/null
@@ -0,0 +1,45 @@
+# Mocks out OpenID
+#
+# http://www.northpub.com/articles/2007/04/02/testing-openid-support
+module OpenIdAuthentication 
+
+  EXTENSION_FIELDS = {'email' => 'user@somedomain.com',
+                      'nickname' => 'cool_user',
+                      'country' => 'US',
+                      'postcode' => '12345',
+                      'fullname' => 'Cool User',
+                      'dob' => '1970-04-01',
+                      'language' => 'en',
+                      'timezone' => 'America/New_York'}     
+
+  protected
+
+    def authenticate_with_open_id(identity_url = params[:openid_url], options = {}) #:doc:
+      if User.find_by_identity_url(identity_url) || identity_url.include?('good')
+        # Don't process registration fields unless it is requested.
+        unless identity_url.include?('blank') || (options[:required].nil? && options[:optional].nil?)
+          extension_response_fields = {}
+
+          options[:required].each do |field|
+            extension_response_fields[field.to_s] = EXTENSION_FIELDS[field.to_s]
+          end unless options[:required].nil?
+
+          options[:optional].each do |field|
+            extension_response_fields[field.to_s] = EXTENSION_FIELDS[field.to_s]
+          end unless options[:optional].nil?
+        end
+
+        yield Result[:successful], identity_url , extension_response_fields
+      else
+        logger.info "OpenID authentication failed: #{identity_url}" 
+        yield Result[:failed], identity_url, nil
+      end
+    end
+
+  private
+
+    def add_simple_registration_fields(open_id_response, fields)
+      open_id_response.add_extension_arg('sreg', 'required', [ fields[:required] ].flatten * ',') if fields[:required]
+      open_id_response.add_extension_arg('sreg', 'optional', [ fields[:optional] ].flatten * ',') if fields[:optional]
+    end
+end
index f61b88d8c411a1824020f5ba45d4590ecbf661a2..57866d49e59021b51fe4533494166736fb857e27 100644 (file)
@@ -19,6 +19,7 @@ ENV["RAILS_ENV"] ||= "test"
 require File.expand_path(File.dirname(__FILE__) + "/../config/environment")
 require 'test_help'
 require File.expand_path(File.dirname(__FILE__) + '/helper_testcase')
+load File.join(RAILS_ROOT,'test', 'mocks', 'open_id_authentication_mock.rb')
 
 class Test::Unit::TestCase
   # Transactional fixtures accelerate your tests by wrapping each test method