Commit c2ed7db3231ad0999848d13313ea18c8292e0f04
Exists in
master
and in
1 other branch
Merge pull request #685 from brianvanburken/devise-fix
Fixed password reset token not working for Devise in current Errbit build.
Showing
3 changed files
with
33 additions
and
2 deletions
Show diff stats
app/views/devise/mailer/reset_password_instructions.html.haml
| ... | ... | @@ -10,7 +10,7 @@ |
| 10 | 10 | %p |
| 11 | 11 | We hear you'd like to change your password. You can do that by visiting the link below: |
| 12 | 12 | %p |
| 13 | - = edit_password_url @resource, :reset_password_token => @resource.reset_password_token | |
| 13 | + = edit_password_url @resource, :reset_password_token => @token | |
| 14 | 14 | %tr |
| 15 | 15 | %td.content(valign="top") |
| 16 | 16 | %div | ... | ... |
app/views/devise/mailer/reset_password_instructions.text.erb
| ... | ... | @@ -2,7 +2,7 @@ Hello, |
| 2 | 2 | |
| 3 | 3 | We hear you'd like to change your password. You can do that by visiting the link below: |
| 4 | 4 | |
| 5 | - <%= edit_password_url(@resource, :reset_password_token => @resource.reset_password_token) %> | |
| 5 | + <%= edit_password_url(@resource, :reset_password_token => @token) %> | |
| 6 | 6 | |
| 7 | 7 | If you didn't request this, please ignore this email. Your password won't change unless you access the link above and create a new one. |
| 8 | 8 | ... | ... |
| ... | ... | @@ -0,0 +1,31 @@ |
| 1 | +require 'acceptance/acceptance_helper' | |
| 2 | + | |
| 3 | +feature 'password reset token' do | |
| 4 | + let(:user) { Fabricate :user } | |
| 5 | + | |
| 6 | + scenario 'receives correct password reset token' do | |
| 7 | + host = ActionMailer::Base.default_url_options.values_at(:host).first | |
| 8 | + port = ActionMailer::Base.default_url_options.values_at(:port).first | |
| 9 | + port = port.blank? ? '' : ':' + port | |
| 10 | + regex = %r{http://#{host}#{port}/users/password/edit\?reset_password_token=([A-Za-z0-9\-_]+)} | |
| 11 | + | |
| 12 | + visit 'https://brighterr.herokuapp.com/users/password/new' | |
| 13 | + fill_in 'Email', with: user.email | |
| 14 | + click_button 'Send me reset password instructions' | |
| 15 | + expect(page).to have_content I18n.t('devise.passwords.send_instructions') | |
| 16 | + | |
| 17 | + mail = ActionMailer::Base.deliveries.last | |
| 18 | + expect(mail.subject).to match(/Reset password instructions/) | |
| 19 | + expect(mail.body.encoded).to_not be_empty | |
| 20 | + expect(mail.body.encoded).to match(/change your password/) | |
| 21 | + expect(mail.body.encoded).to match(regex) | |
| 22 | + if mail.body.encoded =~ regex | |
| 23 | + visit "/users/password/edit?reset_password_token=#{$1}" | |
| 24 | + expect(page).to have_content 'Change your password' | |
| 25 | + fill_in 'New password', with: 'test12345' | |
| 26 | + fill_in 'Type your new password again', with: 'test12345' | |
| 27 | + click_button 'Change my password' | |
| 28 | + expect(page).to_not have_content 'Reset password token is invalid' | |
| 29 | + end | |
| 30 | + end | |
| 31 | +end | ... | ... |