require 'rails_helper' class DummyBaseController < PgEngine::BaseController def action_with_redirect raise PgEngine::BaseController::Redirect, '/some_path' end def test_not_authorized raise Pundit::NotAuthorizedError end def test_internal_error raise PgEngine::Error end def check_dev_user @dev_user_or_env = dev_user_or_env? @dev_user = dev_user? head :ok end end # rubocop:disable RSpec/SpecFilePathFormat describe DummyBaseController do render_views describe 'PgEngine::BaseController::Redirect' do before { get :action_with_redirect } it do expect(response).to redirect_to '/some_path' end end describe 'internal_error' do subject do get :test_internal_error end it do subject expect(response).to have_http_status(:internal_server_error) expect(response.body).to include 'OcurriĆ³ algo inesperado' expect(response.body).to include '' end end context 'cuando acepta json' do before do request.headers['Accept'] = 'application/json' end it do subject expect(response).to have_http_status(:internal_server_error) end end end describe 'not_authorized' do subject do get :test_not_authorized end let(:user) { create :user } before do sign_in user end it do subject expect(response).to have_http_status(:unauthorized) end end describe '#dev_user_or_env?' do let(:user) { create :user, :developer } before do sign_in user if user.present? get :check_dev_user end it do expect(assigns(:dev_user_or_env)).to be_truthy expect(assigns(:dev_user)).to be_truthy end context 'when not signed in' do let(:user) { nil } it do expect(assigns(:dev_user_or_env)).to be_falsey expect(assigns(:dev_user)).to be_falsey end end end end # rubocop:enable RSpec/MultipleExpectations # rubocop:enable RSpec/SpecFilePathFormat