Sha256: afff4192a90e655f75ff854d38f879e85d16c6b6dae4510e625f960e7c66634d

Contents?: true

Size: 1.72 KB

Versions: 41

Compression:

Stored size: 1.72 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

  test 'required_fields should contain the fields that Devise uses' do
    assert_same_content Devise::Models::TokenAuthenticatable.required_fields(User), [
      :authentication_token
    ]
  end
end

Version data entries

41 entries across 41 versions & 7 rubygems

Version Path
devise-3.1.2 test/models/token_authenticatable_test.rb
devise-3.0.4 test/models/token_authenticatable_test.rb
devise-2.2.8 test/models/token_authenticatable_test.rb
devise-3.1.1 test/models/token_authenticatable_test.rb
devise-3.1.0 test/models/token_authenticatable_test.rb
devise-2.1.4 test/models/token_authenticatable_test.rb
devise-2.2.7 test/models/token_authenticatable_test.rb
devise-3.0.3 test/models/token_authenticatable_test.rb
devise-3.1.0.rc2 test/models/token_authenticatable_test.rb
devise-2.2.6 test/models/token_authenticatable_test.rb
devise-3.0.2 test/models/token_authenticatable_test.rb
devise-3.0.1 test/models/token_authenticatable_test.rb
devise-2.2.5 test/models/token_authenticatable_test.rb
loyal_devise-2.1.7 test/models/token_authenticatable_test.rb
loyal_devise-2.1.6 test/models/token_authenticatable_test.rb
devise-3.0.0 test/models/token_authenticatable_test.rb
loyal_devise-2.1.5 test/models/token_authenticatable_test.rb
loyal_devise-2.1.4 test/models/token_authenticatable_test.rb
loyal_devise-2.1.3 test/models/token_authenticatable_test.rb
devise-3.0.0.rc test/models/token_authenticatable_test.rb