|
|
|
require "rails_helper"
|
|
|
|
require_relative "../../support/devise"
|
|
|
|
|
|
|
|
RSpec.describe Auth::PasswordsController, type: :request do
|
|
|
|
let(:params) { { user: { email: email } } }
|
|
|
|
let(:page) { Capybara::Node::Simple.new(response.body) }
|
|
|
|
|
|
|
|
context "when a password reset is requested for a valid email" do
|
|
|
|
let(:user) { FactoryBot.create(:user) }
|
|
|
|
let(:email) { user.email }
|
|
|
|
|
|
|
|
it "redirects to the email sent page" do
|
|
|
|
post "/users/password", params: params
|
|
|
|
expect(response).to have_http_status(:redirect)
|
|
|
|
follow_redirect!
|
|
|
|
expect(response.body).to match(/Check your email/)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context "when a password reset is requested with an email that doesn't exist in the system" do
|
|
|
|
before do
|
|
|
|
allow_any_instance_of(Auth::PasswordsController).to receive(:is_navigational_format?).and_return(false)
|
|
|
|
end
|
|
|
|
|
|
|
|
let(:email) { "madeup_email@test.com" }
|
|
|
|
|
|
|
|
it "redirects to the email sent page anyway" do
|
|
|
|
post "/users/password", params: params
|
|
|
|
expect(response).to have_http_status(:redirect)
|
|
|
|
follow_redirect!
|
|
|
|
expect(response.body).to match(/Check your email/)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context "when a password reset is requested the email" do
|
|
|
|
let(:user) { FactoryBot.create(:user, last_sign_in_at: Time.zone.now) }
|
|
|
|
let(:email) { user.email }
|
|
|
|
|
|
|
|
it "should contain the correct email" do
|
|
|
|
post "/users/password", params: params
|
|
|
|
follow_redirect!
|
|
|
|
email_ascii_content = ActionMailer::Base.deliveries.last.body.raw_source
|
|
|
|
email_content = email_ascii_content.encode("ASCII", "UTF-8", undef: :replace)
|
|
|
|
expect(email_content).to match(email)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context "#Update - reset password" do
|
|
|
|
let(:user) { FactoryBot.create(:user) }
|
|
|
|
let(:token) { user.send(:set_reset_password_token) }
|
|
|
|
let(:updated_password) { "updated_password_280" }
|
|
|
|
let(:update_password_params) do
|
|
|
|
{
|
|
|
|
user:
|
|
|
|
{
|
|
|
|
reset_password_token: token,
|
|
|
|
password: updated_password,
|
|
|
|
password_confirmation: updated_password,
|
|
|
|
},
|
|
|
|
}
|
|
|
|
end
|
|
|
|
let(:message) { "Your password has been changed successfully. You are now signed in" }
|
|
|
|
|
|
|
|
it "changes the password" do
|
|
|
|
expect { put "/users/password", params: update_password_params }
|
|
|
|
.to(change { user.reload.encrypted_password })
|
|
|
|
end
|
|
|
|
|
|
|
|
it "signs in" do
|
|
|
|
put "/users/password", params: update_password_params
|
|
|
|
follow_redirect!
|
|
|
|
expect(page).to have_css("div", class: "govuk-notification-banner__heading", text: message)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|