1
0
Fork 0
mirror of https://github.com/varvet/pundit.git synced 2022-11-09 12:30:11 -05:00
varvet--pundit/lib/pundit/rspec.rb

79 lines
2.6 KiB
Ruby
Raw Normal View History

require "active_support/core_ext/array/conversions"
2012-11-19 10:57:17 +01:00
module Pundit
module RSpec
module Matchers
extend ::RSpec::Matchers::DSL
matcher :permit do |user, record|
2014-06-27 22:39:59 +02:00
match_proc = lambda do |policy|
@violating_permissions = permissions.find_all { |permission| not policy.new(user, record).public_send(permission) }
@violating_permissions.empty?
end
2014-06-27 22:39:59 +02:00
match_when_negated_proc = lambda do |policy|
@violating_permissions = permissions.find_all { |permission| policy.new(user, record).public_send(permission) }
@violating_permissions.empty?
2012-11-19 10:57:17 +01:00
end
2014-06-27 22:39:59 +02:00
failure_message_proc = lambda do |policy|
was_were = @violating_permissions.count > 1 ? "were" : "was"
"Expected #{policy} to grant #{permissions.to_sentence} on #{record} but #{@violating_permissions.to_sentence} #{was_were} not granted"
2012-11-19 10:57:17 +01:00
end
2014-06-27 22:39:59 +02:00
failure_message_when_negated_proc = lambda do |policy|
was_were = @violating_permissions.count > 1 ? "were" : "was"
"Expected #{policy} not to grant #{permissions.to_sentence} on #{record} but #{@violating_permissions.to_sentence} #{was_were} granted"
2012-11-19 10:57:17 +01:00
end
2014-06-27 22:39:59 +02:00
if respond_to?(:match_when_negated)
match(&match_proc)
match_when_negated(&match_when_negated_proc)
failure_message(&failure_message_proc)
failure_message_when_negated(&failure_message_when_negated_proc)
else
match_for_should(&match_proc)
match_for_should_not(&match_when_negated_proc)
failure_message_for_should(&failure_message_proc)
failure_message_for_should_not(&failure_message_when_negated_proc)
end
2012-11-19 10:57:17 +01:00
def permissions
current_example = ::RSpec.respond_to?(:current_example) ? ::RSpec.current_example : example
current_example.metadata[:permissions]
2012-11-19 10:57:17 +01:00
end
end
end
module DSL
def permissions(*list, &block)
describe(list.to_sentence, :permissions => list, :caller => caller) { instance_eval(&block) }
end
end
module PolicyExampleGroup
include Pundit::RSpec::Matchers
def self.included(base)
base.metadata[:type] = :policy
base.extend Pundit::RSpec::DSL
super
end
end
end
end
RSpec.configure do |config|
if RSpec::Core::Version::STRING.split(".").first.to_i >= 3
config.include(Pundit::RSpec::PolicyExampleGroup, {
:type => :policy,
:file_path => /spec\/policies/,
})
else
config.include(Pundit::RSpec::PolicyExampleGroup, {
:type => :policy,
:example_group => { :file_path => /spec\/policies/ }
})
end
2012-11-19 10:57:17 +01:00
end