Convert `settings/migration/redirects` spec controller->system (#33905)
This commit is contained in:
		
							parent
							
								
									db59f37269
								
							
						
					
					
						commit
						b07cd11f4c
					
				|  | @ -1,67 +0,0 @@ | |||
| # frozen_string_literal: true | ||||
| 
 | ||||
| require 'rails_helper' | ||||
| 
 | ||||
| RSpec.describe Settings::Migration::RedirectsController do | ||||
|   render_views | ||||
| 
 | ||||
|   let!(:user) { Fabricate(:user, password: 'testtest') } | ||||
| 
 | ||||
|   before do | ||||
|     sign_in user, scope: :user | ||||
|   end | ||||
| 
 | ||||
|   describe 'GET #new' do | ||||
|     before do | ||||
|       get :new | ||||
|     end | ||||
| 
 | ||||
|     it 'returns http success with private cache control headers', :aggregate_failures do | ||||
|       expect(response).to have_http_status(200) | ||||
|       expect(response.headers['Cache-Control']).to include('private, no-store') | ||||
|     end | ||||
|   end | ||||
| 
 | ||||
|   describe 'POST #create' do | ||||
|     context 'with valid params' do | ||||
|       before { stub_resolver } | ||||
| 
 | ||||
|       it 'redirects to the settings migration path' do | ||||
|         post :create, params: { form_redirect: { acct: 'new@host.com', current_password: 'testtest' } } | ||||
| 
 | ||||
|         expect(response).to redirect_to(settings_migration_path) | ||||
|       end | ||||
|     end | ||||
| 
 | ||||
|     context 'with non valid params' do | ||||
|       it 'returns success and renders the new page' do | ||||
|         post :create, params: { form_redirect: { acct: '' } } | ||||
| 
 | ||||
|         expect(response).to have_http_status(200) | ||||
|         expect(response).to render_template(:new) | ||||
|       end | ||||
|     end | ||||
|   end | ||||
| 
 | ||||
|   describe 'DELETE #destroy' do | ||||
|     let(:account) { Fabricate(:account) } | ||||
| 
 | ||||
|     before do | ||||
|       user.account.update(moved_to_account_id: account.id) | ||||
|     end | ||||
| 
 | ||||
|     it 'resets the account and sends an update' do | ||||
|       delete :destroy | ||||
| 
 | ||||
|       expect(response).to redirect_to(settings_migration_path) | ||||
|       expect(user.account.reload.moved_to_account).to be_nil | ||||
|     end | ||||
|   end | ||||
| 
 | ||||
|   private | ||||
| 
 | ||||
|   def stub_resolver | ||||
|     resolver = instance_double(ResolveAccountService, call: Fabricate(:account)) | ||||
|     allow(ResolveAccountService).to receive(:new).and_return(resolver) | ||||
|   end | ||||
| end | ||||
|  | @ -0,0 +1,42 @@ | |||
| # frozen_string_literal: true | ||||
| 
 | ||||
| require 'rails_helper' | ||||
| 
 | ||||
| RSpec.describe 'Settings Migration Redirects' do | ||||
|   let!(:user) { Fabricate(:user, password: 'testtest') } | ||||
| 
 | ||||
|   before { sign_in(user) } | ||||
| 
 | ||||
|   describe 'Managing redirects' do | ||||
|     before { stub_resolver } | ||||
| 
 | ||||
|     it 'creates and destroys redirects' do | ||||
|       visit new_settings_migration_redirect_path | ||||
|       expect(page) | ||||
|         .to have_title(I18n.t('settings.migrate')) | ||||
| 
 | ||||
|       # Empty form invalid submission | ||||
|       expect { click_on I18n.t('migrations.set_redirect') } | ||||
|         .to_not(change { user.account.moved_to_account_id }.from(nil)) | ||||
| 
 | ||||
|       # Valid form submission | ||||
|       fill_in 'form_redirect_acct', with: 'new@example.host' | ||||
|       fill_in 'form_redirect_current_password', with: 'testtest' | ||||
|       expect { click_on I18n.t('migrations.set_redirect') } | ||||
|         .to(change { user.reload.account.moved_to_account_id }.from(nil)) | ||||
| 
 | ||||
|       # Delete the account move | ||||
|       expect { click_on I18n.t('migrations.cancel') } | ||||
|         .to(change { user.reload.account.moved_to_account_id }.to(nil)) | ||||
|       expect(page) | ||||
|         .to have_content(I18n.t('migrations.cancelled_msg')) | ||||
|     end | ||||
| 
 | ||||
|     private | ||||
| 
 | ||||
|     def stub_resolver | ||||
|       resolver = instance_double(ResolveAccountService, call: Fabricate(:account)) | ||||
|       allow(ResolveAccountService).to receive(:new).and_return(resolver) | ||||
|     end | ||||
|   end | ||||
| end | ||||
		Loading…
	
		Reference in New Issue