adopt-a-hydrant/test/functional/passwords_controller_test.rb

48 lines
1.8 KiB
Ruby

require 'test_helper'
class PasswordsControllerTest < ActionController::TestCase
include Devise::TestHelpers
setup do
request.env["devise.mapping"] = Devise.mappings[:user]
@user = users(:erik)
end
test 'should send password reset instructions if email address is found' do
num_deliveries = ActionMailer::Base.deliveries.size
post :create, user: {email: @user.email}
assert_equal num_deliveries + 1, ActionMailer::Base.deliveries.size
assert_response :success
email = ActionMailer::Base.deliveries.last
assert_equal [@user.email], email.to
assert_equal 'Reset password instructions', email.subject
end
test 'should not send password reset instructions if email address is not found' do
post :create, user: {email: 'not_found@example.com'}
assert_response :error
end
test 'should render edit view' do
get :edit, reset_password_token: 'token'
assert_response :success
end
test 'should reset user password with an valid reset password token' do
@user.send :generate_reset_password_token!
put :update, user: {reset_password_token: @user.reset_password_token, password: 'new_password', password_confirmation: 'new_password'}
@user.reload
assert @user.valid_password?('new_password')
assert_response :redirect
assert_redirected_to controller: 'main', action: 'index'
end
test 'should not reset user password with an invalid reset password token' do
@user.send :generate_reset_password_token!
put :update, user: {reset_password_token: 'invalid_token', password: 'new_password', password_confirmation: 'new_password'}
@user.reload
assert !@user.valid_password?('new_password')
assert_response :redirect
assert_redirected_to controller: 'main', action: 'index'
end
end