neocities/tests/acceptance/password_reset_tests.rb
2024-04-09 16:49:57 -05:00

109 lines
3.6 KiB
Ruby

require_relative './environment.rb'
describe '/password_reset' do
include Capybara::DSL
include Capybara::Minitest::Assertions
before do
Capybara.reset_sessions!
EmailWorker.jobs.clear
end
it 'should load the password reset page' do
visit '/password_reset'
_(page.body).must_match /Reset Password/
end
it 'should not load password reset if logged in' do
@site = Fabricate :site
page.set_rack_session id: @site.id
visit '/password_reset'
_(URI.parse(page.current_url).path).must_equal '/'
end
it 'errors for missing email' do
visit '/password_reset'
click_button 'Send Reset Token'
_(URI.parse(page.current_url).path).must_equal '/password_reset'
_(body).must_match /You must enter a valid email address/
end
it 'fails for invalid username or token' do
@site = Fabricate :site
visit '/password_reset'
fill_in 'email', with: @site.email
click_button 'Send Reset Token'
@site.reload
[
{username: 'derp', token: @site.password_reset_token},
{username: '', token: @site.password_reset_token},
{username: @site.username, token: 'derp'},
{token: 'derp'},
].each do |params|
visit "/password_reset_confirm?#{Rack::Utils.build_query params}"
_(page).must_have_content 'Could not find a site with this username and token'
_(@site.reload.password_reset_confirmed).must_equal false
end
[
{username: @site.username, token: ''},
{username: @site.username},
{username: '', token: ''}
].each do |params|
visit "/password_reset_confirm?#{Rack::Utils.build_query params}"
_(page).must_have_content 'Token cannot be empty'
_(@site.reload.password_reset_confirmed).must_equal false
end
end
it 'works for valid username and token' do
@site = Fabricate :site
visit '/password_reset'
fill_in 'email', with: @site.email
click_button 'Send Reset Token'
_(body).must_match /We sent an e-mail with password reset instructions/
_(@site.reload.password_reset_token.blank?).must_equal false
_(EmailWorker.jobs.first['args'].first['body']).must_match /#{Rack::Utils.build_query(username: @site.username, token: @site.password_reset_token)}/
visit "/password_reset_confirm?#{Rack::Utils.build_query username: @site.username, token: @site.reload.password_reset_token}"
_(@site.reload.password_reset_token).wont_be_nil
_(@site.password_reset_confirmed).must_equal true
_(page.current_url).must_match /.+\/settings#password/
fill_in 'new_password', with: 'n3wp4s$'
fill_in 'new_password_confirm', with: 'n3wp4s$'
click_button 'Change Password'
_(page.current_url).must_match /.+\/settings#password/
_(page).must_have_content 'Successfully changed password'
_(Site.valid_login?(@site.username, 'n3wp4s$')).must_equal true
_(page.get_rack_session['id']).must_equal @site.id
_(@site.reload.password_reset_token).must_be_nil
_(@site.password_reset_confirmed).must_equal false
end
it 'fails if timestamp is too old' do
@site = Fabricate :site
visit '/password_reset'
fill_in 'email', with: @site.email
click_button 'Send Reset Token'
@site.update password_reset_token: "#{SecureRandom.hex}-#{(Time.now - Site::PASSWORD_RESET_EXPIRATION_TIME - 1).to_i}"
visit "/password_reset_confirm?#{Rack::Utils.build_query username: @site.username, token: @site.reload.password_reset_token}"
_(page).must_have_content 'Token has expired'
_(@site.reload.password_reset_token).wont_be_nil
_(@site.password_reset_confirmed).must_equal false
end
end