summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--app/controllers/account_controller.rb6
-rw-r--r--test/functional/account_controller_test.rb18
-rw-r--r--test/test_helper.rb2
3 files changed, 19 insertions, 7 deletions
diff --git a/app/controllers/account_controller.rb b/app/controllers/account_controller.rb
index cdbca5927..09c11927c 100644
--- a/app/controllers/account_controller.rb
+++ b/app/controllers/account_controller.rb
@@ -201,9 +201,9 @@ private
user = User.find_or_initialize_by_identity_url(identity_url)
if user.new_record?
# Create on the fly
- user.login = registration['nickname']
- user.mail = registration['email']
- user.firstname, user.lastname = registration['fullname'].split(' ')
+ user.login = registration['nickname'] unless registration['nickname'].nil?
+ user.mail = registration['email'] unless registration['email'].nil?
+ user.firstname, user.lastname = registration['fullname'].split(' ') unless registration['fullname'].nil?
user.random_password
if user.save
successful_authentication(user)
diff --git a/test/functional/account_controller_test.rb b/test/functional/account_controller_test.rb
index 8de6f64b5..e262b3716 100644
--- a/test/functional/account_controller_test.rb
+++ b/test/functional/account_controller_test.rb
@@ -70,12 +70,24 @@ class AccountControllerTest < Test::Unit::TestCase
end
def test_login_with_openid_with_new_user_created
-
+ post :login, :openid_url => 'http://openid.example.com/good_user'
+ assert_redirected_to 'my/page'
+ user = User.find_by_login('cool_user')
+ assert user
+ assert_equal 'Cool', user.firstname
+ assert_equal 'User', user.lastname
end
-
- def test_login_with_openid_with_new_user_with_conflict
+ def test_login_with_openid_with_new_user_with_conflict_should_register
+ existing_user = User.new(:firstname => 'Cool', :lastname => 'User', :mail => 'user@somedomain.com')
+ existing_user.login = 'cool_user'
+ assert existing_user.save!
+ post :login, :openid_url => 'http://openid.example.com/good_user'
+ assert_response :success
+ assert_template 'register'
+ assert assigns(:user)
+ assert_equal 'http://openid.example.com/good_user', assigns(:user)[:identity_url]
end
def test_autologin
diff --git a/test/test_helper.rb b/test/test_helper.rb
index 57866d49e..ebc9bae46 100644
--- a/test/test_helper.rb
+++ b/test/test_helper.rb
@@ -19,7 +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')
+require 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