123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291 |
- # frozen_string_literal: true
- require 'rails_helper'
- RSpec.describe Auth::RegistrationsController do
- render_views
- shared_examples 'checks for enabled registrations' do |path|
- around do |example|
- registrations_mode = Setting.registrations_mode
- example.run
- Setting.registrations_mode = registrations_mode
- end
- it 'redirects if it is in single user mode while it is open for registration' do
- Fabricate(:account)
- Setting.registrations_mode = 'open'
- allow(Rails.configuration.x).to receive(:single_user_mode).and_return(true)
- get path
- expect(response).to redirect_to '/'
- expect(Rails.configuration.x).to have_received(:single_user_mode)
- end
- it 'redirects if it is not open for registration while it is not in single user mode' do
- Setting.registrations_mode = 'none'
- allow(Rails.configuration.x).to receive(:single_user_mode).and_return(false)
- get path
- expect(response).to redirect_to '/'
- expect(Rails.configuration.x).to have_received(:single_user_mode)
- end
- end
- describe 'GET #edit' do
- before do
- request.env['devise.mapping'] = Devise.mappings[:user]
- sign_in(Fabricate(:user))
- get :edit
- end
- it 'returns http success' do
- expect(response).to have_http_status(200)
- end
- it 'returns private cache control header' do
- expect(response.headers['Cache-Control']).to include('private, no-store')
- end
- end
- describe 'GET #update' do
- let(:user) { Fabricate(:user) }
- before do
- request.env['devise.mapping'] = Devise.mappings[:user]
- sign_in(user, scope: :user)
- post :update
- end
- it 'returns http success' do
- expect(response).to have_http_status(200)
- end
- it 'returns private cache control headers' do
- expect(response.headers['Cache-Control']).to include('private, no-store')
- end
- context 'when suspended' do
- let(:user) { Fabricate(:user, account_attributes: { username: 'test', suspended_at: Time.now.utc }) }
- it 'returns http forbidden' do
- expect(response).to have_http_status(403)
- end
- end
- end
- describe 'GET #new' do
- before do
- request.env['devise.mapping'] = Devise.mappings[:user]
- end
- context 'with open registrations' do
- around do |example|
- registrations_mode = Setting.registrations_mode
- example.run
- Setting.registrations_mode = registrations_mode
- end
- it 'returns http success' do
- Setting.registrations_mode = 'open'
- get :new
- expect(response).to have_http_status(200)
- end
- end
- include_examples 'checks for enabled registrations', :new
- end
- describe 'POST #create' do
- let(:accept_language) { 'de' }
- before do
- session[:registration_form_time] = 5.seconds.ago
- request.env['devise.mapping'] = Devise.mappings[:user]
- end
- around do |example|
- I18n.with_locale(I18n.locale) do
- example.run
- end
- end
- context 'when an accept language is present in headers' do
- subject do
- Setting.registrations_mode = 'open'
- request.headers['Accept-Language'] = accept_language
- post :create, params: { user: { account_attributes: { username: 'test' }, email: 'test@example.com', password: '12345678', password_confirmation: '12345678', agreement: 'true' } }
- end
- around do |example|
- registrations_mode = Setting.registrations_mode
- example.run
- Setting.registrations_mode = registrations_mode
- end
- it 'redirects to setup' do
- subject
- expect(response).to redirect_to auth_setup_path
- end
- it 'creates user' do
- subject
- user = User.find_by(email: 'test@example.com')
- expect(user).to_not be_nil
- expect(user.locale).to eq(accept_language)
- end
- end
- context 'when user has not agreed to terms of service' do
- subject do
- Setting.registrations_mode = 'open'
- request.headers['Accept-Language'] = accept_language
- post :create, params: { user: { account_attributes: { username: 'test' }, email: 'test@example.com', password: '12345678', password_confirmation: '12345678', agreement: 'false' } }
- end
- around do |example|
- registrations_mode = Setting.registrations_mode
- example.run
- Setting.registrations_mode = registrations_mode
- end
- it 'does not create user' do
- subject
- user = User.find_by(email: 'test@example.com')
- expect(user).to be_nil
- end
- end
- context 'with Approval-based registrations without invite' do
- subject do
- Setting.registrations_mode = 'approved'
- request.headers['Accept-Language'] = accept_language
- post :create, params: { user: { account_attributes: { username: 'test' }, email: 'test@example.com', password: '12345678', password_confirmation: '12345678', agreement: 'true' } }
- end
- around do |example|
- registrations_mode = Setting.registrations_mode
- example.run
- Setting.registrations_mode = registrations_mode
- end
- it 'redirects to setup' do
- subject
- expect(response).to redirect_to auth_setup_path
- end
- it 'creates user' do
- subject
- user = User.find_by(email: 'test@example.com')
- expect(user).to_not be_nil
- expect(user.locale).to eq(accept_language)
- expect(user.approved).to be(false)
- end
- end
- context 'with Approval-based registrations with expired invite' do
- subject do
- Setting.registrations_mode = 'approved'
- request.headers['Accept-Language'] = accept_language
- invite = Fabricate(:invite, max_uses: nil, expires_at: 1.hour.ago)
- post :create, params: { user: { account_attributes: { username: 'test' }, email: 'test@example.com', password: '12345678', password_confirmation: '12345678', invite_code: invite.code, agreement: 'true' } }
- end
- around do |example|
- registrations_mode = Setting.registrations_mode
- example.run
- Setting.registrations_mode = registrations_mode
- end
- it 'redirects to setup' do
- subject
- expect(response).to redirect_to auth_setup_path
- end
- it 'creates user' do
- subject
- user = User.find_by(email: 'test@example.com')
- expect(user).to_not be_nil
- expect(user.locale).to eq(accept_language)
- expect(user.approved).to be(false)
- end
- end
- context 'with Approval-based registrations with valid invite and required invite text' do
- subject do
- inviter = Fabricate(:user, confirmed_at: 2.days.ago)
- Setting.registrations_mode = 'approved'
- Setting.require_invite_text = true
- request.headers['Accept-Language'] = accept_language
- invite = Fabricate(:invite, user: inviter, max_uses: nil, expires_at: 1.hour.from_now)
- post :create, params: { user: { account_attributes: { username: 'test' }, email: 'test@example.com', password: '12345678', password_confirmation: '12345678', invite_code: invite.code, agreement: 'true' } }
- end
- around do |example|
- registrations_mode = Setting.registrations_mode
- require_invite_text = Setting.require_invite_text
- example.run
- Setting.require_invite_text = require_invite_text
- Setting.registrations_mode = registrations_mode
- end
- it 'redirects to setup' do
- subject
- expect(response).to redirect_to auth_setup_path
- end
- it 'creates user' do
- subject
- user = User.find_by(email: 'test@example.com')
- expect(user).to_not be_nil
- expect(user.locale).to eq(accept_language)
- expect(user.approved).to be(true)
- end
- end
- context 'with an already taken username' do
- subject do
- Setting.registrations_mode = 'open'
- post :create, params: { user: { account_attributes: { username: 'test' }, email: 'test@example.com', password: '12345678', password_confirmation: '12345678', agreement: 'true' } }
- end
- before do
- Fabricate(:account, username: 'test')
- end
- it 'responds with an error message about the username' do
- subject
- expect(response).to have_http_status(:success)
- expect(username_error_text).to eq(I18n.t('errors.messages.taken'))
- end
- def username_error_text
- Nokogiri::Slop(response.body).css('.user_account_username .error').text
- end
- end
- include_examples 'checks for enabled registrations', :create
- end
- describe 'DELETE #destroy' do
- let(:user) { Fabricate(:user) }
- before do
- request.env['devise.mapping'] = Devise.mappings[:user]
- sign_in(user, scope: :user)
- delete :destroy
- end
- it 'returns http not found' do
- expect(response).to have_http_status(404)
- end
- it 'does not delete user' do
- expect(User.find(user.id)).to_not be_nil
- end
- end
- end
|