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