You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

sessions_controller_test.rb 5.4KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164
  1. # Redmine - project management software
  2. # Copyright (C) 2006-2017 Jean-Philippe Lang
  3. #
  4. # This program is free software; you can redistribute it and/or
  5. # modify it under the terms of the GNU General Public License
  6. # as published by the Free Software Foundation; either version 2
  7. # of the License, or (at your option) any later version.
  8. #
  9. # This program is distributed in the hope that it will be useful,
  10. # but WITHOUT ANY WARRANTY; without even the implied warranty of
  11. # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  12. # GNU General Public License for more details.
  13. #
  14. # You should have received a copy of the GNU General Public License
  15. # along with this program; if not, write to the Free Software
  16. # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
  17. require File.expand_path('../../test_helper', __FILE__)
  18. class SessionsControllerTest < Redmine::ControllerTest
  19. include Redmine::I18n
  20. tests WelcomeController
  21. fixtures :users, :email_addresses
  22. def setup
  23. Rails.application.config.redmine_verify_sessions = true
  24. end
  25. def teardown
  26. Rails.application.config.redmine_verify_sessions = false
  27. end
  28. def test_session_token_should_be_updated
  29. token = Token.create!(:user_id => 2, :action => 'session', :created_on => 10.hours.ago, :updated_on => 10.hours.ago)
  30. created = token.reload.created_on
  31. get :index, :session => {
  32. :user_id => 2,
  33. :tk => token.value
  34. }
  35. assert_response :success
  36. token.reload
  37. assert_equal created.to_i, token.created_on.to_i
  38. assert_not_equal created.to_i, token.updated_on.to_i
  39. assert token.updated_on > created
  40. end
  41. def test_user_session_should_not_be_reset_if_lifetime_and_timeout_disabled
  42. created = 2.years.ago
  43. token = Token.create!(:user_id => 2, :action => 'session', :created_on => created, :updated_on => created)
  44. with_settings :session_lifetime => '0', :session_timeout => '0' do
  45. get :index, :session => {
  46. :user_id => 2,
  47. :tk => token.value
  48. }
  49. assert_response :success
  50. end
  51. end
  52. def test_user_session_without_token_should_be_reset
  53. get :index, :session => {
  54. :user_id => 2
  55. }
  56. assert_redirected_to 'http://test.host/login?back_url=http%3A%2F%2Ftest.host%2F'
  57. end
  58. def test_expired_user_session_should_be_reset_if_lifetime_enabled
  59. created = 2.days.ago
  60. token = Token.create!(:user_id => 2, :action => 'session', :created_on => created, :updated_on => created)
  61. with_settings :session_timeout => '720' do
  62. get :index, :session => {
  63. :user_id => 2,
  64. :tk => token.value
  65. }
  66. assert_redirected_to 'http://test.host/login?back_url=http%3A%2F%2Ftest.host%2F'
  67. end
  68. end
  69. def test_valid_user_session_should_not_be_reset_if_lifetime_enabled
  70. created = 3.hours.ago
  71. token = Token.create!(:user_id => 2, :action => 'session', :created_on => created, :updated_on => created)
  72. with_settings :session_timeout => '720' do
  73. get :index, :session => {
  74. :user_id => 2,
  75. :tk => token.value
  76. }
  77. assert_response :success
  78. end
  79. end
  80. def test_expired_user_session_should_be_reset_if_timeout_enabled
  81. created = 4.hours.ago
  82. token = Token.create!(:user_id => 2, :action => 'session', :created_on => created, :updated_on => created)
  83. with_settings :session_timeout => '60' do
  84. get :index, :session => {
  85. :user_id => 2,
  86. :tk => token.value
  87. }
  88. assert_redirected_to 'http://test.host/login?back_url=http%3A%2F%2Ftest.host%2F'
  89. end
  90. end
  91. def test_valid_user_session_should_not_be_reset_if_timeout_enabled
  92. created = 10.minutes.ago
  93. token = Token.create!(:user_id => 2, :action => 'session', :created_on => created, :updated_on => created)
  94. with_settings :session_timeout => '60' do
  95. get :index, :session => {
  96. :user_id => 2,
  97. :tk => token.value
  98. }
  99. assert_response :success
  100. end
  101. end
  102. def test_expired_user_session_should_be_restarted_if_autologin
  103. created = 2.hours.ago
  104. token = Token.create!(:user_id => 2, :action => 'session', :created_on => created, :updated_on => created)
  105. with_settings :session_lifetime => '720', :session_timeout => '60', :autologin => 7 do
  106. autologin_token = Token.create!(:user_id => 2, :action => 'autologin', :created_on => 1.day.ago)
  107. @request.cookies['autologin'] = autologin_token.value
  108. get :index, :session => {
  109. :user_id => 2,
  110. :tk => token.value
  111. }
  112. assert_equal 2, session[:user_id]
  113. assert_response :success
  114. assert_not_equal token.value, session[:tk]
  115. end
  116. end
  117. def test_expired_user_session_should_set_locale
  118. set_language_if_valid 'it'
  119. user = User.find(2)
  120. user.language = 'fr'
  121. user.save!
  122. created = 4.hours.ago
  123. token = Token.create!(:user_id => 2, :action => 'session', :created_on => created, :updated_on => created)
  124. with_settings :session_timeout => '60' do
  125. get :index, :session => {
  126. :user_id => user.id,
  127. :tk => token.value
  128. }
  129. assert_redirected_to 'http://test.host/login?back_url=http%3A%2F%2Ftest.host%2F'
  130. assert_include "Veuillez vous reconnecter", flash[:error]
  131. assert_equal :fr, current_language
  132. end
  133. end
  134. def test_anonymous_session_should_not_be_reset
  135. with_settings :session_lifetime => '720', :session_timeout => '60' do
  136. get :index
  137. assert_response :success
  138. end
  139. end
  140. end