jlecour-authlogic 2.1.2

Sign up to get free protection for your applications and to get access to all the features.
Files changed (123) hide show
  1. data/.gitignore +9 -0
  2. data/CHANGELOG.rdoc +345 -0
  3. data/LICENSE +20 -0
  4. data/README.rdoc +245 -0
  5. data/Rakefile +42 -0
  6. data/VERSION.yml +4 -0
  7. data/authlogic.gemspec +212 -0
  8. data/generators/session/session_generator.rb +9 -0
  9. data/generators/session/templates/session.erb +2 -0
  10. data/init.rb +1 -0
  11. data/lib/authlogic.rb +56 -0
  12. data/lib/authlogic/acts_as_authentic/base.rb +107 -0
  13. data/lib/authlogic/acts_as_authentic/email.rb +110 -0
  14. data/lib/authlogic/acts_as_authentic/logged_in_status.rb +60 -0
  15. data/lib/authlogic/acts_as_authentic/login.rb +141 -0
  16. data/lib/authlogic/acts_as_authentic/magic_columns.rb +24 -0
  17. data/lib/authlogic/acts_as_authentic/password.rb +344 -0
  18. data/lib/authlogic/acts_as_authentic/perishable_token.rb +105 -0
  19. data/lib/authlogic/acts_as_authentic/persistence_token.rb +68 -0
  20. data/lib/authlogic/acts_as_authentic/restful_authentication.rb +61 -0
  21. data/lib/authlogic/acts_as_authentic/session_maintenance.rb +139 -0
  22. data/lib/authlogic/acts_as_authentic/single_access_token.rb +65 -0
  23. data/lib/authlogic/acts_as_authentic/validations_scope.rb +32 -0
  24. data/lib/authlogic/authenticates_many/association.rb +42 -0
  25. data/lib/authlogic/authenticates_many/base.rb +55 -0
  26. data/lib/authlogic/controller_adapters/abstract_adapter.rb +67 -0
  27. data/lib/authlogic/controller_adapters/merb_adapter.rb +30 -0
  28. data/lib/authlogic/controller_adapters/rails_adapter.rb +48 -0
  29. data/lib/authlogic/controller_adapters/sinatra_adapter.rb +61 -0
  30. data/lib/authlogic/crypto_providers/aes256.rb +43 -0
  31. data/lib/authlogic/crypto_providers/bcrypt.rb +89 -0
  32. data/lib/authlogic/crypto_providers/md5.rb +34 -0
  33. data/lib/authlogic/crypto_providers/sha1.rb +35 -0
  34. data/lib/authlogic/crypto_providers/sha512.rb +50 -0
  35. data/lib/authlogic/i18n.rb +83 -0
  36. data/lib/authlogic/i18n/translator.rb +15 -0
  37. data/lib/authlogic/random.rb +33 -0
  38. data/lib/authlogic/regex.rb +25 -0
  39. data/lib/authlogic/session/activation.rb +58 -0
  40. data/lib/authlogic/session/active_record_trickery.rb +61 -0
  41. data/lib/authlogic/session/base.rb +37 -0
  42. data/lib/authlogic/session/brute_force_protection.rb +96 -0
  43. data/lib/authlogic/session/callbacks.rb +88 -0
  44. data/lib/authlogic/session/cookies.rb +130 -0
  45. data/lib/authlogic/session/existence.rb +93 -0
  46. data/lib/authlogic/session/foundation.rb +63 -0
  47. data/lib/authlogic/session/http_auth.rb +58 -0
  48. data/lib/authlogic/session/id.rb +41 -0
  49. data/lib/authlogic/session/klass.rb +75 -0
  50. data/lib/authlogic/session/magic_columns.rb +95 -0
  51. data/lib/authlogic/session/magic_states.rb +59 -0
  52. data/lib/authlogic/session/params.rb +101 -0
  53. data/lib/authlogic/session/password.rb +240 -0
  54. data/lib/authlogic/session/perishable_token.rb +18 -0
  55. data/lib/authlogic/session/persistence.rb +70 -0
  56. data/lib/authlogic/session/priority_record.rb +34 -0
  57. data/lib/authlogic/session/scopes.rb +101 -0
  58. data/lib/authlogic/session/session.rb +62 -0
  59. data/lib/authlogic/session/timeout.rb +82 -0
  60. data/lib/authlogic/session/unauthorized_record.rb +50 -0
  61. data/lib/authlogic/session/validation.rb +82 -0
  62. data/lib/authlogic/test_case.rb +114 -0
  63. data/lib/authlogic/test_case/mock_controller.rb +45 -0
  64. data/lib/authlogic/test_case/mock_cookie_jar.rb +14 -0
  65. data/lib/authlogic/test_case/mock_logger.rb +10 -0
  66. data/lib/authlogic/test_case/mock_request.rb +19 -0
  67. data/lib/authlogic/test_case/rails_request_adapter.rb +30 -0
  68. data/rails/init.rb +1 -0
  69. data/shoulda_macros/authlogic.rb +13 -0
  70. data/test/acts_as_authentic_test/base_test.rb +18 -0
  71. data/test/acts_as_authentic_test/email_test.rb +97 -0
  72. data/test/acts_as_authentic_test/logged_in_status_test.rb +36 -0
  73. data/test/acts_as_authentic_test/login_test.rb +109 -0
  74. data/test/acts_as_authentic_test/magic_columns_test.rb +27 -0
  75. data/test/acts_as_authentic_test/password_test.rb +236 -0
  76. data/test/acts_as_authentic_test/perishable_token_test.rb +90 -0
  77. data/test/acts_as_authentic_test/persistence_token_test.rb +55 -0
  78. data/test/acts_as_authentic_test/restful_authentication_test.rb +40 -0
  79. data/test/acts_as_authentic_test/session_maintenance_test.rb +84 -0
  80. data/test/acts_as_authentic_test/single_access_test.rb +44 -0
  81. data/test/authenticates_many_test.rb +16 -0
  82. data/test/crypto_provider_test/aes256_test.rb +14 -0
  83. data/test/crypto_provider_test/bcrypt_test.rb +14 -0
  84. data/test/crypto_provider_test/sha1_test.rb +23 -0
  85. data/test/crypto_provider_test/sha512_test.rb +14 -0
  86. data/test/fixtures/companies.yml +5 -0
  87. data/test/fixtures/employees.yml +17 -0
  88. data/test/fixtures/projects.yml +3 -0
  89. data/test/fixtures/users.yml +24 -0
  90. data/test/i18n_test.rb +33 -0
  91. data/test/libs/affiliate.rb +7 -0
  92. data/test/libs/company.rb +6 -0
  93. data/test/libs/employee.rb +7 -0
  94. data/test/libs/employee_session.rb +2 -0
  95. data/test/libs/ldaper.rb +3 -0
  96. data/test/libs/ordered_hash.rb +9 -0
  97. data/test/libs/project.rb +3 -0
  98. data/test/libs/user.rb +5 -0
  99. data/test/libs/user_session.rb +2 -0
  100. data/test/random_test.rb +49 -0
  101. data/test/session_test/activation_test.rb +43 -0
  102. data/test/session_test/active_record_trickery_test.rb +36 -0
  103. data/test/session_test/brute_force_protection_test.rb +101 -0
  104. data/test/session_test/callbacks_test.rb +6 -0
  105. data/test/session_test/cookies_test.rb +107 -0
  106. data/test/session_test/credentials_test.rb +0 -0
  107. data/test/session_test/existence_test.rb +64 -0
  108. data/test/session_test/http_auth_test.rb +28 -0
  109. data/test/session_test/id_test.rb +17 -0
  110. data/test/session_test/klass_test.rb +35 -0
  111. data/test/session_test/magic_columns_test.rb +62 -0
  112. data/test/session_test/magic_states_test.rb +60 -0
  113. data/test/session_test/params_test.rb +53 -0
  114. data/test/session_test/password_test.rb +106 -0
  115. data/test/session_test/perishability_test.rb +15 -0
  116. data/test/session_test/persistence_test.rb +21 -0
  117. data/test/session_test/scopes_test.rb +60 -0
  118. data/test/session_test/session_test.rb +59 -0
  119. data/test/session_test/timeout_test.rb +52 -0
  120. data/test/session_test/unauthorized_record_test.rb +13 -0
  121. data/test/session_test/validation_test.rb +23 -0
  122. data/test/test_helper.rb +181 -0
  123. metadata +233 -0
@@ -0,0 +1,36 @@
1
+ require File.dirname(__FILE__) + '/../test_helper.rb'
2
+
3
+ module SessionTest
4
+ module ActiveRecordTrickeryTest
5
+ class ClassMethodsTest < ActiveSupport::TestCase
6
+ def test_human_attribute_name
7
+ assert_equal "Some attribute", UserSession.human_attribute_name("some_attribute")
8
+ assert_equal "Some attribute", UserSession.human_attribute_name(:some_attribute)
9
+ end
10
+
11
+ def test_human_name
12
+ assert_equal "Usersession", UserSession.human_name
13
+ end
14
+
15
+ def test_self_and_descendents_from_active_record
16
+ assert_equal [UserSession], UserSession.self_and_descendents_from_active_record
17
+ end
18
+
19
+ def test_self_and_descendants_from_active_record
20
+ assert_equal [UserSession], UserSession.self_and_descendants_from_active_record
21
+ end
22
+ end
23
+
24
+ class InstanceMethodsTest < ActiveSupport::TestCase
25
+ def test_new_record
26
+ session = UserSession.new
27
+ assert session.new_record?
28
+ end
29
+
30
+ def test_to_model
31
+ session = UserSession.new
32
+ assert session, session.to_model
33
+ end
34
+ end
35
+ end
36
+ end
@@ -0,0 +1,101 @@
1
+ require File.dirname(__FILE__) + '/../test_helper.rb'
2
+
3
+ module SessionTest
4
+ module BruteForceProtectionTest
5
+ class ConfigTest < ActiveSupport::TestCase
6
+ def test_consecutive_failed_logins_limit
7
+ UserSession.consecutive_failed_logins_limit = 10
8
+ assert_equal 10, UserSession.consecutive_failed_logins_limit
9
+
10
+ UserSession.consecutive_failed_logins_limit 50
11
+ assert_equal 50, UserSession.consecutive_failed_logins_limit
12
+ end
13
+
14
+ def test_failed_login_ban_for
15
+ UserSession.failed_login_ban_for = 10
16
+ assert_equal 10, UserSession.failed_login_ban_for
17
+
18
+ UserSession.failed_login_ban_for 2.hours
19
+ assert_equal 2.hours.to_i, UserSession.failed_login_ban_for
20
+ end
21
+ end
22
+
23
+ class InstaceMethodsTest < ActiveSupport::TestCase
24
+ def test_under_limit
25
+ ben = users(:ben)
26
+ ben.failed_login_count = UserSession.consecutive_failed_logins_limit - 1
27
+ assert ben.save
28
+ assert UserSession.create(:login => ben.login, :password => "benrocks")
29
+ end
30
+
31
+ def test_exceeded_limit
32
+ ben = users(:ben)
33
+ ben.failed_login_count = UserSession.consecutive_failed_logins_limit
34
+ assert ben.save
35
+ assert UserSession.create(:login => ben.login, :password => "benrocks").new_session?
36
+ assert UserSession.create(ben).new_session?
37
+ ben.updated_at = (UserSession.failed_login_ban_for + 2.hours.to_i).seconds.ago
38
+ assert !UserSession.create(ben).new_session?
39
+ end
40
+
41
+ def test_exceeding_failed_logins_limit
42
+ UserSession.consecutive_failed_logins_limit = 2
43
+ ben = users(:ben)
44
+
45
+ 2.times do |i|
46
+ session = UserSession.new(:login => ben.login, :password => "badpassword1")
47
+ assert !session.save
48
+ assert session.errors[:password].size > 0
49
+ assert_equal i + 1, ben.reload.failed_login_count
50
+ end
51
+
52
+ session = UserSession.new(:login => ben.login, :password => "badpassword2")
53
+ assert !session.save
54
+ assert session.errors[:password].size == 0
55
+ assert_equal 3, ben.reload.failed_login_count
56
+
57
+ UserSession.consecutive_failed_logins_limit = 50
58
+ end
59
+
60
+ def test_exceeded_ban_for
61
+ UserSession.consecutive_failed_logins_limit = 2
62
+ UserSession.generalize_credentials_error_messages true
63
+ ben = users(:ben)
64
+
65
+ 2.times do |i|
66
+ session = UserSession.new(:login => ben.login, :password => "badpassword1")
67
+ assert !session.save
68
+ assert session.invalid_password?
69
+ assert_equal i + 1, ben.reload.failed_login_count
70
+ end
71
+
72
+ ActiveRecord::Base.connection.execute("update users set updated_at = '#{1.day.ago.to_s(:db)}' where login = '#{ben.login}'")
73
+ session = UserSession.new(:login => ben.login, :password => "benrocks")
74
+ assert session.save
75
+ assert_equal 0, ben.reload.failed_login_count
76
+
77
+ UserSession.consecutive_failed_logins_limit = 50
78
+ UserSession.generalize_credentials_error_messages false
79
+ end
80
+
81
+ def test_exceeded_ban_and_failed_doesnt_ban_again
82
+ UserSession.consecutive_failed_logins_limit = 2
83
+ ben = users(:ben)
84
+
85
+ 2.times do |i|
86
+ session = UserSession.new(:login => ben.login, :password => "badpassword1")
87
+ assert !session.save
88
+ assert session.errors[:password].size > 0
89
+ assert_equal i + 1, ben.reload.failed_login_count
90
+ end
91
+
92
+ ActiveRecord::Base.connection.execute("update users set updated_at = '#{1.day.ago.to_s(:db)}' where login = '#{ben.login}'")
93
+ session = UserSession.new(:login => ben.login, :password => "badpassword1")
94
+ assert !session.save
95
+ assert_equal 1, ben.reload.failed_login_count
96
+
97
+ UserSession.consecutive_failed_logins_limit = 50
98
+ end
99
+ end
100
+ end
101
+ end
@@ -0,0 +1,6 @@
1
+ require File.dirname(__FILE__) + '/../test_helper.rb'
2
+
3
+ module SessionTest
4
+ class CallbacksTest < ActiveSupport::TestCase
5
+ end
6
+ end
@@ -0,0 +1,107 @@
1
+ require File.dirname(__FILE__) + '/../test_helper.rb'
2
+
3
+ module SessionTest
4
+ module CookiesTest
5
+ class ConfiTest < ActiveSupport::TestCase
6
+ def test_cookie_key
7
+ UserSession.cookie_key = "my_cookie_key"
8
+ assert_equal "my_cookie_key", UserSession.cookie_key
9
+
10
+ UserSession.cookie_key "user_credentials"
11
+ assert_equal "user_credentials", UserSession.cookie_key
12
+ end
13
+
14
+ def test_remember_me
15
+ UserSession.remember_me = true
16
+ assert_equal true, UserSession.remember_me
17
+ session = UserSession.new
18
+ assert_equal true, session.remember_me
19
+
20
+ UserSession.remember_me false
21
+ assert_equal false, UserSession.remember_me
22
+ session = UserSession.new
23
+ assert_equal false, session.remember_me
24
+ end
25
+
26
+ def test_remember_me_for
27
+ UserSession.remember_me_for = 3.years
28
+ assert_equal 3.years, UserSession.remember_me_for
29
+ session = UserSession.new
30
+ session.remember_me = true
31
+ assert_equal 3.years, session.remember_me_for
32
+
33
+ UserSession.remember_me_for 3.months
34
+ assert_equal 3.months, UserSession.remember_me_for
35
+ session = UserSession.new
36
+ session.remember_me = true
37
+ assert_equal 3.months, session.remember_me_for
38
+ end
39
+ end
40
+
41
+ class InstanceMethodsTest < ActiveSupport::TestCase
42
+ def test_credentials
43
+ session = UserSession.new
44
+ session.credentials = {:remember_me => true}
45
+ assert_equal true, session.remember_me
46
+ end
47
+
48
+ def test_remember_me
49
+ session = UserSession.new
50
+ assert_equal false, session.remember_me
51
+ assert !session.remember_me?
52
+
53
+ session.remember_me = false
54
+ assert_equal false, session.remember_me
55
+ assert !session.remember_me?
56
+
57
+ session.remember_me = true
58
+ assert_equal true, session.remember_me
59
+ assert session.remember_me?
60
+
61
+ session.remember_me = nil
62
+ assert_nil session.remember_me
63
+ assert !session.remember_me?
64
+
65
+ session.remember_me = "1"
66
+ assert_equal "1", session.remember_me
67
+ assert session.remember_me?
68
+
69
+ session.remember_me = "true"
70
+ assert_equal "true", session.remember_me
71
+ assert session.remember_me?
72
+ end
73
+
74
+ def test_remember_me_until
75
+ session = UserSession.new
76
+ assert_nil session.remember_me_until
77
+
78
+ session.remember_me = true
79
+ assert 3.months.from_now <= session.remember_me_until
80
+ end
81
+
82
+ def test_persist_persist_by_cookie
83
+ ben = users(:ben)
84
+ assert !UserSession.find
85
+ set_cookie_for(ben)
86
+ assert session = UserSession.find
87
+ assert_equal ben, session.record
88
+ end
89
+
90
+ def test_after_save_save_cookie
91
+ ben = users(:ben)
92
+ session = UserSession.new(ben)
93
+ assert session.save
94
+ assert_equal "#{ben.persistence_token}::#{ben.id}", controller.cookies["user_credentials"]
95
+ end
96
+
97
+ def test_after_destroy_destroy_cookie
98
+ ben = users(:ben)
99
+ set_cookie_for(ben)
100
+ session = UserSession.find
101
+ assert controller.cookies["user_credentials"]
102
+ assert session.destroy
103
+ assert !controller.cookies["user_credentials"]
104
+ end
105
+ end
106
+ end
107
+ end
File without changes
@@ -0,0 +1,64 @@
1
+ require File.dirname(__FILE__) + '/../test_helper.rb'
2
+
3
+ module SessionTest
4
+ module ExistenceTest
5
+ class ClassMethodsTest < ActiveSupport::TestCase
6
+ def test_create
7
+ ben = users(:ben)
8
+ assert UserSession.create(:login => "somelogin", :password => "badpw2").new_session?
9
+ assert !UserSession.create(:login => ben.login, :password => "benrocks").new_session?
10
+ assert_raise(Authlogic::Session::Existence::SessionInvalidError) { UserSession.create!(:login => ben.login, :password => "badpw") }
11
+ assert !UserSession.create!(:login => ben.login, :password => "benrocks").new_session?
12
+ end
13
+ end
14
+
15
+ class IsntaceMethodsTest < ActiveSupport::TestCase
16
+ def test_new_session
17
+ session = UserSession.new
18
+ assert session.new_session?
19
+
20
+ set_session_for(users(:ben))
21
+ session = UserSession.find
22
+ assert !session.new_session?
23
+ end
24
+
25
+ def test_save_with_nothing
26
+ session = UserSession.new
27
+ assert !session.save
28
+ assert session.new_session?
29
+ end
30
+
31
+ def test_save_with_block
32
+ ben = users(:ben)
33
+ session = UserSession.new
34
+ block_result = session.save do |result|
35
+ assert !result
36
+ end
37
+ assert !block_result
38
+ assert session.new_session?
39
+ end
40
+
41
+ def test_save_with_bang
42
+ session = UserSession.new
43
+ assert_raise(Authlogic::Session::Existence::SessionInvalidError) { session.save! }
44
+
45
+ session.unauthorized_record = users(:ben)
46
+ assert_nothing_raised { session.save! }
47
+ end
48
+
49
+ def test_destroy
50
+ ben = users(:ben)
51
+ session = UserSession.new
52
+ assert !session.valid?
53
+ assert !session.errors.empty?
54
+ assert session.destroy
55
+ assert session.errors.empty?
56
+ session.unauthorized_record = ben
57
+ assert session.save
58
+ assert session.record
59
+ assert session.destroy
60
+ assert !session.record
61
+ end
62
+ end
63
+ end
64
+ end
@@ -0,0 +1,28 @@
1
+ require File.dirname(__FILE__) + '/../test_helper.rb'
2
+
3
+ module SessionTest
4
+ class HttpAuthTest < ActiveSupport::TestCase
5
+ class ConfiTest < ActiveSupport::TestCase
6
+ def test_allow_http_basic_auth
7
+ UserSession.allow_http_basic_auth = false
8
+ assert_equal false, UserSession.allow_http_basic_auth
9
+
10
+ UserSession.allow_http_basic_auth true
11
+ assert_equal true, UserSession.allow_http_basic_auth
12
+ end
13
+ end
14
+
15
+ class InstanceMethodsTest < ActiveSupport::TestCase
16
+ def test_persist_persist_by_http_auth
17
+ ben = users(:ben)
18
+ http_basic_auth_for { assert !UserSession.find }
19
+ http_basic_auth_for(ben) do
20
+ assert session = UserSession.find
21
+ assert_equal ben, session.record
22
+ assert_equal ben.login, session.login
23
+ assert_equal "benrocks", session.send(:protected_password)
24
+ end
25
+ end
26
+ end
27
+ end
28
+ end
@@ -0,0 +1,17 @@
1
+ require File.dirname(__FILE__) + '/../test_helper.rb'
2
+
3
+ module SessionTest
4
+ class IdTest < ActiveSupport::TestCase
5
+ def test_credentials
6
+ session = UserSession.new
7
+ session.credentials = [:my_id]
8
+ assert_equal :my_id, session.id
9
+ end
10
+
11
+ def test_id
12
+ session = UserSession.new
13
+ session.id = :my_id
14
+ assert_equal :my_id, session.id
15
+ end
16
+ end
17
+ end
@@ -0,0 +1,35 @@
1
+ require File.dirname(__FILE__) + '/../test_helper.rb'
2
+
3
+ module SessionTest
4
+ module KlassTest
5
+ class ConfigTest < ActiveSupport::TestCase
6
+ def test_authenticate_with
7
+ UserSession.authenticate_with = Employee
8
+ assert_equal "Employee", UserSession.klass_name
9
+ assert_equal Employee, UserSession.klass
10
+
11
+ UserSession.authenticate_with User
12
+ assert_equal "User", UserSession.klass_name
13
+ assert_equal User, UserSession.klass
14
+ end
15
+
16
+ def test_klass
17
+ assert_equal User, UserSession.klass
18
+ end
19
+
20
+ def test_klass_name
21
+ assert_equal "User", UserSession.klass_name
22
+ end
23
+ end
24
+
25
+ class InstanceMethodsTest < ActiveSupport::TestCase
26
+ def test_record_method
27
+ ben = users(:ben)
28
+ set_session_for(ben)
29
+ session = UserSession.find
30
+ assert_equal ben, session.record
31
+ assert_equal ben, session.user
32
+ end
33
+ end
34
+ end
35
+ end
@@ -0,0 +1,62 @@
1
+ require File.dirname(__FILE__) + '/../test_helper.rb'
2
+
3
+ module SessionTest
4
+ module MagicColumnsTest
5
+ class ConfigTest < ActiveSupport::TestCase
6
+ def test_last_request_at_threshold_config
7
+ UserSession.last_request_at_threshold = 2.minutes
8
+ assert_equal 2.minutes, UserSession.last_request_at_threshold
9
+
10
+ UserSession.last_request_at_threshold 0
11
+ assert_equal 0, UserSession.last_request_at_threshold
12
+ end
13
+ end
14
+
15
+ class InstanceMethodsTest < ActiveSupport::TestCase
16
+ def test_after_persisting_set_last_request_at
17
+ ben = users(:ben)
18
+ assert !UserSession.create(ben).new_session?
19
+
20
+ set_cookie_for(ben)
21
+ old_last_request_at = ben.last_request_at
22
+ assert UserSession.find
23
+ ben.reload
24
+ assert ben.last_request_at != old_last_request_at
25
+ end
26
+
27
+ def test_valid_increase_failed_login_count
28
+ ben = users(:ben)
29
+ old_failed_login_count = ben.failed_login_count
30
+ assert UserSession.create(:login => ben.login, :password => "wrong").new_session?
31
+ ben.reload
32
+ assert_equal old_failed_login_count + 1, ben.failed_login_count
33
+ end
34
+
35
+ def test_before_save_update_info
36
+ ben = users(:ben)
37
+
38
+ # increase failed login count
39
+ assert UserSession.create(:login => ben.login, :password => "wrong").new_session?
40
+ ben.reload
41
+
42
+ # grab old values
43
+ old_login_count = ben.login_count
44
+ old_failed_login_count = ben.failed_login_count
45
+ old_last_login_at = ben.last_login_at
46
+ old_current_login_at = ben.current_login_at
47
+ old_last_login_ip = ben.last_login_ip
48
+ old_current_login_ip = ben.current_login_ip
49
+
50
+ assert !UserSession.create(:login => ben.login, :password => "benrocks").new_session?
51
+
52
+ ben.reload
53
+ assert_equal old_login_count + 1, ben.login_count
54
+ assert_equal 0, ben.failed_login_count
55
+ assert_equal old_current_login_at, ben.last_login_at
56
+ assert ben.current_login_at != old_current_login_at
57
+ assert_equal old_current_login_ip, ben.last_login_ip
58
+ assert_equal "1.1.1.1", ben.current_login_ip
59
+ end
60
+ end
61
+ end
62
+ end