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