test suite refactor

This commit is contained in:
Mark Moser 2016-09-14 17:05:37 -05:00
parent 9db007489f
commit 27ef8565f3
13 changed files with 127 additions and 135 deletions

View File

@ -56,7 +56,7 @@ guard 'livereload' do
end end
guard :minitest, spring: "bin/rails test", all_after_pass: true do guard :minitest, spring: "bin/rails test", all_after_pass: true do
watch(%r{^app/(.+)\.rb$}) { |m| "test/#{m[1]}_test.rb" } watch(%r{^app/(.+)\.rb$}) { |m| ["test/#{m[1]}", "test/#{m[1]}_test.rb"] }
watch(%r{^app/controllers/(admin|application)_controller\.rb$}) { 'test/controllers' } watch(%r{^app/controllers/(admin|application)_controller\.rb$}) { 'test/controllers' }
watch(%r{^app/controllers/(.+)_controller\.rb$}) { |m| "test/integration/#{m[1]}_test.rb" } watch(%r{^app/controllers/(.+)_controller\.rb$}) { |m| "test/integration/#{m[1]}_test.rb" }
watch(%r{^app/views/(.+)_mailer/.+}) { |m| "test/mailers/#{m[1]}_mailer_test.rb" } watch(%r{^app/views/(.+)_mailer/.+}) { |m| "test/mailers/#{m[1]}_mailer_test.rb" }

View File

@ -40,7 +40,6 @@ class QuizController < ApplicationController
ReviewerMailer.candidate_submission(current_candidate).deliver_later ReviewerMailer.candidate_submission(current_candidate).deliver_later
return true return true
end end
false
end end
def prep_question qid def prep_question qid

View File

@ -2,12 +2,6 @@
require 'test_helper' require 'test_helper'
class CandidateControllerTest < ActionDispatch::IntegrationTest class CandidateControllerTest < ActionDispatch::IntegrationTest
include ActiveJob::TestHelper
def setup_auth candidate
post validate_candidate_url, params: { test_id: candidate.test_hash }
end
test "should get login" do test "should get login" do
get login_path get login_path
assert_response :success assert_response :success
@ -23,7 +17,7 @@ class CandidateControllerTest < ActionDispatch::IntegrationTest
end end
test "should auth to welcome" do test "should auth to welcome" do
setup_auth candidates(:martha) auth_candidate candidates(:martha)
assert_redirected_to welcome_path assert_redirected_to welcome_path
assert session[:test_id].present? assert session[:test_id].present?
@ -39,56 +33,30 @@ class CandidateControllerTest < ActionDispatch::IntegrationTest
end end
test "should display welcome view" do test "should display welcome view" do
setup_auth candidates(:martha) auth_candidate candidates(:martha)
get welcome_path get welcome_path
assert_select '.prft-heading', "Welcome!" assert_select '.prft-heading', "Welcome!"
end end
test "should display welcome back view" do test "should display welcome back view" do
setup_auth candidates(:roy) auth_candidate candidates(:roy)
get welcome_path get welcome_path
assert_select '.prft-heading', "Welcome Back" assert_select '.prft-heading', "Welcome Back"
end end
test "should redirect to thankyou when completed" do test "should redirect to thankyou when completed" do
setup_auth candidates(:richard) auth_candidate candidates(:richard)
assert_redirected_to thankyou_path assert_redirected_to thankyou_path
end end
test 'should reset session' do test 'should reset session' do
setup_auth candidates(:dawn) auth_candidate candidates(:dawn)
get thankyou_path get thankyou_path
assert :success assert :success
assert session[:test_id].nil? assert session[:test_id].nil?
end end
test "should get summary if complete but not submitted" do
setup_auth candidates(:dawn)
get summary_url
assert_response :success
end
test "should NOT send mailers on submission" do
setup_auth candidates(:dawn)
assert_enqueued_jobs 0 do
post post_summary_path
end
assert_redirected_to summary_path
assert_match 'must complete', flash[:error]
end
test "should send mailers on submission" do
setup_auth candidates(:peggy)
assert_enqueued_jobs 3 do
post post_summary_path
end
assert_redirected_to thankyou_path
end
end end

View File

@ -0,0 +1,25 @@
# frozen_string_literal: true
require 'test_helper'
class QuizControllerTest < ActionDispatch::IntegrationTest
test "should require auth and redirect" do
get question_path
assert_redirected_to login_path
get question_path(questions(:fed1).id)
assert_redirected_to login_path
end
test "should redirect to next question on next" do
auth_candidate 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
end

View File

@ -2,23 +2,8 @@
require 'test_helper' require 'test_helper'
class QuizControllerTest < ActionDispatch::IntegrationTest 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
test "should redirect to saved on save" do test "should redirect to saved on save" do
setup_auth candidates(:dawn) auth_candidate candidates(:dawn)
qid = questions(:fed5).id qid = questions(:fed5).id
post post_answer_path, params: { save: 'Save', answer: { question_id: qid, answer: 'an option' } } post post_answer_path, params: { save: 'Save', answer: { question_id: qid, answer: 'an option' } }
@ -26,36 +11,8 @@ class QuizControllerTest < ActionDispatch::IntegrationTest
assert session[:test_id].present? assert session[:test_id].present?
end 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 test "should get flash message on bad radio response" do
setup_auth candidates(:dawn) auth_candidate candidates(:dawn)
qid = questions(:fed5).id qid = questions(:fed5).id
post post_answer_path, params: { answer: { question_id: qid, answer: nil } } post post_answer_path, params: { answer: { question_id: qid, answer: nil } }
@ -67,7 +24,7 @@ class QuizControllerTest < ActionDispatch::IntegrationTest
end end
test "should get flash message on bad text response" do test "should get flash message on bad text response" do
setup_auth candidates(:dawn) auth_candidate candidates(:dawn)
qid = questions(:fed4).id qid = questions(:fed4).id
post post_answer_path, params: { answer: { question_id: qid, answer: nil } } post post_answer_path, params: { answer: { question_id: qid, answer: nil } }
@ -79,7 +36,7 @@ class QuizControllerTest < ActionDispatch::IntegrationTest
end end
test "should process checkbox" do test "should process checkbox" do
setup_auth candidates(:dawn) auth_candidate candidates(:dawn)
qid = questions(:fed10).id qid = questions(:fed10).id
post post_answer_path, params: { answer: { question_id: qid, answer_array: 'an-option' } } post post_answer_path, params: { answer: { question_id: qid, answer_array: 'an-option' } }
@ -90,7 +47,7 @@ class QuizControllerTest < ActionDispatch::IntegrationTest
end end
test 'should handle XHR update and complete progress' do test 'should handle XHR update and complete progress' do
setup_auth candidates(:peggy) auth_candidate candidates(:peggy)
qid = questions(:fed10).id qid = questions(:fed10).id
post post_answer_path, xhr: true, params: { answer: { question_id: qid, answer_array: ['an-option'] } } post post_answer_path, xhr: true, params: { answer: { question_id: qid, answer_array: ['an-option'] } }
@ -102,7 +59,7 @@ class QuizControllerTest < ActionDispatch::IntegrationTest
end end
test 'should handle XHR fail' do test 'should handle XHR fail' do
setup_auth candidates(:peggy) auth_candidate candidates(:peggy)
qid = questions(:fed10).id qid = questions(:fed10).id
post post_answer_path, xhr: true, params: { answer: { question_id: qid, answer_array: [nil] } } post post_answer_path, xhr: true, params: { answer: { question_id: qid, answer_array: [nil] } }

View File

@ -0,0 +1,52 @@
# frozen_string_literal: true
require 'test_helper'
class QuizControllerTest < ActionDispatch::IntegrationTest
include ActiveJob::TestHelper
test 'summary should require auth and redirect' do
get summary_path
assert_redirected_to login_path
end
test "should get summary" do
auth_candidate candidates :dawn
get summary_path
assert_response :success
assert assigns(:quiz), '@quiz not present'
end
test "should get summary if complete but not submitted" do
auth_candidate candidates(:dawn)
get summary_url
assert_response :success
end
test "should redirect from summary" do
auth_candidate candidates :roy
get summary_path
assert_redirected_to question_path
end
test "should NOT send mailers on submission" do
auth_candidate candidates(:dawn)
assert_enqueued_jobs 0 do
post post_summary_path
end
assert_redirected_to summary_path
assert_match 'must complete', flash[:error]
end
test "should send mailers on submission" do
auth_candidate candidates(:peggy)
assert_enqueued_jobs 3 do
post post_summary_path
end
assert_redirected_to thankyou_path
end
end

View File

@ -4,18 +4,13 @@ require 'test_helper'
class RecruiterControllerTest < ActionDispatch::IntegrationTest class RecruiterControllerTest < ActionDispatch::IntegrationTest
include ActiveJob::TestHelper include ActiveJob::TestHelper
def setup_auth
post recruiter_auth_url, params: { auth:
{ email: 'pdr.recruiter@mailinator.com', password: 'password' } }
end
test "should get login" do test "should get login" do
get recruiter_login_url get recruiter_login_url
assert_response :success assert_response :success
end end
test 'should logout and reset session' do test 'should logout and reset session' do
setup_auth auth_recruiter
get recruiter_logout_path get recruiter_logout_path
assert :success assert :success
@ -34,7 +29,7 @@ class RecruiterControllerTest < ActionDispatch::IntegrationTest
end end
test "should auth to index" do test "should auth to index" do
setup_auth auth_recruiter
assert_redirected_to recruiter_path assert_redirected_to recruiter_path
assert session[:user].present? assert session[:user].present?
end end
@ -48,27 +43,27 @@ class RecruiterControllerTest < ActionDispatch::IntegrationTest
end end
test "should get candidate list" do test "should get candidate list" do
setup_auth auth_recruiter
get recruiter_url get recruiter_url
assert_response :success assert_response :success
assert assigns(:candidates), "@candidates not present" assert assigns(:candidates), "@candidates not present"
end end
test "should get new" do test "should get new" do
setup_auth auth_recruiter
get new_candidate_url get new_candidate_url
assert_response :success assert_response :success
assert assigns(:candidate), "@candidate not present" assert assigns(:candidate), "@candidate not present"
end end
test "should get create" do test "should get create" do
setup_auth auth_recruiter
get create_candidate_url get create_candidate_url
assert_response :success assert_response :success
end end
test "should create new candidate" do test "should create new candidate" do
setup_auth auth_recruiter
assert_enqueued_jobs 2 do assert_enqueued_jobs 2 do
assert_difference("Candidate.count") do assert_difference("Candidate.count") do
@ -81,7 +76,7 @@ class RecruiterControllerTest < ActionDispatch::IntegrationTest
end end
test "should fail creation with improper email format" do test "should fail creation with improper email format" do
setup_auth auth_recruiter
assert_enqueued_jobs 0 do assert_enqueued_jobs 0 do
assert_difference("Candidate.count", 0) do assert_difference("Candidate.count", 0) do
@ -95,7 +90,7 @@ class RecruiterControllerTest < ActionDispatch::IntegrationTest
end end
test "should fail creation gracefully with empty email" do test "should fail creation gracefully with empty email" do
setup_auth auth_recruiter
assert_enqueued_jobs 0 do assert_enqueued_jobs 0 do
assert_difference("Candidate.count", 0) do assert_difference("Candidate.count", 0) do

View File

@ -2,11 +2,6 @@
require 'test_helper' require 'test_helper'
class ReviewControllerTest < ActionDispatch::IntegrationTest class ReviewControllerTest < ActionDispatch::IntegrationTest
def setup_auth
post review_auth_url, params: { auth:
{ email: 'fed.reviewer@mailinator.com', password: 'password' } }
end
test "should get login" do test "should get login" do
get review_login_url get review_login_url
assert_response :success assert_response :success
@ -21,7 +16,7 @@ class ReviewControllerTest < ActionDispatch::IntegrationTest
end end
test "should auth to index" do test "should auth to index" do
setup_auth auth_reviewer
assert_redirected_to review_path assert_redirected_to review_path
assert session[:user].present? assert session[:user].present?
end end
@ -35,21 +30,21 @@ class ReviewControllerTest < ActionDispatch::IntegrationTest
end end
test "should get review list" do test "should get review list" do
setup_auth auth_reviewer
get review_url get review_url
assert_response :success assert_response :success
assert assigns(:candidates), '@candidates not present' assert assigns(:candidates), '@candidates not present'
end end
test "should get index" do test "should get index" do
setup_auth auth_reviewer
get review_url get review_url
assert_response :success assert_response :success
end end
test "should get view" do test "should get view" do
setup_auth auth_reviewer
get review_test_url(candidates(:richard).test_hash) get review_test_url(candidates(:richard).test_hash)
assert_response :success assert_response :success
@ -59,7 +54,7 @@ class ReviewControllerTest < ActionDispatch::IntegrationTest
end end
test 'should logout and reset session' do test 'should logout and reset session' do
setup_auth auth_reviewer
get review_logout_path get review_logout_path
assert :success assert :success

View File

@ -2,12 +2,8 @@
require 'test_helper' require 'test_helper'
class QuestionAttachmentsTest < ActionDispatch::IntegrationTest class QuestionAttachmentsTest < ActionDispatch::IntegrationTest
def setup_auth candidate
post validate_candidate_url, params: { test_id: candidate.test_hash }
end
test "should show attachments on question" do test "should show attachments on question" do
setup_auth candidates(:dawn) auth_candidate candidates(:dawn)
get question_path questions(:fed6) get question_path questions(:fed6)
assert_response :success assert_response :success
@ -16,7 +12,7 @@ class QuestionAttachmentsTest < ActionDispatch::IntegrationTest
end end
test "should show attachments on summary" do test "should show attachments on summary" do
setup_auth candidates(:dawn) auth_candidate candidates(:dawn)
get summary_path get summary_path
assert_response :success assert_response :success

View File

@ -2,12 +2,8 @@
require 'test_helper' require 'test_helper'
class QuestionFlowTest < ActionDispatch::IntegrationTest class QuestionFlowTest < ActionDispatch::IntegrationTest
def setup_auth candidate
post validate_candidate_url, params: { test_id: candidate.test_hash }
end
test "should load the first question" do test "should load the first question" do
setup_auth candidates(:martha) auth_candidate candidates(:martha)
get question_path get question_path
assert_response :success assert_response :success
@ -15,7 +11,7 @@ class QuestionFlowTest < ActionDispatch::IntegrationTest
end end
test "should load the summary" do test "should load the summary" do
setup_auth candidates(:dawn) auth_candidate candidates(:dawn)
get summary_path get summary_path
assert_response :success assert_response :success
@ -23,18 +19,16 @@ class QuestionFlowTest < ActionDispatch::IntegrationTest
end end
test "can load specific question from summary" do test "can load specific question from summary" do
setup_auth candidates(:dawn) auth_candidate candidates(:dawn)
question = questions(:fed4) question = questions(:fed4)
get question_path(question.id) get question_path(question.id)
assert_response :success assert_response :success
assert_select '.question-text', question.question assert_select '.question-text', question.question
# TODO: add in capybara and test form post
# assert_redirected summary_path
end end
test 'juan should be on summary with 80% complete' do test 'juan should be on summary with 80% complete' do
setup_auth candidates(:juan) auth_candidate candidates(:juan)
get summary_path get summary_path
assert_response :success assert_response :success

View File

@ -2,23 +2,17 @@
require 'test_helper' require 'test_helper'
class QuestionLiveCoderTest < ActionDispatch::IntegrationTest class QuestionLiveCoderTest < ActionDispatch::IntegrationTest
def setup_auth candidate
post validate_candidate_url, params: { test_id: candidate.test_hash }
end
test "can load a live coder question" do test "can load a live coder question" do
setup_auth candidates(:dawn) auth_candidate candidates(:dawn)
question = questions(:fed7) question = questions(:fed7)
get question_path(question.id) get question_path(question.id)
assert_response :success assert_response :success
assert_select '.question-text', question.question assert_select '.question-text', question.question
# TODO: add in capybara and test form post
# assert_redirected summary_path
end end
test "should load seed data into live coder" do test "should load seed data into live coder" do
setup_auth candidates(:juan) auth_candidate candidates(:juan)
question = questions(:fed7) question = questions(:fed7)
get question_path(question.id) get question_path(question.id)

View File

@ -24,4 +24,5 @@ class ActiveSupport::TestCase
fixtures :all fixtures :all
# Add more helper methods to be used by all tests here... # Add more helper methods to be used by all tests here...
include AuthTestHelper
end end

View File

@ -0,0 +1,16 @@
# frozen_string_literal: true
module AuthTestHelper
def auth_candidate candidate
post validate_candidate_url, params: { test_id: candidate.test_hash }
end
def auth_recruiter
post recruiter_auth_url, params: { auth:
{ email: 'pdr.recruiter@mailinator.com', password: 'password' } }
end
def auth_reviewer
post review_auth_url, params: { auth:
{ email: 'fed.reviewer@mailinator.com', password: 'password' } }
end
end