require File.dirname(__FILE__) + '/../test_helper.rb' module SessionTest module PasswordTest class ConfigTest < ActiveSupport::TestCase def test_find_by_login_method UserSession.find_by_login_method = "my_login_method" assert_equal "my_login_method", UserSession.find_by_login_method UserSession.find_by_login_method "find_by_login" assert_equal "find_by_login", UserSession.find_by_login_method end def test_verify_password_method UserSession.verify_password_method = "my_login_method" assert_equal "my_login_method", UserSession.verify_password_method UserSession.verify_password_method "valid_password?" assert_equal "valid_password?", UserSession.verify_password_method end def test_generalize_credentials_error_messages UserSession.generalize_credentials_error_messages = true assert UserSession.generalize_credentials_error_messages UserSession.generalize_credentials_error_messages false assert !UserSession.generalize_credentials_error_messages end def test_login_field UserSession.configured_password_methods = false UserSession.login_field = :saweet assert_equal :saweet, UserSession.login_field session = UserSession.new assert session.respond_to?(:saweet) UserSession.login_field :login assert_equal :login, UserSession.login_field session = UserSession.new assert session.respond_to?(:login) end def test_password_field UserSession.configured_password_methods = false UserSession.password_field = :saweet assert_equal :saweet, UserSession.password_field session = UserSession.new assert session.respond_to?(:saweet) UserSession.password_field :password assert_equal :password, UserSession.password_field session = UserSession.new assert session.respond_to?(:password) end end class InstanceMethodsTest < ActiveSupport::TestCase def test_init session = UserSession.new assert session.respond_to?(:login) assert session.respond_to?(:login=) assert session.respond_to?(:password) assert session.respond_to?(:password=) assert session.respond_to?(:protected_password, true) end def test_credentials session = UserSession.new session.credentials = {:login => "login", :password => "pass"} assert_equal "login", session.login assert_nil session.password assert_equal "pass", session.send(:protected_password) assert_equal({:password => "<protected>", :login => "login"}, session.credentials) end def test_credentials_are_params_safe session = UserSession.new assert_nothing_raised { session.credentials = {:hacker_method => "error!"} } end def test_save_with_credentials ben = users(:ben) session = UserSession.new(:login => ben.login, :password => "benrocks") assert session.save assert !session.new_session? assert_equal 1, session.record.login_count assert Time.now >= session.record.current_login_at assert_equal "1.1.1.1", session.record.current_login_ip end end end end