spec/pundit_spec.rb in pundit-0.3.0 vs spec/pundit_spec.rb in pundit-1.0.0

- old
+ new

@@ -6,23 +6,56 @@ let(:comment) { Comment.new } let(:article) { Article.new } let(:controller) { Controller.new(user, { :action => 'update' }) } let(:artificial_blog) { ArtificialBlog.new } let(:article_tag) { ArticleTag.new } + let(:comments_relation) { CommentsRelation.new } + let(:empty_comments_relation) { CommentsRelation.new(true) } + describe ".authorize" do + it "infers the policy and authorizes based on it" do + expect(Pundit.authorize(user, post, :update?)).to be_truthy + end + + it "works with anonymous class policies" do + expect(Pundit.authorize(user, article_tag, :show?)).to be_truthy + expect { Pundit.authorize(user, article_tag, :destroy?) }.to raise_error(Pundit::NotAuthorizedError) + end + + it "raises an error with a query and action" do + expect { Pundit.authorize(user, post, :destroy?) }.to raise_error(Pundit::NotAuthorizedError, "not allowed to destroy? this #<Post>") do |error| + expect(error.query).to eq :destroy? + expect(error.record).to eq post + expect(error.policy).to eq Pundit.policy(user, post) + end + end + end + describe ".policy_scope" do it "returns an instantiated policy scope given a plain model class" do expect(Pundit.policy_scope(user, Post)).to eq :published end it "returns an instantiated policy scope given an active model class" do expect(Pundit.policy_scope(user, Comment)).to eq Comment end + it "returns an instantiated policy scope given an active record relation" do + expect(Pundit.policy_scope(user, comments_relation)).to eq comments_relation + end + + it "returns an instantiated policy scope given an empty active record relation" do + expect(Pundit.policy_scope(user, empty_comments_relation)).to eq empty_comments_relation + end + it "returns nil if the given policy scope can't be found" do expect(Pundit.policy_scope(user, Article)).to be_nil end + + it "returns nil if blank object given" do + expect(Pundit.policy_scope(user, nil)).to be_nil + end end describe ".policy_scope!" do it "returns an instantiated policy scope given a plain model class" do expect(Pundit.policy_scope!(user, Post)).to eq :published @@ -37,10 +70,14 @@ end it "throws an exception if the given policy scope can't be found" do expect { Pundit.policy_scope!(user, ArticleTag) }.to raise_error(Pundit::NotDefinedError) end + + it "throws an exception if the given policy scope is nil" do + expect { Pundit.policy_scope!(user, nil) }.to raise_error(Pundit::NotDefinedError, "unable to find policy scope of nil") + end end describe ".policy" do it "returns an instantiated policy given a plain model instance" do policy = Pundit.policy(user, post) @@ -69,10 +106,14 @@ it "returns nil if the given policy can't be found" do expect(Pundit.policy(user, article)).to be_nil expect(Pundit.policy(user, Article)).to be_nil end + it "returns nil if the given policy is nil" do + expect(Pundit.policy(user, nil)).to be_nil + end + describe "with .policy_class set on the model" do it "returns an instantiated policy given a plain model instance" do policy = Pundit.policy(user, artificial_blog) expect(policy.user).to eq user expect(policy.blog).to eq artificial_blog @@ -100,10 +141,17 @@ policy = Pundit.policy(user, :dashboard) expect(policy.class).to eq DashboardPolicy expect(policy.user).to eq user expect(policy.dashboard).to eq :dashboard end + + it "returns an instantiated policy given an array" do + policy = Pundit.policy(user, [:project, :dashboard]) + expect(policy.class).to eq Project::DashboardPolicy + expect(policy.user).to eq user + expect(policy.dashboard).to eq [:project, :dashboard] + end end end describe ".policy!" do it "returns an instantiated policy given a plain model instance" do @@ -135,14 +183,25 @@ expect(policy.class).to eq DashboardPolicy expect(policy.user).to eq user expect(policy.dashboard).to eq :dashboard end + it "returns an instantiated policy given an array" do + policy = Pundit.policy!(user, [:project, :dashboard]) + expect(policy.class).to eq Project::DashboardPolicy + expect(policy.user).to eq user + expect(policy.dashboard).to eq [:project, :dashboard] + end + it "throws an exception if the given policy can't be found" do expect { Pundit.policy!(user, article) }.to raise_error(Pundit::NotDefinedError) expect { Pundit.policy!(user, Article) }.to raise_error(Pundit::NotDefinedError) end + + it "throws an exception if the given policy is nil" do + expect { Pundit.policy!(user, nil) }.to raise_error(Pundit::NotDefinedError, "unable to find policy of nil") + end end describe "#verify_authorized" do it "does nothing when authorized" do controller.authorize(post) @@ -163,12 +222,34 @@ it "raises an exception when policy_scope is not used" do expect { controller.verify_policy_scoped }.to raise_error(Pundit::PolicyScopingNotPerformedError) end end + describe "#pundit_policy_authorized?" do + it "is true when authorized" do + controller.authorize(post) + expect(controller.pundit_policy_authorized?).to be true + end + + it "is false when not authorized" do + expect(controller.pundit_policy_authorized?).to be false + end + end + + describe "#pundit_policy_scoped?" do + it "is true when policy_scope is used" do + controller.policy_scope(Post) + expect(controller.pundit_policy_scoped?).to be true + end + + it "is false when policy scope is not used" do + expect(controller.pundit_policy_scoped?).to be false + end + end + describe "#authorize" do - it "infers the policy name and authorized based on it" do + it "infers the policy name and authorizes based on it" do expect(controller.authorize(post)).to be_truthy end it "can be given a different permission to check" do expect(controller.authorize(post, :show?)).to be_truthy @@ -178,30 +259,50 @@ it "works with anonymous class policies" do expect(controller.authorize(article_tag, :show?)).to be_truthy expect { controller.authorize(article_tag, :destroy?) }.to raise_error(Pundit::NotAuthorizedError) end - it "raises an error when the permission check fails" do + it "throws an exception when the permission check fails" do expect { controller.authorize(Post.new) }.to raise_error(Pundit::NotAuthorizedError) end - it "raises an error with a query and action" do - expect { controller.authorize(post, :destroy?) }.to raise_error do |error| - expect(error.query).to eq :destroy? - expect(error.record).to eq post - expect(error.policy).to eq controller.policy(post) - end + it "throws an exception when a policy cannot be found" do + expect { controller.authorize(Article) }.to raise_error(Pundit::NotDefinedError) end + + it "caches the policy" do + expect(controller.policies[post]).to be_nil + controller.authorize(post) + expect(controller.policies[post]).not_to be_nil + end + + it "raises an error when the given record is nil" do + expect { controller.authorize(nil, :destroy?) }.to raise_error(Pundit::NotDefinedError) + end end + describe "#skip_authorization" do + it "disables authorization verification" do + controller.skip_authorization + expect { controller.verify_authorized }.not_to raise_error + end + end + + describe "#skip_policy_scope" do + it "disables policy scope verification" do + controller.skip_policy_scope + expect { controller.verify_policy_scoped }.not_to raise_error + end + end + describe "#pundit_user" do it 'returns the same thing as current_user' do expect(controller.pundit_user).to eq controller.current_user end end - describe ".policy" do + describe "#policy" do it "returns an instantiated policy" do policy = controller.policy(post) expect(policy.user).to eq user expect(policy.post).to eq post end @@ -210,28 +311,37 @@ expect { controller.policy(article) }.to raise_error(Pundit::NotDefinedError) end it "allows policy to be injected" do new_policy = OpenStruct.new - controller.policy = new_policy + controller.policies[post] = new_policy expect(controller.policy(post)).to eq new_policy end end - describe ".policy_scope" do + describe "#policy_scope" do it "returns an instantiated policy scope" do expect(controller.policy_scope(Post)).to eq :published end it "throws an exception if the given policy can't be found" do expect { controller.policy_scope(Article) }.to raise_error(Pundit::NotDefinedError) end it "allows policy_scope to be injected" do new_scope = OpenStruct.new - controller.policy_scope = new_scope + controller.policy_scopes[Post] = new_scope - expect(controller.policy_scope(post)).to eq new_scope + expect(controller.policy_scope(Post)).to eq new_scope + end + end + + describe "#permitted_attributes" do + it "checks policy for permitted attributes" do + params = ActionController::Parameters.new({ action: 'update', post: { title: 'Hello', votes: 5, admin: true } }) + + expect(Controller.new(user, params).permitted_attributes(post)).to eq({ 'title' => 'Hello', 'votes' => 5 }) + expect(Controller.new(double, params).permitted_attributes(post)).to eq({ 'votes' => 5 }) end end end