photomix/vendor/plugins/authlogic/test/session_test/password_test.rb
2011-04-11 18:07:31 +08:00

107 lines
4.1 KiB
Ruby

require 'test_helper'
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_mesages_set_to_false
UserSession.generalize_credentials_error_messages false
assert !UserSession.generalize_credentials_error_messages
session = UserSession.create(:login => users(:ben).login, :password => "invalud-password")
assert_equal ["Password is not valid"], session.errors.full_messages
end
def test_generalize_credentials_error_messages_set_to_true
UserSession.generalize_credentials_error_messages true
assert UserSession.generalize_credentials_error_messages
session = UserSession.create(:login => users(:ben).login, :password => "invalud-password")
assert_equal ["Login/Password combination is not valid"], session.errors.full_messages
end
def test_generalize_credentials_error_messages_set_to_string
UserSession.generalize_credentials_error_messages= "Custom Error Message"
assert UserSession.generalize_credentials_error_messages
session = UserSession.create(:login => users(:ben).login, :password => "invalud-password")
assert_equal ["Custom Error Message"], session.errors.full_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