Sha256: 69c42a2c15330e8d9b62bf0a2e3011963c7358198fe9ef8f39b4cbbe55cd4e42

Contents?: true

Size: 1.53 KB

Versions: 30

Compression:

Stored size: 1.53 KB

Contents

require 'test_helper'

class TokenAuthenticatableTest < ActiveSupport::TestCase

  test 'should reset authentication token' do
    user = new_user
    user.reset_authentication_token
    previous_token = user.authentication_token
    user.reset_authentication_token
    assert_not_equal previous_token, user.authentication_token
  end

  test 'should ensure authentication token' do
    user = new_user
    user.ensure_authentication_token
    previous_token = user.authentication_token
    user.ensure_authentication_token
    assert_equal previous_token, user.authentication_token
  end

  test 'should authenticate a valid user with authentication token and return it' do
    user = create_user
    user.ensure_authentication_token!
    user.confirm!
    authenticated_user = User.find_for_token_authentication(:auth_token => user.authentication_token)
    assert_equal authenticated_user, user
  end

  test 'should return nil when authenticating an invalid user by authentication token' do
    user = create_user
    user.ensure_authentication_token!
    user.confirm!
    authenticated_user = User.find_for_token_authentication(:auth_token => user.authentication_token.reverse)
    assert_nil authenticated_user
  end

  test 'should not be subject to injection' do
    user1 = create_user
    user1.ensure_authentication_token!
    user1.confirm!

    user2 = create_user
    user2.ensure_authentication_token!
    user2.confirm!

    user = User.find_for_token_authentication(:auth_token => {'$ne' => user1.authentication_token})
    assert_nil user
  end
end

Version data entries

30 entries across 30 versions & 4 rubygems

Version Path
devise-1.5.0.rc1 test/models/token_authenticatable_test.rb
devise-1.4.9 test/models/token_authenticatable_test.rb
devise-1.4.8 test/models/token_authenticatable_test.rb
devise-1.4.7 test/models/token_authenticatable_test.rb
devise-1.4.5 test/models/token_authenticatable_test.rb
devise-1.4.3 test/models/token_authenticatable_test.rb
devise-1.4.2 test/models/token_authenticatable_test.rb
devise-1.4.1 test/models/token_authenticatable_test.rb
devise-1.1.9 test/models/token_authenticatable_test.rb
devise-1.1.8 test/models/token_authenticatable_test.rb