2024-04-29 00:17:15 +02:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2021-08-31 18:14:32 +02:00
|
|
|
describe DevisePopulatedResource, type: :controller do
|
|
|
|
controller(Devise::PasswordsController) do
|
|
|
|
include DevisePopulatedResource
|
2022-04-19 18:51:03 +02:00
|
|
|
layout false
|
2021-08-31 18:14:32 +02:00
|
|
|
end
|
|
|
|
|
|
|
|
let(:user) { create(:user) }
|
|
|
|
|
|
|
|
before do
|
|
|
|
routes.draw do
|
|
|
|
get 'edit' => 'devise/passwords#edit'
|
|
|
|
put 'update' => 'devise/passwords#update'
|
|
|
|
end
|
|
|
|
|
|
|
|
@request.env["devise.mapping"] = Devise.mappings[:user]
|
|
|
|
|
|
|
|
@token = user.send_reset_password_instructions
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when initiating a password reset' do
|
2021-09-16 18:42:18 +02:00
|
|
|
subject { get :edit, params: { reset_password_token: token } }
|
2021-08-31 18:14:32 +02:00
|
|
|
|
2021-09-16 18:42:18 +02:00
|
|
|
context 'with a valid token' do
|
|
|
|
let(:token) { @token }
|
|
|
|
|
|
|
|
it 'returns the fully populated resource' do
|
|
|
|
subject
|
|
|
|
expect(controller.populated_resource.id).to eq(user.id)
|
|
|
|
expect(controller.populated_resource.email).to eq(user.email)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'with an expired token' do
|
|
|
|
let(:token) { 'invalid-token' }
|
|
|
|
|
|
|
|
it 'returns a new blank resource' do
|
|
|
|
subject
|
|
|
|
expect(controller.populated_resource).to be_present
|
|
|
|
expect(controller.populated_resource.new_record?).to be(true)
|
|
|
|
expect(controller.populated_resource.email).to be_blank
|
|
|
|
end
|
2021-08-31 18:14:32 +02:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when submitting a password reset' do
|
|
|
|
subject { put :update, params: { user: { reset_password_token: @token } } }
|
|
|
|
|
|
|
|
it 'returns the fully populated resource' do
|
|
|
|
subject
|
|
|
|
expect(controller.populated_resource.id).to eq(user.id)
|
|
|
|
expect(controller.populated_resource.email).to eq(user.email)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|