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|
|
2012-11-19 10:57:17 +01:00
|
|
|
permissions.all? { |permission| policy.new(user, record).public_send(permission) }
|
2014-01-17 14:31:53 +01:00
|
|
|
end
|
|
|
|
|
2014-06-27 22:39:59 +02:00
|
|
|
match_when_negated_proc = lambda do |policy|
|
2014-01-17 14:31:53 +01:00
|
|
|
permissions.none? { |permission| policy.new(user, record).public_send(permission) }
|
2012-11-19 10:57:17 +01:00
|
|
|
end
|
|
|
|
|
2014-06-27 22:39:59 +02:00
|
|
|
failure_message_proc = lambda do |policy|
|
2012-11-19 10:57:17 +01:00
|
|
|
"Expected #{policy} to grant #{permissions.to_sentence} on #{record} but it didn't"
|
|
|
|
end
|
|
|
|
|
2014-06-27 22:39:59 +02:00
|
|
|
failure_message_when_negated_proc = lambda do |policy|
|
2012-11-19 10:57:17 +01:00
|
|
|
"Expected #{policy} not to grant #{permissions.to_sentence} on #{record} but it did"
|
|
|
|
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
|
2014-03-13 15:19:43 -04:00
|
|
|
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|
|
|
|
|
config.include Pundit::RSpec::PolicyExampleGroup, :type => :policy, :example_group => {
|
|
|
|
:file_path => /spec\/policies/
|
|
|
|
}
|
|
|
|
end
|