account_controller_test.rb
222 lines
| 7.4 KiB
| text/x-ruby
|
RubyLexer
|
r5869 | # Redmine - project management software | ||
# Copyright (C) 2006-2011 Jean-Philippe Lang | ||||
|
r974 | # | ||
# This program is free software; you can redistribute it and/or | ||||
# modify it under the terms of the GNU General Public License | ||||
# as published by the Free Software Foundation; either version 2 | ||||
# of the License, or (at your option) any later version. | ||||
|
r5869 | # | ||
|
r974 | # This program is distributed in the hope that it will be useful, | ||
# but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||||
# GNU General Public License for more details. | ||||
|
r5869 | # | ||
|
r974 | # You should have received a copy of the GNU General Public License | ||
# along with this program; if not, write to the Free Software | ||||
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. | ||||
|
r4395 | require File.expand_path('../../test_helper', __FILE__) | ||
|
r974 | require 'account_controller' | ||
# Re-raise errors caught by the controller. | ||||
class AccountController; def rescue_action(e) raise e end; end | ||||
|
r2773 | class AccountControllerTest < ActionController::TestCase | ||
|
r2188 | fixtures :users, :roles | ||
|
r5869 | |||
|
r974 | def setup | ||
@controller = AccountController.new | ||||
@request = ActionController::TestRequest.new | ||||
@response = ActionController::TestResponse.new | ||||
User.current = nil | ||||
end | ||||
|
r5869 | |||
|
r1686 | def test_login_should_redirect_to_back_url_param | ||
# request.uri is "test.host" in test environment | ||||
|
r1891 | post :login, :username => 'jsmith', :password => 'jsmith', :back_url => 'http%3A%2F%2Ftest.host%2Fissues%2Fshow%2F1' | ||
|
r1686 | assert_redirected_to '/issues/show/1' | ||
end | ||||
|
r5869 | |||
|
r1686 | def test_login_should_not_redirect_to_another_host | ||
|
r1891 | post :login, :username => 'jsmith', :password => 'jsmith', :back_url => 'http%3A%2F%2Ftest.foo%2Ffake' | ||
|
r1686 | assert_redirected_to '/my/page' | ||
end | ||||
|
r974 | def test_login_with_wrong_password | ||
|
r1167 | post :login, :username => 'admin', :password => 'bad' | ||
|
r974 | assert_response :success | ||
assert_template 'login' | ||||
assert_tag 'div', | ||||
:attributes => { :class => "flash error" }, | ||||
:content => /Invalid user or password/ | ||||
end | ||||
|
r5869 | |||
|
r2397 | if Object.const_defined?(:OpenID) | ||
|
r5869 | |||
|
r2386 | def test_login_with_openid_for_existing_user | ||
|
r2385 | Setting.self_registration = '3' | ||
|
r2388 | Setting.openid = '1' | ||
|
r2386 | existing_user = User.new(:firstname => 'Cool', | ||
:lastname => 'User', | ||||
:mail => 'user@somedomain.com', | ||||
:identity_url => 'http://openid.example.com/good_user') | ||||
existing_user.login = 'cool_user' | ||||
assert existing_user.save! | ||||
post :login, :openid_url => existing_user.identity_url | ||||
|
r4293 | assert_redirected_to '/my/page' | ||
|
r2383 | end | ||
|
r3819 | def test_login_with_invalid_openid_provider | ||
Setting.self_registration = '0' | ||||
Setting.openid = '1' | ||||
post :login, :openid_url => 'http;//openid.example.com/good_user' | ||||
assert_redirected_to home_url | ||||
end | ||||
|
r5869 | |||
|
r2420 | def test_login_with_openid_for_existing_non_active_user | ||
Setting.self_registration = '2' | ||||
Setting.openid = '1' | ||||
existing_user = User.new(:firstname => 'Cool', | ||||
:lastname => 'User', | ||||
:mail => 'user@somedomain.com', | ||||
:identity_url => 'http://openid.example.com/good_user', | ||||
:status => User::STATUS_REGISTERED) | ||||
existing_user.login = 'cool_user' | ||||
assert existing_user.save! | ||||
post :login, :openid_url => existing_user.identity_url | ||||
|
r4293 | assert_redirected_to '/login' | ||
|
r2420 | end | ||
|
r2383 | def test_login_with_openid_with_new_user_created | ||
|
r2385 | Setting.self_registration = '3' | ||
|
r2388 | Setting.openid = '1' | ||
|
r2384 | post :login, :openid_url => 'http://openid.example.com/good_user' | ||
|
r4293 | assert_redirected_to '/my/account' | ||
|
r2384 | user = User.find_by_login('cool_user') | ||
assert user | ||||
assert_equal 'Cool', user.firstname | ||||
assert_equal 'User', user.lastname | ||||
|
r2383 | end | ||
|
r2387 | |||
def test_login_with_openid_with_new_user_and_self_registration_off | ||||
Setting.self_registration = '0' | ||||
|
r2388 | Setting.openid = '1' | ||
|
r2387 | post :login, :openid_url => 'http://openid.example.com/good_user' | ||
assert_redirected_to home_url | ||||
user = User.find_by_login('cool_user') | ||||
assert ! user | ||||
end | ||||
|
r2385 | def test_login_with_openid_with_new_user_created_with_email_activation_should_have_a_token | ||
Setting.self_registration = '1' | ||||
|
r2388 | Setting.openid = '1' | ||
|
r2385 | post :login, :openid_url => 'http://openid.example.com/good_user' | ||
|
r4293 | assert_redirected_to '/login' | ||
|
r2385 | user = User.find_by_login('cool_user') | ||
assert user | ||||
token = Token.find_by_user_id_and_action(user.id, 'register') | ||||
assert token | ||||
end | ||||
|
r5869 | |||
|
r2385 | def test_login_with_openid_with_new_user_created_with_manual_activation | ||
Setting.self_registration = '2' | ||||
|
r2388 | Setting.openid = '1' | ||
|
r2385 | post :login, :openid_url => 'http://openid.example.com/good_user' | ||
|
r4293 | assert_redirected_to '/login' | ||
|
r2385 | user = User.find_by_login('cool_user') | ||
assert user | ||||
assert_equal User::STATUS_REGISTERED, user.status | ||||
end | ||||
|
r5869 | |||
|
r2384 | def test_login_with_openid_with_new_user_with_conflict_should_register | ||
|
r2385 | Setting.self_registration = '3' | ||
|
r2388 | Setting.openid = '1' | ||
|
r2384 | existing_user = User.new(:firstname => 'Cool', :lastname => 'User', :mail => 'user@somedomain.com') | ||
existing_user.login = 'cool_user' | ||||
assert existing_user.save! | ||||
|
r5869 | |||
|
r2384 | 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] | ||||
|
r2383 | end | ||
|
r5869 | |||
|
r2419 | def test_setting_openid_should_return_true_when_set_to_true | ||
Setting.openid = '1' | ||||
assert_equal true, Setting.openid? | ||||
end | ||||
|
r5869 | |||
|
r2397 | else | ||
puts "Skipping openid tests." | ||||
end | ||||
|
r5869 | |||
|
r974 | def test_logout | ||
@request.session[:user_id] = 2 | ||||
get :logout | ||||
|
r4293 | assert_redirected_to '/' | ||
|
r974 | assert_nil @request.session[:user_id] | ||
end | ||||
|
r3789 | |||
|
r8129 | def test_get_register_with_registration_on | ||
with_settings :self_registration => '3' do | ||||
get :register | ||||
assert_response :success | ||||
assert_template 'register' | ||||
assert_not_nil assigns(:user) | ||||
|
r8662 | |||
assert_tag 'input', :attributes => {:name => 'user[password]'} | ||||
assert_tag 'input', :attributes => {:name => 'user[password_confirmation]'} | ||||
|
r3789 | end | ||
|
r8129 | end | ||
|
r5869 | |||
|
r8129 | def test_get_register_with_registration_off_should_redirect | ||
with_settings :self_registration => '0' do | ||||
get :register | ||||
assert_redirected_to '/' | ||||
|
r3789 | end | ||
end | ||||
|
r3790 | |||
# See integration/account_test.rb for the full test | ||||
|
r8129 | def test_post_register_with_registration_on | ||
with_settings :self_registration => '3' do | ||||
assert_difference 'User.count' do | ||||
|
r3790 | post :register, :user => { | ||
:login => 'register', | ||||
:password => 'test', | ||||
:password_confirmation => 'test', | ||||
:firstname => 'John', | ||||
:lastname => 'Doe', | ||||
:mail => 'register@example.com' | ||||
} | ||||
|
r8129 | assert_redirected_to '/my/account' | ||
|
r3790 | end | ||
|
r8129 | user = User.first(:order => 'id DESC') | ||
assert_equal 'register', user.login | ||||
|
r8662 | assert_equal 'John', user.firstname | ||
assert_equal 'Doe', user.lastname | ||||
assert_equal 'register@example.com', user.mail | ||||
assert user.check_password?('test') | ||||
|
r8129 | assert user.active? | ||
|
r3790 | end | ||
|
r8129 | end | ||
def test_post_register_with_registration_off_should_redirect | ||||
with_settings :self_registration => '0' do | ||||
assert_no_difference 'User.count' do | ||||
post :register, :user => { | ||||
:login => 'register', | ||||
:password => 'test', | ||||
:password_confirmation => 'test', | ||||
:firstname => 'John', | ||||
:lastname => 'Doe', | ||||
:mail => 'register@example.com' | ||||
} | ||||
assert_redirected_to '/' | ||||
|
r3790 | end | ||
end | ||||
end | ||||
|
r974 | end | ||