2016-09-22 13:30:30 -05:00

51 lines
1.5 KiB
Ruby

# frozen_string_literal: true
require 'test_helper'
class QuestionPolicyTest < PolicyAssertions::Test
test 'should require current_user' do
assert_raise Pundit::NotAuthorizedError do
QuestionPolicy.new(nil, Question.first).view?
end
end
test 'should allow admin to scope' do
scope = QuestionPolicy::Scope.new(users(:admin), Question).resolve
assert_equal Question.count, scope.count
end
test 'should allow manager to scope' do
scope = QuestionPolicy::Scope.new(users(:manager), Question).resolve
assert_equal Question.count, scope.count
end
test 'should allow reviewer to scope' do
quiz_ids = users(:reviewer).quizzes.map(&:id)
scope = QuestionPolicy::Scope.new(users(:reviewer), Question).resolve
assert_equal Question.where(quiz_id: quiz_ids).count, scope.count
end
test 'should NOT allow recruiter to scope' do
assert_raise Pundit::NotAuthorizedError do
QuestionPolicy::Scope.new(users(:recruiter), Question).resolve
end
end
def test_view_and_options
assert_permit users(:admin), questions(:fed1)
assert_permit users(:manager), questions(:fed1)
assert_permit users(:reviewer), questions(:fed1)
refute_permit users(:reviewer), questions(:admin1)
refute_permit users(:recruiter), questions(:fed1)
end
def test_create_and_update
assert_permit users(:admin), Question
assert_permit users(:manager), Question
refute_permit users(:recruiter), Question
refute_permit users(:reviewer), Question
end
end