Adding the .ruby-verison file triggered previously un-run cops, specifically: This cop is designed to help upgrade to Ruby 3.0. It will add the comment `# frozen_string_literal: true` to the top of files to enable frozen string literals. Frozen string literals will be default in Ruby 3.0. The comment will be added below a shebang and encoding comment. The frozen string literal comment is only valid in Ruby 2.3+. More info on rubocop [Automatic-Corrections](https://github.com/bbatsov/rubocop/wiki/Automatic-Corrections)
		
			
				
	
	
		
			120 lines
		
	
	
		
			3.8 KiB
		
	
	
	
		
			Ruby
		
	
	
	
	
	
			
		
		
	
	
			120 lines
		
	
	
		
			3.8 KiB
		
	
	
	
		
			Ruby
		
	
	
	
	
	
| # frozen_string_literal: true
 | |
| require 'test_helper'
 | |
| 
 | |
| class QuizControllerTest < ActionDispatch::IntegrationTest
 | |
|   def setup_auth candidate
 | |
|     post validate_candidate_url, params: { test_id: candidate.test_hash }
 | |
|   end
 | |
| 
 | |
|   test "should require auth and redirect" do
 | |
|     get summary_path
 | |
|     assert_redirected_to login_path
 | |
| 
 | |
|     get question_path
 | |
|     assert_redirected_to login_path
 | |
| 
 | |
|     get question_path(questions(:fed1).id)
 | |
|     assert_redirected_to login_path
 | |
|   end
 | |
| 
 | |
|   # TODO: test models/candidate.complete! == false
 | |
|   # test 'should gracefully fail on summary submit' do
 | |
|   #   # if the mailers fail, should go to thank you still
 | |
|   # end
 | |
| 
 | |
|   test "should redirect to saved on save" do
 | |
|     setup_auth candidates(:dawn)
 | |
|     qid = questions(:fed5).id
 | |
|     post post_answer_path, params: { save: 'Save', answer: { question_id: qid, answer: 'an option' } }
 | |
| 
 | |
|     assert_redirected_to saved_path
 | |
|     assert session[:test_id].present?
 | |
|   end
 | |
| 
 | |
|   test "should redirect to next question on next" do
 | |
|     setup_auth candidates(:roy)
 | |
|     qid = questions(:fed3).id
 | |
|     params = { submit: 'Next', answer: { question_id: qid, answer_hash: { text: 'stuff' } } }
 | |
|     post post_answer_path, params: params
 | |
| 
 | |
|     assert_redirected_to question_path
 | |
|     assert session[:test_id].present?
 | |
|     assert assigns(:question), '@question not present'
 | |
|     assert assigns(:answer), '@answer not present'
 | |
|     assert assigns(:status), '@status not present'
 | |
|   end
 | |
| 
 | |
|   test "should get summary" do
 | |
|     setup_auth candidates :dawn
 | |
|     get summary_path
 | |
| 
 | |
|     assert_response :success
 | |
|     assert assigns(:quiz), '@quiz not present'
 | |
|   end
 | |
| 
 | |
|   test "should redirect from summary" do
 | |
|     setup_auth candidates :roy
 | |
|     get summary_path
 | |
| 
 | |
|     assert_redirected_to question_path
 | |
|   end
 | |
| 
 | |
|   test "should get flash message on bad radio response" do
 | |
|     setup_auth candidates(:dawn)
 | |
|     qid = questions(:fed5).id
 | |
|     post post_answer_path, params: { answer: { question_id: qid, answer: nil } }
 | |
| 
 | |
|     assert_response :success
 | |
|     assert session[:test_id].present?
 | |
|     assert_equal qid, flash[:error]
 | |
|     assert assigns(:question), '@question not present'
 | |
|     assert assigns(:answer), '@answer not present'
 | |
|   end
 | |
| 
 | |
|   test "should get flash message on bad text response" do
 | |
|     setup_auth candidates(:dawn)
 | |
|     qid = questions(:fed4).id
 | |
|     post post_answer_path, params: { answer: { question_id: qid, answer: nil } }
 | |
| 
 | |
|     assert_response :success
 | |
|     assert session[:test_id].present?
 | |
|     assert_equal qid, flash[:error]
 | |
|     assert assigns(:question), '@question not present'
 | |
|     assert assigns(:answer), '@answer not present'
 | |
|   end
 | |
| 
 | |
|   test "should process checkbox" do
 | |
|     setup_auth candidates(:dawn)
 | |
|     qid = questions(:fed10).id
 | |
|     post post_answer_path, params: { answer: { question_id: qid, answer_array: 'an-option' } }
 | |
| 
 | |
|     assert_response :success
 | |
|     assert session[:test_id].present?
 | |
|     assert assigns(:question), '@question not present'
 | |
|     assert assigns(:answer), '@answer not present'
 | |
|   end
 | |
| 
 | |
|   test 'should handle XHR update and complete progress' do
 | |
|     setup_auth candidates(:peggy)
 | |
|     qid = questions(:fed10).id
 | |
|     post post_answer_path, xhr: true, params: { answer: { question_id: qid, answer_array: ['an-option'] } }
 | |
| 
 | |
|     assert_response :success
 | |
|     assert_match(/updated successfully/, JSON.parse(@response.body)['message'])
 | |
|     assert_equal 100, JSON.parse(@response.body)['progress']
 | |
|     assert assigns(:question), '@question not present'
 | |
|     assert assigns(:answer), '@answer not present'
 | |
|   end
 | |
| 
 | |
|   test 'should handle XHR fail' do
 | |
|     setup_auth candidates(:peggy)
 | |
|     qid = questions(:fed10).id
 | |
|     post post_answer_path, xhr: true, params: { answer: { question_id: qid, answer_array: [nil] } }
 | |
| 
 | |
|     assert_response 400
 | |
|     assert_match(/select.*answer/i, JSON.parse(@response.body).join)
 | |
|     assert assigns(:question), '@question not present'
 | |
|     assert assigns(:answer), '@answer not present'
 | |
|   end
 | |
| end
 |