FIX: Prevent duplicate flags after undoing on the server side too.
This commit is contained in:
parent
a71640c15f
commit
1e281a909e
|
@ -7,7 +7,8 @@ class PostActionsController < ApplicationController
|
||||||
before_filter :fetch_post_action_type_id_from_params
|
before_filter :fetch_post_action_type_id_from_params
|
||||||
|
|
||||||
def create
|
def create
|
||||||
guardian.ensure_post_can_act!(@post, PostActionType.types[@post_action_type_id])
|
taken = PostAction.counts_for([@post], current_user)[@post.id]
|
||||||
|
guardian.ensure_post_can_act!(@post, PostActionType.types[@post_action_type_id], taken_actions: taken)
|
||||||
|
|
||||||
args = {}
|
args = {}
|
||||||
args[:message] = params[:message] if params[:message].present?
|
args[:message] = params[:message] if params[:message].present?
|
||||||
|
|
|
@ -28,7 +28,7 @@ describe PostActionsController do
|
||||||
end
|
end
|
||||||
|
|
||||||
it "fails when the user doesn't have permission to perform that action" do
|
it "fails when the user doesn't have permission to perform that action" do
|
||||||
Guardian.any_instance.expects(:post_can_act?).with(@post, :like).returns(false)
|
Guardian.any_instance.expects(:post_can_act?).with(@post, :like, taken_actions: nil).returns(false)
|
||||||
xhr :post, :create, id: @post.id, post_action_type_id: PostActionType.types[:like]
|
xhr :post, :create, id: @post.id, post_action_type_id: PostActionType.types[:like]
|
||||||
response.should be_forbidden
|
response.should be_forbidden
|
||||||
end
|
end
|
||||||
|
@ -38,6 +38,12 @@ describe PostActionsController do
|
||||||
xhr :post, :create, id: @post.id, post_action_type_id: PostActionType.types[:like]
|
xhr :post, :create, id: @post.id, post_action_type_id: PostActionType.types[:like]
|
||||||
end
|
end
|
||||||
|
|
||||||
|
it "passes a list of taken actions through" do
|
||||||
|
PostAction.create(post_id: @post.id, user_id: @user.id, post_action_type_id: PostActionType.types[:inappropriate])
|
||||||
|
Guardian.any_instance.expects(:post_can_act?).with(@post, :off_topic, has_entry({:taken_actions => has_key(PostActionType.types[:inappropriate])}))
|
||||||
|
xhr :post, :create, id: @post.id, post_action_type_id: PostActionType.types[:off_topic]
|
||||||
|
end
|
||||||
|
|
||||||
it 'passes the message through' do
|
it 'passes the message through' do
|
||||||
PostAction.expects(:act).once.with(@user, @post, PostActionType.types[:like], {message: 'action message goes here'})
|
PostAction.expects(:act).once.with(@user, @post, PostActionType.types[:like], {message: 'action message goes here'})
|
||||||
xhr :post, :create, id: @post.id, post_action_type_id: PostActionType.types[:like], message: 'action message goes here'
|
xhr :post, :create, id: @post.id, post_action_type_id: PostActionType.types[:like], message: 'action message goes here'
|
||||||
|
|
Loading…
Reference in New Issue