devise 4.1.1 → 4.8.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (255) hide show
  1. checksums.yaml +5 -5
  2. data/CHANGELOG.md +224 -4
  3. data/MIT-LICENSE +2 -1
  4. data/README.md +275 -90
  5. data/app/controllers/devise/confirmations_controller.rb +2 -0
  6. data/app/controllers/devise/omniauth_callbacks_controller.rb +7 -5
  7. data/app/controllers/devise/passwords_controller.rb +3 -0
  8. data/app/controllers/devise/registrations_controller.rb +34 -13
  9. data/app/controllers/devise/sessions_controller.rb +3 -1
  10. data/app/controllers/devise/unlocks_controller.rb +2 -0
  11. data/app/controllers/devise_controller.rb +5 -3
  12. data/app/helpers/devise_helper.rb +23 -18
  13. data/app/mailers/devise/mailer.rb +10 -4
  14. data/app/views/devise/confirmations/new.html.erb +2 -2
  15. data/app/views/devise/mailer/email_changed.html.erb +7 -0
  16. data/app/views/devise/passwords/edit.html.erb +3 -3
  17. data/app/views/devise/passwords/new.html.erb +2 -2
  18. data/app/views/devise/registrations/edit.html.erb +9 -5
  19. data/app/views/devise/registrations/new.html.erb +4 -4
  20. data/app/views/devise/sessions/new.html.erb +4 -4
  21. data/app/views/devise/shared/_error_messages.html.erb +15 -0
  22. data/app/views/devise/shared/_links.html.erb +8 -8
  23. data/app/views/devise/unlocks/new.html.erb +2 -2
  24. data/config/locales/en.yml +5 -2
  25. data/lib/devise.rb +39 -17
  26. data/lib/devise/controllers/helpers.rb +22 -9
  27. data/lib/devise/controllers/rememberable.rb +3 -1
  28. data/lib/devise/controllers/scoped_views.rb +2 -0
  29. data/lib/devise/controllers/sign_in_out.rb +39 -14
  30. data/lib/devise/controllers/store_location.rb +25 -7
  31. data/lib/devise/controllers/url_helpers.rb +3 -1
  32. data/lib/devise/delegator.rb +2 -0
  33. data/lib/devise/encryptor.rb +2 -0
  34. data/lib/devise/failure_app.rb +63 -33
  35. data/lib/devise/hooks/activatable.rb +2 -0
  36. data/lib/devise/hooks/csrf_cleaner.rb +2 -0
  37. data/lib/devise/hooks/forgetable.rb +2 -0
  38. data/lib/devise/hooks/lockable.rb +4 -2
  39. data/lib/devise/hooks/proxy.rb +3 -1
  40. data/lib/devise/hooks/rememberable.rb +2 -0
  41. data/lib/devise/hooks/timeoutable.rb +4 -2
  42. data/lib/devise/hooks/trackable.rb +2 -0
  43. data/lib/devise/mailers/helpers.rb +6 -3
  44. data/lib/devise/mapping.rb +3 -1
  45. data/lib/devise/models.rb +3 -1
  46. data/lib/devise/models/authenticatable.rb +63 -37
  47. data/lib/devise/models/confirmable.rb +79 -22
  48. data/lib/devise/models/database_authenticatable.rb +86 -17
  49. data/lib/devise/models/lockable.rb +17 -3
  50. data/lib/devise/models/omniauthable.rb +2 -0
  51. data/lib/devise/models/recoverable.rb +32 -20
  52. data/lib/devise/models/registerable.rb +4 -0
  53. data/lib/devise/models/rememberable.rb +5 -3
  54. data/lib/devise/models/timeoutable.rb +2 -0
  55. data/lib/devise/models/trackable.rb +15 -1
  56. data/lib/devise/models/validatable.rb +10 -3
  57. data/lib/devise/modules.rb +2 -0
  58. data/lib/devise/omniauth.rb +4 -5
  59. data/lib/devise/omniauth/config.rb +2 -0
  60. data/lib/devise/omniauth/url_helpers.rb +2 -51
  61. data/lib/devise/orm/active_record.rb +5 -1
  62. data/lib/devise/orm/mongoid.rb +6 -2
  63. data/lib/devise/parameter_filter.rb +4 -0
  64. data/lib/devise/parameter_sanitizer.rb +15 -56
  65. data/lib/devise/rails.rb +6 -6
  66. data/lib/devise/rails/deprecated_constant_accessor.rb +39 -0
  67. data/lib/devise/rails/routes.rb +9 -7
  68. data/lib/devise/rails/warden_compat.rb +2 -0
  69. data/lib/devise/secret_key_finder.rb +27 -0
  70. data/lib/devise/strategies/authenticatable.rb +3 -1
  71. data/lib/devise/strategies/base.rb +2 -0
  72. data/lib/devise/strategies/database_authenticatable.rb +8 -1
  73. data/lib/devise/strategies/rememberable.rb +2 -0
  74. data/lib/devise/test/controller_helpers.rb +167 -0
  75. data/lib/devise/test/integration_helpers.rb +63 -0
  76. data/lib/devise/test_helpers.rb +7 -129
  77. data/lib/devise/time_inflector.rb +2 -0
  78. data/lib/devise/token_generator.rb +2 -0
  79. data/lib/devise/version.rb +3 -1
  80. data/lib/generators/active_record/devise_generator.rb +40 -12
  81. data/lib/generators/active_record/templates/migration.rb +3 -1
  82. data/lib/generators/active_record/templates/migration_existing.rb +2 -0
  83. data/lib/generators/devise/controllers_generator.rb +3 -1
  84. data/lib/generators/devise/devise_generator.rb +5 -3
  85. data/lib/generators/devise/install_generator.rb +3 -5
  86. data/lib/generators/devise/orm_helpers.rb +9 -3
  87. data/lib/generators/devise/views_generator.rb +8 -9
  88. data/lib/generators/mongoid/devise_generator.rb +7 -5
  89. data/lib/generators/templates/README +9 -8
  90. data/lib/generators/templates/controllers/confirmations_controller.rb +2 -0
  91. data/lib/generators/templates/controllers/omniauth_callbacks_controller.rb +3 -1
  92. data/lib/generators/templates/controllers/passwords_controller.rb +2 -0
  93. data/lib/generators/templates/controllers/registrations_controller.rb +4 -2
  94. data/lib/generators/templates/controllers/sessions_controller.rb +3 -1
  95. data/lib/generators/templates/controllers/unlocks_controller.rb +2 -0
  96. data/lib/generators/templates/devise.rb +49 -6
  97. data/lib/generators/templates/markerb/email_changed.markerb +7 -0
  98. data/lib/generators/templates/markerb/password_change.markerb +2 -2
  99. data/lib/generators/templates/simple_form_for/confirmations/new.html.erb +5 -1
  100. data/lib/generators/templates/simple_form_for/passwords/edit.html.erb +10 -2
  101. data/lib/generators/templates/simple_form_for/passwords/new.html.erb +4 -1
  102. data/lib/generators/templates/simple_form_for/registrations/edit.html.erb +11 -3
  103. data/lib/generators/templates/simple_form_for/registrations/new.html.erb +11 -3
  104. data/lib/generators/templates/simple_form_for/sessions/new.html.erb +7 -2
  105. data/lib/generators/templates/simple_form_for/unlocks/new.html.erb +4 -1
  106. metadata +16 -297
  107. data/.gitignore +0 -10
  108. data/.travis.yml +0 -44
  109. data/.yardopts +0 -9
  110. data/CODE_OF_CONDUCT.md +0 -22
  111. data/CONTRIBUTING.md +0 -16
  112. data/Gemfile +0 -30
  113. data/Gemfile.lock +0 -182
  114. data/Rakefile +0 -36
  115. data/bin/test +0 -13
  116. data/devise.gemspec +0 -26
  117. data/devise.png +0 -0
  118. data/gemfiles/Gemfile.rails-4.1-stable +0 -30
  119. data/gemfiles/Gemfile.rails-4.1-stable.lock +0 -170
  120. data/gemfiles/Gemfile.rails-4.2-stable +0 -30
  121. data/gemfiles/Gemfile.rails-4.2-stable.lock +0 -192
  122. data/gemfiles/Gemfile.rails-5.0-beta +0 -37
  123. data/gemfiles/Gemfile.rails-5.0-beta.lock +0 -199
  124. data/test/controllers/custom_registrations_controller_test.rb +0 -40
  125. data/test/controllers/custom_strategy_test.rb +0 -64
  126. data/test/controllers/helper_methods_test.rb +0 -22
  127. data/test/controllers/helpers_test.rb +0 -316
  128. data/test/controllers/inherited_controller_i18n_messages_test.rb +0 -51
  129. data/test/controllers/internal_helpers_test.rb +0 -127
  130. data/test/controllers/load_hooks_controller_test.rb +0 -19
  131. data/test/controllers/passwords_controller_test.rb +0 -32
  132. data/test/controllers/sessions_controller_test.rb +0 -106
  133. data/test/controllers/url_helpers_test.rb +0 -65
  134. data/test/delegator_test.rb +0 -19
  135. data/test/devise_test.rb +0 -107
  136. data/test/failure_app_test.rb +0 -320
  137. data/test/generators/active_record_generator_test.rb +0 -83
  138. data/test/generators/controllers_generator_test.rb +0 -48
  139. data/test/generators/devise_generator_test.rb +0 -39
  140. data/test/generators/install_generator_test.rb +0 -24
  141. data/test/generators/mongoid_generator_test.rb +0 -23
  142. data/test/generators/views_generator_test.rb +0 -103
  143. data/test/helpers/devise_helper_test.rb +0 -49
  144. data/test/integration/authenticatable_test.rb +0 -698
  145. data/test/integration/confirmable_test.rb +0 -324
  146. data/test/integration/database_authenticatable_test.rb +0 -95
  147. data/test/integration/http_authenticatable_test.rb +0 -106
  148. data/test/integration/lockable_test.rb +0 -240
  149. data/test/integration/omniauthable_test.rb +0 -135
  150. data/test/integration/recoverable_test.rb +0 -347
  151. data/test/integration/registerable_test.rb +0 -357
  152. data/test/integration/rememberable_test.rb +0 -211
  153. data/test/integration/timeoutable_test.rb +0 -184
  154. data/test/integration/trackable_test.rb +0 -92
  155. data/test/mailers/confirmation_instructions_test.rb +0 -115
  156. data/test/mailers/reset_password_instructions_test.rb +0 -96
  157. data/test/mailers/unlock_instructions_test.rb +0 -91
  158. data/test/mapping_test.rb +0 -134
  159. data/test/models/authenticatable_test.rb +0 -23
  160. data/test/models/confirmable_test.rb +0 -511
  161. data/test/models/database_authenticatable_test.rb +0 -269
  162. data/test/models/lockable_test.rb +0 -350
  163. data/test/models/omniauthable_test.rb +0 -7
  164. data/test/models/recoverable_test.rb +0 -251
  165. data/test/models/registerable_test.rb +0 -7
  166. data/test/models/rememberable_test.rb +0 -169
  167. data/test/models/serializable_test.rb +0 -49
  168. data/test/models/timeoutable_test.rb +0 -51
  169. data/test/models/trackable_test.rb +0 -41
  170. data/test/models/validatable_test.rb +0 -119
  171. data/test/models_test.rb +0 -153
  172. data/test/omniauth/config_test.rb +0 -57
  173. data/test/omniauth/url_helpers_test.rb +0 -51
  174. data/test/orm/active_record.rb +0 -17
  175. data/test/orm/mongoid.rb +0 -13
  176. data/test/parameter_sanitizer_test.rb +0 -131
  177. data/test/rails_app/Rakefile +0 -6
  178. data/test/rails_app/app/active_record/admin.rb +0 -6
  179. data/test/rails_app/app/active_record/shim.rb +0 -2
  180. data/test/rails_app/app/active_record/user.rb +0 -7
  181. data/test/rails_app/app/active_record/user_on_engine.rb +0 -7
  182. data/test/rails_app/app/active_record/user_on_main_app.rb +0 -7
  183. data/test/rails_app/app/active_record/user_without_email.rb +0 -8
  184. data/test/rails_app/app/controllers/admins/sessions_controller.rb +0 -6
  185. data/test/rails_app/app/controllers/admins_controller.rb +0 -6
  186. data/test/rails_app/app/controllers/application_controller.rb +0 -11
  187. data/test/rails_app/app/controllers/application_with_fake_engine.rb +0 -30
  188. data/test/rails_app/app/controllers/custom/registrations_controller.rb +0 -31
  189. data/test/rails_app/app/controllers/home_controller.rb +0 -29
  190. data/test/rails_app/app/controllers/publisher/registrations_controller.rb +0 -2
  191. data/test/rails_app/app/controllers/publisher/sessions_controller.rb +0 -2
  192. data/test/rails_app/app/controllers/users/omniauth_callbacks_controller.rb +0 -14
  193. data/test/rails_app/app/controllers/users_controller.rb +0 -31
  194. data/test/rails_app/app/helpers/application_helper.rb +0 -3
  195. data/test/rails_app/app/mailers/users/from_proc_mailer.rb +0 -3
  196. data/test/rails_app/app/mailers/users/mailer.rb +0 -3
  197. data/test/rails_app/app/mailers/users/reply_to_mailer.rb +0 -4
  198. data/test/rails_app/app/mongoid/admin.rb +0 -29
  199. data/test/rails_app/app/mongoid/shim.rb +0 -23
  200. data/test/rails_app/app/mongoid/user.rb +0 -39
  201. data/test/rails_app/app/mongoid/user_on_engine.rb +0 -39
  202. data/test/rails_app/app/mongoid/user_on_main_app.rb +0 -39
  203. data/test/rails_app/app/mongoid/user_without_email.rb +0 -33
  204. data/test/rails_app/app/views/admins/index.html.erb +0 -1
  205. data/test/rails_app/app/views/admins/sessions/new.html.erb +0 -2
  206. data/test/rails_app/app/views/home/admin_dashboard.html.erb +0 -1
  207. data/test/rails_app/app/views/home/index.html.erb +0 -1
  208. data/test/rails_app/app/views/home/join.html.erb +0 -1
  209. data/test/rails_app/app/views/home/private.html.erb +0 -1
  210. data/test/rails_app/app/views/home/user_dashboard.html.erb +0 -1
  211. data/test/rails_app/app/views/layouts/application.html.erb +0 -24
  212. data/test/rails_app/app/views/users/edit_form.html.erb +0 -1
  213. data/test/rails_app/app/views/users/index.html.erb +0 -1
  214. data/test/rails_app/app/views/users/mailer/confirmation_instructions.erb +0 -1
  215. data/test/rails_app/app/views/users/sessions/new.html.erb +0 -1
  216. data/test/rails_app/bin/bundle +0 -3
  217. data/test/rails_app/bin/rails +0 -4
  218. data/test/rails_app/bin/rake +0 -4
  219. data/test/rails_app/config.ru +0 -4
  220. data/test/rails_app/config/application.rb +0 -44
  221. data/test/rails_app/config/boot.rb +0 -14
  222. data/test/rails_app/config/database.yml +0 -18
  223. data/test/rails_app/config/environment.rb +0 -5
  224. data/test/rails_app/config/environments/development.rb +0 -30
  225. data/test/rails_app/config/environments/production.rb +0 -84
  226. data/test/rails_app/config/environments/test.rb +0 -46
  227. data/test/rails_app/config/initializers/backtrace_silencers.rb +0 -7
  228. data/test/rails_app/config/initializers/devise.rb +0 -180
  229. data/test/rails_app/config/initializers/inflections.rb +0 -2
  230. data/test/rails_app/config/initializers/secret_token.rb +0 -3
  231. data/test/rails_app/config/initializers/session_store.rb +0 -1
  232. data/test/rails_app/config/routes.rb +0 -126
  233. data/test/rails_app/db/migrate/20100401102949_create_tables.rb +0 -71
  234. data/test/rails_app/db/schema.rb +0 -55
  235. data/test/rails_app/lib/shared_admin.rb +0 -17
  236. data/test/rails_app/lib/shared_user.rb +0 -30
  237. data/test/rails_app/lib/shared_user_without_email.rb +0 -26
  238. data/test/rails_app/lib/shared_user_without_omniauth.rb +0 -13
  239. data/test/rails_app/public/404.html +0 -26
  240. data/test/rails_app/public/422.html +0 -26
  241. data/test/rails_app/public/500.html +0 -26
  242. data/test/rails_app/public/favicon.ico +0 -0
  243. data/test/rails_test.rb +0 -9
  244. data/test/routes_test.rb +0 -279
  245. data/test/support/action_controller/record_identifier.rb +0 -10
  246. data/test/support/assertions.rb +0 -39
  247. data/test/support/helpers.rb +0 -77
  248. data/test/support/http_method_compatibility.rb +0 -51
  249. data/test/support/integration.rb +0 -92
  250. data/test/support/locale/en.yml +0 -8
  251. data/test/support/mongoid.yml +0 -6
  252. data/test/support/webrat/integrations/rails.rb +0 -33
  253. data/test/test_helper.rb +0 -34
  254. data/test/test_helpers_test.rb +0 -178
  255. data/test/test_models.rb +0 -33
@@ -1,184 +0,0 @@
1
- require 'test_helper'
2
-
3
- class SessionTimeoutTest < Devise::IntegrationTest
4
-
5
- def last_request_at
6
- @controller.user_session['last_request_at']
7
- end
8
-
9
- test 'set last request at in user session after each request' do
10
- sign_in_as_user
11
- assert_not_nil last_request_at
12
-
13
- @controller.user_session.delete('last_request_at')
14
- get users_path
15
- assert_not_nil last_request_at
16
- end
17
-
18
- test 'set last request at in user session after each request is skipped if tracking is disabled' do
19
- sign_in_as_user
20
- old_last_request = last_request_at
21
- assert_not_nil last_request_at
22
-
23
- get users_path, headers: { 'devise.skip_trackable' => true }
24
- assert_equal old_last_request, last_request_at
25
- end
26
-
27
- test 'does not set last request at in user session after each request if timeoutable is disabled' do
28
- sign_in_as_user
29
- old_last_request = last_request_at
30
- assert_not_nil last_request_at
31
-
32
- new_time = 2.seconds.from_now
33
- Time.stubs(:now).returns(new_time)
34
-
35
- get users_path, headers: { 'devise.skip_timeoutable' => true }
36
- assert_equal old_last_request, last_request_at
37
- end
38
-
39
- test 'does not time out user session before default limit time' do
40
- sign_in_as_user
41
- assert_response :success
42
- assert warden.authenticated?(:user)
43
-
44
- get users_path
45
- assert_response :success
46
- assert warden.authenticated?(:user)
47
- end
48
-
49
- test 'time out user session after default limit time when sign_out_all_scopes is false' do
50
- swap Devise, sign_out_all_scopes: false do
51
- sign_in_as_admin
52
-
53
- user = sign_in_as_user
54
- get expire_user_path(user)
55
- assert_not_nil last_request_at
56
-
57
- get users_path
58
- assert_redirected_to users_path
59
- assert_not warden.authenticated?(:user)
60
- assert warden.authenticated?(:admin)
61
- end
62
- end
63
-
64
- test 'time out all sessions after default limit time when sign_out_all_scopes is true' do
65
- swap Devise, sign_out_all_scopes: true do
66
- sign_in_as_admin
67
-
68
- user = sign_in_as_user
69
- get expire_user_path(user)
70
- assert_not_nil last_request_at
71
-
72
- get root_path
73
- assert_not warden.authenticated?(:user)
74
- assert_not warden.authenticated?(:admin)
75
- end
76
- end
77
-
78
- test 'time out user session after deault limit time and redirect to latest get request' do
79
- user = sign_in_as_user
80
- visit edit_form_user_path(user)
81
-
82
- click_button 'Update'
83
- sign_in_as_user
84
-
85
- assert_equal edit_form_user_url(user), current_url
86
- end
87
-
88
- test 'time out is not triggered on sign out' do
89
- user = sign_in_as_user
90
- get expire_user_path(user)
91
-
92
- delete destroy_user_session_path
93
-
94
- assert_response :redirect
95
- assert_redirected_to root_path
96
- follow_redirect!
97
- assert_contain 'Signed out successfully'
98
- end
99
-
100
- test 'expired session is not extended by sign in page' do
101
- user = sign_in_as_user
102
- get expire_user_path(user)
103
- assert warden.authenticated?(:user)
104
-
105
- get "/users/sign_in"
106
- assert_redirected_to "/users/sign_in"
107
- follow_redirect!
108
-
109
- assert_response :success
110
- assert_contain 'Sign in'
111
- assert_not warden.authenticated?(:user)
112
- end
113
-
114
- test 'time out is not triggered on sign in' do
115
- user = sign_in_as_user
116
- get expire_user_path(user)
117
-
118
- post "/users/sign_in", params: { email: user.email, password: "123456" }
119
-
120
- assert_response :redirect
121
- follow_redirect!
122
- assert_contain 'You are signed in'
123
- end
124
-
125
- test 'user configured timeout limit' do
126
- swap Devise, timeout_in: 8.minutes do
127
- user = sign_in_as_user
128
-
129
- get users_path
130
- assert_not_nil last_request_at
131
- assert_response :success
132
- assert warden.authenticated?(:user)
133
-
134
- get expire_user_path(user)
135
- get users_path
136
- assert_redirected_to users_path
137
- assert_not warden.authenticated?(:user)
138
- end
139
- end
140
-
141
- test 'error message with i18n' do
142
- store_translations :en, devise: {
143
- failure: { user: { timeout: 'Session expired!' } }
144
- } do
145
- user = sign_in_as_user
146
-
147
- get expire_user_path(user)
148
- get root_path
149
- follow_redirect!
150
- assert_contain 'Session expired!'
151
- end
152
- end
153
-
154
- test 'error message with i18n with double redirect' do
155
- store_translations :en, devise: {
156
- failure: { user: { timeout: 'Session expired!' } }
157
- } do
158
- user = sign_in_as_user
159
-
160
- get expire_user_path(user)
161
- get users_path
162
- follow_redirect!
163
- follow_redirect!
164
- assert_contain 'Session expired!'
165
- end
166
- end
167
-
168
- test 'time out not triggered if remembered' do
169
- user = sign_in_as_user remember_me: true
170
- get expire_user_path(user)
171
- assert_not_nil last_request_at
172
-
173
- get users_path
174
- assert_response :success
175
- assert warden.authenticated?(:user)
176
- end
177
-
178
- test 'does not crash when the last_request_at is a String' do
179
- user = sign_in_as_user
180
-
181
- get edit_form_user_path(user, last_request_at: Time.now.utc.to_s)
182
- get users_path
183
- end
184
- end
@@ -1,92 +0,0 @@
1
- require 'test_helper'
2
-
3
- class TrackableHooksTest < Devise::IntegrationTest
4
-
5
- test "current and last sign in timestamps are updated on each sign in" do
6
- user = create_user
7
- assert_nil user.current_sign_in_at
8
- assert_nil user.last_sign_in_at
9
-
10
- sign_in_as_user
11
- user.reload
12
-
13
- assert user.current_sign_in_at.acts_like?(:time)
14
- assert user.last_sign_in_at.acts_like?(:time)
15
-
16
- assert_equal user.current_sign_in_at, user.last_sign_in_at
17
- assert user.current_sign_in_at >= user.created_at
18
-
19
- delete destroy_user_session_path
20
- new_time = 2.seconds.from_now
21
- Time.stubs(:now).returns(new_time)
22
-
23
- sign_in_as_user
24
- user.reload
25
- assert user.current_sign_in_at > user.last_sign_in_at
26
- end
27
-
28
- test "current and last sign in remote ip are updated on each sign in" do
29
- user = create_user
30
- assert_nil user.current_sign_in_ip
31
- assert_nil user.last_sign_in_ip
32
-
33
- sign_in_as_user
34
- user.reload
35
-
36
- assert_equal "127.0.0.1", user.current_sign_in_ip
37
- assert_equal "127.0.0.1", user.last_sign_in_ip
38
- end
39
-
40
- test "current remote ip returns original ip behind a non transparent proxy" do
41
- user = create_user
42
-
43
- arbitrary_ip = '200.121.1.69'
44
- sign_in_as_user do
45
- header 'HTTP_X_FORWARDED_FOR', arbitrary_ip
46
- end
47
- user.reload
48
- assert_equal arbitrary_ip, user.current_sign_in_ip
49
- end
50
-
51
- test "increase sign in count" do
52
- user = create_user
53
- assert_equal 0, user.sign_in_count
54
-
55
- sign_in_as_user
56
- user.reload
57
- assert_equal 1, user.sign_in_count
58
-
59
- delete destroy_user_session_path
60
- sign_in_as_user
61
- user.reload
62
- assert_equal 2, user.sign_in_count
63
- end
64
-
65
- test "does not update anything if user has signed out along the way" do
66
- swap Devise, allow_unconfirmed_access_for: 0.days do
67
- user = create_user(confirm: false)
68
- sign_in_as_user
69
-
70
- user.reload
71
- assert_nil user.current_sign_in_at
72
- assert_nil user.last_sign_in_at
73
- end
74
- end
75
-
76
- test "do not track if devise.skip_trackable is set" do
77
- user = create_user
78
- sign_in_as_user do
79
- header 'devise.skip_trackable', '1'
80
- end
81
- user.reload
82
- assert_equal 0, user.sign_in_count
83
- delete destroy_user_session_path
84
-
85
- sign_in_as_user do
86
- header 'devise.skip_trackable', false
87
- end
88
- user.reload
89
- assert_equal 1, user.sign_in_count
90
- end
91
-
92
- end
@@ -1,115 +0,0 @@
1
- require 'test_helper'
2
-
3
- class ConfirmationInstructionsTest < ActionMailer::TestCase
4
-
5
- def setup
6
- setup_mailer
7
- Devise.mailer = 'Devise::Mailer'
8
- Devise.mailer_sender = 'test@example.com'
9
- end
10
-
11
- def teardown
12
- Devise.mailer = 'Devise::Mailer'
13
- Devise.mailer_sender = 'please-change-me@config-initializers-devise.com'
14
- end
15
-
16
- def user
17
- @user ||= create_user
18
- end
19
-
20
- def mail
21
- @mail ||= begin
22
- user
23
- ActionMailer::Base.deliveries.first
24
- end
25
- end
26
-
27
- test 'email sent after creating the user' do
28
- assert_not_nil mail
29
- end
30
-
31
- test 'content type should be set to html' do
32
- assert mail.content_type.include?('text/html')
33
- end
34
-
35
- test 'send confirmation instructions to the user email' do
36
- mail
37
- assert_equal [user.email], mail.to
38
- end
39
-
40
- test 'set up sender from configuration' do
41
- assert_equal ['test@example.com'], mail.from
42
- end
43
-
44
- test 'set up sender from custom mailer defaults' do
45
- Devise.mailer = 'Users::Mailer'
46
- assert_equal ['custom@example.com'], mail.from
47
- end
48
-
49
- test 'set up sender from custom mailer defaults with proc' do
50
- Devise.mailer = 'Users::FromProcMailer'
51
- assert_equal ['custom@example.com'], mail.from
52
- end
53
-
54
- test 'custom mailer renders parent mailer template' do
55
- Devise.mailer = 'Users::Mailer'
56
- assert_present mail.body.encoded
57
- end
58
-
59
- test 'set up reply to as copy from sender' do
60
- assert_equal ['test@example.com'], mail.reply_to
61
- end
62
-
63
- test 'set up reply to as different if set in defaults' do
64
- Devise.mailer = 'Users::ReplyToMailer'
65
- assert_equal ['custom@example.com'], mail.from
66
- assert_equal ['custom_reply_to@example.com'], mail.reply_to
67
- end
68
-
69
- test 'set up subject from I18n' do
70
- store_translations :en, devise: { mailer: { confirmation_instructions: { subject: 'Account Confirmation' } } } do
71
- assert_equal 'Account Confirmation', mail.subject
72
- end
73
- end
74
-
75
- test 'subject namespaced by model' do
76
- store_translations :en, devise: { mailer: { confirmation_instructions: { user_subject: 'User Account Confirmation' } } } do
77
- assert_equal 'User Account Confirmation', mail.subject
78
- end
79
- end
80
-
81
- test 'body should have user info' do
82
- assert_match user.email, mail.body.encoded
83
- end
84
-
85
- test 'body should have link to confirm the account' do
86
- host, port = ActionMailer::Base.default_url_options.values_at :host, :port
87
-
88
- if mail.body.encoded =~ %r{<a href=\"http://#{host}:#{port}/users/confirmation\?confirmation_token=([^"]+)">}
89
- assert_equal $1, user.confirmation_token
90
- else
91
- flunk "expected confirmation url regex to match"
92
- end
93
- end
94
-
95
- test 'renders a scoped if scoped_views is set to true' do
96
- swap Devise, scoped_views: true do
97
- assert_equal user.email, mail.body.decoded
98
- end
99
- end
100
-
101
- test 'renders a scoped if scoped_views is set in the mailer class' do
102
- begin
103
- Devise::Mailer.scoped_views = true
104
- assert_equal user.email, mail.body.decoded
105
- ensure
106
- Devise::Mailer.send :remove_instance_variable, :@scoped_views
107
- end
108
- end
109
-
110
- test 'mailer sender accepts a proc' do
111
- swap Devise, mailer_sender: proc { "another@example.com" } do
112
- assert_equal ['another@example.com'], mail.from
113
- end
114
- end
115
- end
@@ -1,96 +0,0 @@
1
- require 'test_helper'
2
-
3
- class ResetPasswordInstructionsTest < ActionMailer::TestCase
4
- def setup
5
- setup_mailer
6
- Devise.mailer = 'Devise::Mailer'
7
- Devise.mailer_sender = 'test@example.com'
8
- end
9
-
10
- def teardown
11
- Devise.mailer = 'Devise::Mailer'
12
- Devise.mailer_sender = 'please-change-me@config-initializers-devise.com'
13
- end
14
-
15
- def user
16
- @user ||= begin
17
- user = create_user
18
- user.send_reset_password_instructions
19
- user
20
- end
21
- end
22
-
23
- def mail
24
- @mail ||= begin
25
- user
26
- ActionMailer::Base.deliveries.last
27
- end
28
- end
29
-
30
- test 'email sent after reseting the user password' do
31
- assert_not_nil mail
32
- end
33
-
34
- test 'content type should be set to html' do
35
- assert mail.content_type.include?('text/html')
36
- end
37
-
38
- test 'send confirmation instructions to the user email' do
39
- assert_equal [user.email], mail.to
40
- end
41
-
42
- test 'set up sender from configuration' do
43
- assert_equal ['test@example.com'], mail.from
44
- end
45
-
46
- test 'set up sender from custom mailer defaults' do
47
- Devise.mailer = 'Users::Mailer'
48
- assert_equal ['custom@example.com'], mail.from
49
- end
50
-
51
- test 'set up sender from custom mailer defaults with proc' do
52
- Devise.mailer = 'Users::FromProcMailer'
53
- assert_equal ['custom@example.com'], mail.from
54
- end
55
-
56
- test 'custom mailer renders parent mailer template' do
57
- Devise.mailer = 'Users::Mailer'
58
- assert_present mail.body.encoded
59
- end
60
-
61
- test 'set up reply to as copy from sender' do
62
- assert_equal ['test@example.com'], mail.reply_to
63
- end
64
-
65
- test 'set up subject from I18n' do
66
- store_translations :en, devise: { mailer: { reset_password_instructions: { subject: 'Reset instructions' } } } do
67
- assert_equal 'Reset instructions', mail.subject
68
- end
69
- end
70
-
71
- test 'subject namespaced by model' do
72
- store_translations :en, devise: { mailer: { reset_password_instructions: { user_subject: 'User Reset Instructions' } } } do
73
- assert_equal 'User Reset Instructions', mail.subject
74
- end
75
- end
76
-
77
- test 'body should have user info' do
78
- assert_match user.email, mail.body.encoded
79
- end
80
-
81
- test 'body should have link to confirm the account' do
82
- host, port = ActionMailer::Base.default_url_options.values_at :host, :port
83
-
84
- if mail.body.encoded =~ %r{<a href=\"http://#{host}:#{port}/users/password/edit\?reset_password_token=([^"]+)">}
85
- assert_equal Devise.token_generator.digest(user.class, :reset_password_token, $1), user.reset_password_token
86
- else
87
- flunk "expected reset password url regex to match"
88
- end
89
- end
90
-
91
- test 'mailer sender accepts a proc' do
92
- swap Devise, mailer_sender: proc { "another@example.com" } do
93
- assert_equal ['another@example.com'], mail.from
94
- end
95
- end
96
- end