123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247 |
- # Redmine - project management software
- # Copyright (C) 2006-2012 Jean-Philippe Lang
- #
- # 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.
- #
- # 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.
- #
- # 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.
-
- require File.expand_path('../../test_helper', __FILE__)
- require 'account_controller'
-
- # Re-raise errors caught by the controller.
- class AccountController; def rescue_action(e) raise e end; end
-
- class AccountControllerTest < ActionController::TestCase
- fixtures :users, :roles
-
- def setup
- @controller = AccountController.new
- @request = ActionController::TestRequest.new
- @response = ActionController::TestResponse.new
- User.current = nil
- end
-
- def test_login_should_redirect_to_back_url_param
- # request.uri is "test.host" in test environment
- post :login, :username => 'jsmith', :password => 'jsmith', :back_url => 'http%3A%2F%2Ftest.host%2Fissues%2Fshow%2F1'
- assert_redirected_to '/issues/show/1'
- end
-
- def test_login_should_not_redirect_to_another_host
- post :login, :username => 'jsmith', :password => 'jsmith', :back_url => 'http%3A%2F%2Ftest.foo%2Ffake'
- assert_redirected_to '/my/page'
- end
-
- def test_login_with_wrong_password
- post :login, :username => 'admin', :password => 'bad'
- assert_response :success
- assert_template 'login'
- assert_tag 'div',
- :attributes => { :class => "flash error" },
- :content => /Invalid user or password/
- end
-
- def test_login_should_rescue_auth_source_exception
- source = AuthSource.create!(:name => 'Test')
- User.find(2).update_attribute :auth_source_id, source.id
- AuthSource.any_instance.stubs(:authenticate).raises(AuthSourceException.new("Something wrong"))
-
- post :login, :username => 'jsmith', :password => 'jsmith'
- assert_response 500
- assert_error_tag :content => /Something wrong/
- end
-
- def test_login_should_reset_session
- @controller.expects(:reset_session).once
-
- post :login, :username => 'jsmith', :password => 'jsmith'
- assert_response 302
- end
-
- if Object.const_defined?(:OpenID)
-
- def test_login_with_openid_for_existing_user
- Setting.self_registration = '3'
- Setting.openid = '1'
- 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
- assert_redirected_to '/my/page'
- end
-
- 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
-
- 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
- assert_redirected_to '/login'
- end
-
- def test_login_with_openid_with_new_user_created
- Setting.self_registration = '3'
- Setting.openid = '1'
- post :login, :openid_url => 'http://openid.example.com/good_user'
- assert_redirected_to '/my/account'
- 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_and_self_registration_off
- Setting.self_registration = '0'
- Setting.openid = '1'
- 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
-
- def test_login_with_openid_with_new_user_created_with_email_activation_should_have_a_token
- Setting.self_registration = '1'
- Setting.openid = '1'
- post :login, :openid_url => 'http://openid.example.com/good_user'
- assert_redirected_to '/login'
- user = User.find_by_login('cool_user')
- assert user
-
- token = Token.find_by_user_id_and_action(user.id, 'register')
- assert token
- end
-
- def test_login_with_openid_with_new_user_created_with_manual_activation
- Setting.self_registration = '2'
- Setting.openid = '1'
- post :login, :openid_url => 'http://openid.example.com/good_user'
- assert_redirected_to '/login'
- user = User.find_by_login('cool_user')
- assert user
- assert_equal User::STATUS_REGISTERED, user.status
- end
-
- def test_login_with_openid_with_new_user_with_conflict_should_register
- Setting.self_registration = '3'
- Setting.openid = '1'
- 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_setting_openid_should_return_true_when_set_to_true
- Setting.openid = '1'
- assert_equal true, Setting.openid?
- end
-
- else
- puts "Skipping openid tests."
- end
-
- def test_logout
- @request.session[:user_id] = 2
- get :logout
- assert_redirected_to '/'
- assert_nil @request.session[:user_id]
- end
-
- def test_logout_should_reset_session
- @controller.expects(:reset_session).once
-
- @request.session[:user_id] = 2
- get :logout
- assert_response 302
- end
-
- 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)
-
- assert_tag 'input', :attributes => {:name => 'user[password]'}
- assert_tag 'input', :attributes => {:name => 'user[password_confirmation]'}
- end
- end
-
- def test_get_register_with_registration_off_should_redirect
- with_settings :self_registration => '0' do
- get :register
- assert_redirected_to '/'
- end
- end
-
- # See integration/account_test.rb for the full test
- def test_post_register_with_registration_on
- with_settings :self_registration => '3' do
- assert_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 '/my/account'
- end
- user = User.first(:order => 'id DESC')
- assert_equal 'register', user.login
- assert_equal 'John', user.firstname
- assert_equal 'Doe', user.lastname
- assert_equal 'register@example.com', user.mail
- assert user.check_password?('test')
- assert user.active?
- end
- 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 '/'
- end
- end
- end
- end
|