account_controller_test.rb
243 lines
| 7.9 KiB
| text/x-ruby
|
RubyLexer
|
r5869 | # Redmine - project management software | ||
|
r9453 | # Copyright (C) 2006-2012 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 | ||||
|
r10056 | post :login, :username => 'jsmith', :password => 'jsmith', :back_url => 'http://test.host/issues/show/1' | ||
|
r1686 | assert_redirected_to '/issues/show/1' | ||
end | ||||
|
r5869 | |||
|
r1686 | def test_login_should_not_redirect_to_another_host | ||
|
r10056 | post :login, :username => 'jsmith', :password => 'jsmith', :back_url => 'http://test.foo/fake' | ||
|
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 | |||
|
r8791 | 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 | ||||
|
r8894 | def test_login_should_reset_session | ||
@controller.expects(:reset_session).once | ||||
post :login, :username => 'jsmith', :password => 'jsmith' | ||||
assert_response 302 | ||||
end | ||||
|
r974 | def test_logout | ||
@request.session[:user_id] = 2 | ||||
get :logout | ||||
|
r4293 | assert_redirected_to '/' | ||
|
r974 | assert_nil @request.session[:user_id] | ||
end | ||||
|
r3789 | |||
|
r8894 | def test_logout_should_reset_session | ||
@controller.expects(:reset_session).once | ||||
@request.session[:user_id] = 2 | ||||
get :logout | ||||
assert_response 302 | ||||
end | ||||
|
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 | ||||
|
r9760 | |||
def test_get_lost_password_should_display_lost_password_form | ||||
get :lost_password | ||||
assert_response :success | ||||
assert_select 'input[name=mail]' | ||||
end | ||||
def test_lost_password_for_active_user_should_create_a_token | ||||
|
r9761 | Token.delete_all | ||
|
r9762 | ActionMailer::Base.deliveries.clear | ||
|
r9760 | assert_difference 'ActionMailer::Base.deliveries.size' do | ||
assert_difference 'Token.count' do | ||||
with_settings :host_name => 'mydomain.foo', :protocol => 'http' do | ||||
post :lost_password, :mail => 'JSmith@somenet.foo' | ||||
assert_redirected_to '/login' | ||||
end | ||||
end | ||||
end | ||||
token = Token.order('id DESC').first | ||||
assert_equal User.find(2), token.user | ||||
assert_equal 'recovery', token.action | ||||
assert_select_email do | ||||
assert_select "a[href=?]", "http://mydomain.foo/account/lost_password?token=#{token.value}" | ||||
end | ||||
end | ||||
def test_lost_password_for_unknown_user_should_fail | ||||
|
r9761 | Token.delete_all | ||
|
r9760 | assert_no_difference 'Token.count' do | ||
post :lost_password, :mail => 'invalid@somenet.foo' | ||||
assert_response :success | ||||
end | ||||
end | ||||
def test_lost_password_for_non_active_user_should_fail | ||||
|
r9761 | Token.delete_all | ||
|
r9760 | assert User.find(2).lock! | ||
assert_no_difference 'Token.count' do | ||||
post :lost_password, :mail => 'JSmith@somenet.foo' | ||||
assert_response :success | ||||
end | ||||
end | ||||
|
r9763 | |||
def test_get_lost_password_with_token_should_display_the_password_recovery_form | ||||
user = User.find(2) | ||||
token = Token.create!(:action => 'recovery', :user => user) | ||||
get :lost_password, :token => token.value | ||||
assert_response :success | ||||
assert_template 'password_recovery' | ||||
assert_select 'input[type=hidden][name=token][value=?]', token.value | ||||
end | ||||
def test_get_lost_password_with_invalid_token_should_redirect | ||||
get :lost_password, :token => "abcdef" | ||||
assert_redirected_to '/' | ||||
end | ||||
def test_post_lost_password_with_token_should_change_the_user_password | ||||
user = User.find(2) | ||||
token = Token.create!(:action => 'recovery', :user => user) | ||||
post :lost_password, :token => token.value, :new_password => 'newpass', :new_password_confirmation => 'newpass' | ||||
assert_redirected_to '/login' | ||||
user.reload | ||||
assert user.check_password?('newpass') | ||||
assert_nil Token.find_by_id(token.id), "Token was not deleted" | ||||
end | ||||
def test_post_lost_password_with_token_for_non_active_user_should_fail | ||||
user = User.find(2) | ||||
token = Token.create!(:action => 'recovery', :user => user) | ||||
user.lock! | ||||
post :lost_password, :token => token.value, :new_password => 'newpass', :new_password_confirmation => 'newpass' | ||||
assert_redirected_to '/' | ||||
assert ! user.check_password?('newpass') | ||||
end | ||||
def test_post_lost_password_with_token_and_password_confirmation_failure_should_redisplay_the_form | ||||
user = User.find(2) | ||||
token = Token.create!(:action => 'recovery', :user => user) | ||||
post :lost_password, :token => token.value, :new_password => 'newpass', :new_password_confirmation => 'wrongpass' | ||||
assert_response :success | ||||
assert_template 'password_recovery' | ||||
assert_not_nil Token.find_by_id(token.id), "Token was deleted" | ||||
assert_select 'input[type=hidden][name=token][value=?]', token.value | ||||
end | ||||
def test_post_lost_password_with_invalid_token_should_redirect | ||||
post :lost_password, :token => "abcdef", :new_password => 'newpass', :new_password_confirmation => 'newpass' | ||||
assert_redirected_to '/' | ||||
end | ||||
|
r974 | end | ||