1
0
Fork 0
mirror of https://github.com/varvet/pundit.git synced 2022-11-09 12:30:11 -05:00
varvet--pundit/spec/spec_helper.rb
Jonas Nicklas and Kim Burgestrand 56a8bdee5a Implement authorize class method separately
This is a little less DRY, but `Pundit.authorize` doesn't have to take an extra policy as an argument.

Conflicts:
	lib/pundit.rb
	spec/spec_helper.rb
2015-03-26 10:34:45 +01:00

110 lines
1.8 KiB
Ruby

require "pundit"
require "pundit/rspec"
require "pry"
require "active_support"
require "active_support/core_ext"
require "active_model/naming"
I18n.enforce_available_locales = false
module PunditSpecHelper
extend RSpec::Matchers::DSL
matcher :be_truthy do
match do |actual|
actual
end
end
end
RSpec.configure do |config|
config.include PunditSpecHelper
end
class PostPolicy < Struct.new(:user, :post)
def update?
post.user == user
end
def destroy?
false
end
def show?
true
end
end
class PostPolicy::Scope < Struct.new(:user, :scope)
def resolve
scope.published
end
end
class Post < Struct.new(:user)
def self.published
:published
end
end
class CommentPolicy < Struct.new(:user, :comment); end
class CommentPolicy::Scope < Struct.new(:user, :scope)
def resolve
scope
end
end
class Comment; extend ActiveModel::Naming; end
class Article; end
class BlogPolicy < Struct.new(:user, :blog); end
class Blog; end
class ArtificialBlog < Blog
def self.policy_class
BlogPolicy
end
end
class ArticleTag
def self.policy_class
Struct.new(:user, :tag) do
def show?
true
end
def destroy?
false
end
end
end
end
class DashboardPolicy < Struct.new(:user, :dashboard); end
module Project
class DashboardPolicy < Struct.new(:user, :dashboard); end
end
class DenierPolicy < Struct.new(:user, :record)
def update?
false
end
end
class Controller
include Pundit
attr_reader :current_user, :params
def initialize(current_user, params)
@current_user = current_user
@params = params
end
end
class NilClassPolicy
class Scope
def initialize(*)
raise "I'm only here to be annoying!"
end
end
def initialize(*)
raise "I'm only here to be annoying!"
end
end