mirror of
https://github.com/discourse/discourse.git
synced 2025-01-06 02:33:43 +08:00
bddffa7f9a
All flags should end up in one of the three dispositions - Agree - Disagree - Defer In the administration area, the *active* flags section displays 4 buttons - Agree (hide post + send PM) - Disagree - Defer - Delete Clicking "Delete" will open a modal that offer to - Delete Post & Defer Flags - Delete Post & Agree with Flags - Delete Spammer (if available) When the flag has a list associated, the list will now display 1 response and 1 reply and a "show more..." link if there are more in the conversation. Replying to the conversation will NOT give a disposition. Moderators must click the buttons that does that. If someone clicks one buttons, this will add a default moderator message from that moderator saying what happened. The *old* flags section now displays the proper dispositions and is super duper fast (no more N+9999 queries). FIX: the old list includes deleted topics FIX: the lists now properly display the topic states (deleted, closed, archived, hidden, PM) FIX: flagging a topic that you've already flagged the first post
187 lines
6.6 KiB
Ruby
187 lines
6.6 KiB
Ruby
require 'spec_helper'
|
|
|
|
describe PostActionsController do
|
|
|
|
describe 'create' do
|
|
it 'requires you to be logged in' do
|
|
lambda { xhr :post, :create }.should raise_error(Discourse::NotLoggedIn)
|
|
end
|
|
|
|
describe 'logged in' do
|
|
before do
|
|
@user = log_in(:moderator)
|
|
@post = Fabricate(:post, user: Fabricate(:coding_horror))
|
|
end
|
|
|
|
it 'raises an error when the id is missing' do
|
|
lambda { xhr :post, :create, post_action_type_id: PostActionType.types[:like] }.should raise_error(ActionController::ParameterMissing)
|
|
end
|
|
|
|
it 'raises an error when the post_action_type_id index is missing' do
|
|
lambda { xhr :post, :create, id: @post.id }.should raise_error(ActionController::ParameterMissing)
|
|
end
|
|
|
|
it "fails when the user doesn't have permission to see the post" do
|
|
Guardian.any_instance.expects(:can_see?).with(@post).returns(false)
|
|
xhr :post, :create, id: @post.id, post_action_type_id: PostActionType.types[:like]
|
|
response.should be_forbidden
|
|
end
|
|
|
|
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)
|
|
xhr :post, :create, id: @post.id, post_action_type_id: PostActionType.types[:like]
|
|
response.should be_forbidden
|
|
end
|
|
|
|
it 'allows us to create an post action on a post' do
|
|
PostAction.expects(:act).once.with(@user, @post, PostActionType.types[:like], {})
|
|
xhr :post, :create, id: @post.id, post_action_type_id: PostActionType.types[:like]
|
|
end
|
|
|
|
it 'passes the message through' do
|
|
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'
|
|
end
|
|
|
|
it 'passes take_action through' do
|
|
PostAction.expects(:act).once.with(@user, @post, PostActionType.types[:like], {take_action: true})
|
|
xhr :post, :create, id: @post.id, post_action_type_id: PostActionType.types[:like], take_action: 'true'
|
|
end
|
|
|
|
it "doesn't pass take_action through if the user isn't staff" do
|
|
Guardian.any_instance.stubs(:is_staff?).returns(false)
|
|
PostAction.expects(:act).once.with(@user, @post, PostActionType.types[:like], {})
|
|
xhr :post, :create, id: @post.id, post_action_type_id: PostActionType.types[:like], take_action: 'true'
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
context 'destroy' do
|
|
|
|
let(:post) { Fabricate(:post, user: Fabricate(:coding_horror)) }
|
|
|
|
it 'requires you to be logged in' do
|
|
lambda { xhr :delete, :destroy, id: post.id }.should raise_error(Discourse::NotLoggedIn)
|
|
end
|
|
|
|
context 'logged in' do
|
|
let!(:user) { log_in }
|
|
|
|
it 'raises an error when the post_action_type_id is missing' do
|
|
lambda { xhr :delete, :destroy, id: post.id }.should raise_error(ActionController::ParameterMissing)
|
|
end
|
|
|
|
it "returns 404 when the post action type doesn't exist for that user" do
|
|
xhr :delete, :destroy, id: post.id, post_action_type_id: 1
|
|
response.code.should == '404'
|
|
end
|
|
|
|
context 'with a post_action record ' do
|
|
let!(:post_action) { PostAction.create(user_id: user.id, post_id: post.id, post_action_type_id: 1)}
|
|
|
|
it 'returns success' do
|
|
xhr :delete, :destroy, id: post.id, post_action_type_id: 1
|
|
response.should be_success
|
|
end
|
|
|
|
it 'deletes the action' do
|
|
xhr :delete, :destroy, id: post.id, post_action_type_id: 1
|
|
PostAction.exists?(user_id: user.id, post_id: post.id, post_action_type_id: 1, deleted_at: nil).should be_false
|
|
end
|
|
|
|
it 'ensures it can be deleted' do
|
|
Guardian.any_instance.expects(:can_delete?).with(post_action).returns(false)
|
|
xhr :delete, :destroy, id: post.id, post_action_type_id: 1
|
|
response.should be_forbidden
|
|
end
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
context 'defer_flags' do
|
|
|
|
let(:flagged_post) { Fabricate(:post, user: Fabricate(:coding_horror)) }
|
|
|
|
context "not logged in" do
|
|
it "should not allow them to clear flags" do
|
|
lambda { xhr :post, :defer_flags }.should raise_error(Discourse::NotLoggedIn)
|
|
end
|
|
end
|
|
|
|
context 'logged in' do
|
|
let!(:user) { log_in(:moderator) }
|
|
|
|
it "raises an error without a post_action_type_id" do
|
|
-> { xhr :post, :defer_flags, id: flagged_post.id }.should raise_error(ActionController::ParameterMissing)
|
|
end
|
|
|
|
it "raises an error when the user doesn't have access" do
|
|
Guardian.any_instance.expects(:can_defer_flags?).returns(false)
|
|
xhr :post, :defer_flags, id: flagged_post.id, post_action_type_id: PostActionType.types[:spam]
|
|
response.should be_forbidden
|
|
end
|
|
|
|
context "success" do
|
|
before do
|
|
Guardian.any_instance.expects(:can_defer_flags?).returns(true)
|
|
PostAction.expects(:defer_flags!).with(flagged_post, user)
|
|
end
|
|
|
|
it "delegates to defer_flags" do
|
|
xhr :post, :defer_flags, id: flagged_post.id, post_action_type_id: PostActionType.types[:spam]
|
|
response.should be_success
|
|
end
|
|
|
|
it "works with a deleted post" do
|
|
flagged_post.trash!(user)
|
|
xhr :post, :defer_flags, id: flagged_post.id, post_action_type_id: PostActionType.types[:spam]
|
|
response.should be_success
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
describe 'users' do
|
|
|
|
let!(:post) { Fabricate(:post, user: log_in) }
|
|
|
|
it 'raises an error without an id' do
|
|
lambda {
|
|
xhr :get, :users, post_action_type_id: PostActionType.types[:like]
|
|
}.should raise_error(ActionController::ParameterMissing)
|
|
end
|
|
|
|
it 'raises an error without a post action type' do
|
|
lambda {
|
|
xhr :get, :users, id: post.id
|
|
}.should raise_error(ActionController::ParameterMissing)
|
|
end
|
|
|
|
it "fails when the user doesn't have permission to see the post" do
|
|
Guardian.any_instance.expects(:can_see?).with(post).returns(false)
|
|
xhr :get, :users, id: post.id, post_action_type_id: PostActionType.types[:like]
|
|
response.should be_forbidden
|
|
end
|
|
|
|
it 'raises an error when the post action type cannot be seen' do
|
|
Guardian.any_instance.expects(:can_see_post_actors?).with(instance_of(Topic), PostActionType.types[:like]).returns(false)
|
|
xhr :get, :users, id: post.id, post_action_type_id: PostActionType.types[:like]
|
|
response.should be_forbidden
|
|
end
|
|
|
|
it 'succeeds' do
|
|
xhr :get, :users, id: post.id, post_action_type_id: PostActionType.types[:like]
|
|
response.should be_success
|
|
end
|
|
|
|
end
|
|
|
|
end
|