mirror of
https://github.com/heartcombo/devise.git
synced 2026-04-28 03:00:29 -04:00
61 lines
1.5 KiB
Ruby
61 lines
1.5 KiB
Ruby
require 'test/test_helper'
|
|
|
|
class SessionTimeoutTest < ActionController::IntegrationTest
|
|
|
|
def last_request_at
|
|
@controller.user_session['last_request_at']
|
|
end
|
|
|
|
test 'set last request at in user session after each request' do
|
|
sign_in_as_user
|
|
old_last_request = last_request_at
|
|
assert_not_nil last_request_at
|
|
get users_path
|
|
assert_not_nil last_request_at
|
|
assert_not_equal old_last_request, last_request_at
|
|
end
|
|
|
|
test 'time out user session after default limit time' do
|
|
sign_in_as_user
|
|
assert_response :success
|
|
assert warden.authenticated?(:user)
|
|
|
|
# Setup last_request_at to timeout
|
|
get new_user_path
|
|
assert_not_nil last_request_at
|
|
|
|
get users_path
|
|
assert_redirected_to new_user_session_path(:timeout => true)
|
|
assert_not warden.authenticated?(:user)
|
|
end
|
|
|
|
test 'not time out user session before default limit time' do
|
|
user = sign_in_as_user
|
|
|
|
# Setup last_request_at to timeout
|
|
get edit_user_path(user)
|
|
assert_not_nil last_request_at
|
|
|
|
get users_path
|
|
assert_response :success
|
|
assert warden.authenticated?(:user)
|
|
end
|
|
|
|
test 'user configured timeout limit' do
|
|
swap Devise, :timeout => 8.minutes do
|
|
user = sign_in_as_user
|
|
|
|
# Setup last_request_at to timeout
|
|
get edit_user_path(user)
|
|
assert_not_nil last_request_at
|
|
assert_response :success
|
|
assert warden.authenticated?(:user)
|
|
|
|
get users_path
|
|
assert_redirected_to new_user_session_path(:timeout => true)
|
|
assert_not warden.authenticated?(:user)
|
|
end
|
|
end
|
|
|
|
end
|