diff options
author | Azul <azul@leap.se> | 2013-08-28 11:13:38 +0200 |
---|---|---|
committer | Azul <azul@leap.se> | 2013-09-03 08:36:17 +0200 |
commit | 42cef3117cd97d9c37968a8cf63d33b27b4b8ed2 (patch) | |
tree | 712cb953ec449c48d8589be0c3a74ab54592556d /users/test/unit | |
parent | 2875af7cf9fe22c40a3ea7c1cc34eb563a4f3eed (diff) |
expire token according to config setting auth:token_expires_after
Diffstat (limited to 'users/test/unit')
-rw-r--r-- | users/test/unit/token_test.rb | 33 |
1 files changed, 31 insertions, 2 deletions
diff --git a/users/test/unit/token_test.rb b/users/test/unit/token_test.rb index bff6b71..f56c576 100644 --- a/users/test/unit/token_test.rb +++ b/users/test/unit/token_test.rb @@ -1,19 +1,20 @@ require 'test_helper' class ClientCertificateTest < ActiveSupport::TestCase + include StubRecordHelper setup do - @user = FactoryGirl.create(:user) + @user = find_record :user end teardown do - @user.destroy end test "new token for user" do sample = Token.new(:user_id => @user.id) assert sample.valid? assert_equal @user.id, sample.user_id + assert_equal @user, sample.authenticate end test "token id is secure" do @@ -34,4 +35,32 @@ class ClientCertificateTest < ActiveSupport::TestCase assert !sample.valid?, "Token should require a user record" end + test "token updates timestamps" do + sample = Token.new(user_id: @user.id) + sample.last_seen_at = 1.minute.ago + sample.expects(:save) + assert_equal @user, sample.authenticate + assert Time.now - sample.last_seen_at < 1.minute, "last_seen_at has not been updated" + end + + test "token will not expire if token_expires_after is not set" do + sample = Token.new(user_id: @user.id) + sample.last_seen_at = 2.years.ago + with_config auth: {} do + sample.expects(:save) + assert_equal @user, sample.authenticate + end + end + + test "expired token returns nil on authenticate" do + sample = Token.new(user_id: @user.id) + sample.last_seen_at = 2.hours.ago + with_config auth: {token_expires_after: 60} do + sample.expects(:destroy) + assert_nil sample.authenticate + end + end + + + end |