Reformat spec/requests/maintenance_spec.rb
This commit is contained in:
		
							parent
							
								
									9d2ee08958
								
							
						
					
					
						commit
						16933dde08
					
				
					 1 changed files with 99 additions and 77 deletions
				
			
		|  | @ -4,7 +4,8 @@ | |||
| # Full license explanation at https://github.com/houdiniproject/houdini/blob/master/LICENSE | ||||
| require 'rails_helper' | ||||
| require 'controllers/support/shared_user_context' | ||||
| 
 | ||||
| # rubocop:disable RSpec/InstanceVariable | ||||
| # rubocop:disable RSpec/DescribeClass | ||||
| describe 'Maintenance Mode' do | ||||
| 	page = 'http://commet' | ||||
| 	token = 'thoathioa' | ||||
|  | @ -18,7 +19,7 @@ describe 'Maintenance Mode' do | |||
| 		end | ||||
| 
 | ||||
| 		describe 'in maintenance' do | ||||
|       before(:each) do | ||||
| 			before do | ||||
| 				Houdini.maintenance = Houdini::Maintenance.new(active: true, token: token, page: page) | ||||
| 			end | ||||
| 
 | ||||
|  | @ -36,64 +37,85 @@ describe 'Maintenance Mode' do | |||
| 	end | ||||
| 
 | ||||
| 	describe Users::SessionsController, type: :controller do | ||||
|     after(:each) do | ||||
| 		after do | ||||
| 			Houdini.maintenance.active = false | ||||
| 		end | ||||
| 
 | ||||
| 		describe 'in maintenance' do | ||||
| 			include_context :shared_user_context | ||||
| 
 | ||||
|       before(:each) do | ||||
| 			before do | ||||
| 				@request.env['devise.mapping'] = Devise.mappings[:user] | ||||
| 			end | ||||
| 
 | ||||
| 			describe 'in maintenance' do | ||||
|         before(:each) do | ||||
| 				before do | ||||
| 					Houdini.maintenance = Houdini::Maintenance.new(active: true, token: token, page: page) | ||||
| 				end | ||||
| 
 | ||||
|         it 'redirects sign_in if the token is wrong' do | ||||
| 				describe 'redirects sign_in if the token is wrong' do | ||||
| 					subject do | ||||
| 						get(:new, params: { maintenance_token: "#{token}3" }) | ||||
|           expect(response.code).to eq '302' | ||||
|           expect(response.location).to eq page | ||||
| 						response | ||||
| 					end | ||||
| 
 | ||||
|         it 'redirects for login' do | ||||
| 					it { is_expected.to have_attributes(code: '302', location: page) } | ||||
| 				end | ||||
| 
 | ||||
| 				describe 'redirects to sign_in' do | ||||
| 					subject do | ||||
| 						get(:new) | ||||
|           expect(response.code).to eq '302' | ||||
|           expect(response.location).to eq page | ||||
| 						response | ||||
| 					end | ||||
| 
 | ||||
|         it 'redirects sign_in if the token is passed in wrong param' do | ||||
| 					it { is_expected.to have_attributes(code: '302', location: page) } | ||||
| 				end | ||||
| 
 | ||||
| 				describe 'redirects to sign_in if token passed on wrong param' do | ||||
| 					subject do | ||||
| 						get(:new, params: { maintnancerwrwer_token: token.to_s }) | ||||
|           expect(response.code).to eq '302' | ||||
|           expect(response.location).to eq page | ||||
| 						response | ||||
| 					end | ||||
| 
 | ||||
|         it 'allows sign_in if the token is passed' do | ||||
| 					it { is_expected.to have_attributes(code: '302', location: page) } | ||||
| 				end | ||||
| 
 | ||||
| 				describe 'allows sign_in if the token is passed' do | ||||
| 					subject do | ||||
| 						get(:new, params: { maintenance_token: token.to_s }) | ||||
|           expect(response.code).to eq '200' | ||||
| 						response | ||||
| 					end | ||||
| 
 | ||||
|         it 'allows sign_in.json' do | ||||
| 					it { is_expected.to have_attributes(code: '200') } | ||||
| 				end | ||||
| 
 | ||||
| 				describe 'allows sign_in.json if the token is passed' do | ||||
| 					subject do | ||||
| 						get(:new, params: { maintenance_token: token.to_s, format: 'json' }) | ||||
|           expect(response.code).to eq '200' | ||||
| 						response | ||||
| 					end | ||||
| 
 | ||||
| 					it { is_expected.to have_attributes(code: '200') } | ||||
| 				end | ||||
| 			end | ||||
| 		end | ||||
| 
 | ||||
| 		describe 'in maintenance without maintenance_token set' do | ||||
|       before(:each) do | ||||
| 			before do | ||||
| 				@request.env['devise.mapping'] = Devise.mappings[:user] | ||||
|       end | ||||
|       before(:each) do | ||||
| 				Houdini.maintenance = Houdini::Maintenance.new(active: true, token: nil, page: page) | ||||
| 			end | ||||
| 
 | ||||
|       it 'redirects sign_in if the token is nil' do | ||||
| 			describe 'redirects sign_in if the token is nil' do | ||||
| 				subject do | ||||
| 					get(:new) | ||||
|         expect(response.code).to eq '302' | ||||
|         expect(response.location).to eq page | ||||
| 					response | ||||
| 				end | ||||
| 
 | ||||
| 				it { is_expected.to have_attributes(code: '302', location: page) } | ||||
| 			end | ||||
| 		end | ||||
| 	end | ||||
| end | ||||
| 
 | ||||
| # rubocop:enable all | ||||
|  |  | |||
		Loading…
	
	Add table
		
		Reference in a new issue
	
	 Eric Schultz
						Eric Schultz