2019-04-29 20:27:42 -04:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2015-10-11 05:41:23 -04:00
|
|
|
require 'rails_helper'
|
2013-02-05 14:16:51 -05:00
|
|
|
|
|
|
|
describe Jobs::NotifyMovedPosts do
|
|
|
|
|
|
|
|
it "raises an error without post_ids" do
|
2014-12-31 09:55:03 -05:00
|
|
|
expect { Jobs::NotifyMovedPosts.new.execute(moved_by_id: 1234) }.to raise_error(Discourse::InvalidParameters)
|
2013-02-05 14:16:51 -05:00
|
|
|
end
|
|
|
|
|
|
|
|
it "raises an error without moved_by_id" do
|
2014-12-31 09:55:03 -05:00
|
|
|
expect { Jobs::NotifyMovedPosts.new.execute(post_ids: [1, 2, 3]) }.to raise_error(Discourse::InvalidParameters)
|
2013-02-05 14:16:51 -05:00
|
|
|
end
|
|
|
|
|
|
|
|
context 'with post ids' do
|
2019-05-06 23:12:20 -04:00
|
|
|
fab!(:p1) { Fabricate(:post) }
|
|
|
|
fab!(:p2) { Fabricate(:post, user: Fabricate(:evil_trout), topic: p1.topic) }
|
|
|
|
fab!(:p3) { Fabricate(:post, user: p1.user, topic: p1.topic) }
|
|
|
|
fab!(:admin) { Fabricate(:admin) }
|
2013-02-05 14:16:51 -05:00
|
|
|
|
2013-03-01 07:07:44 -05:00
|
|
|
let(:moved_post_notifications) { Notification.where(notification_type: Notification.types[:moved_post]) }
|
2013-02-05 14:16:51 -05:00
|
|
|
|
|
|
|
it "should create two notifications" do
|
2014-12-31 09:55:03 -05:00
|
|
|
expect { Jobs::NotifyMovedPosts.new.execute(post_ids: [p1.id, p2.id, p3.id], moved_by_id: admin.id) }.to change(moved_post_notifications, :count).by(2)
|
2013-02-05 14:16:51 -05:00
|
|
|
end
|
|
|
|
|
|
|
|
context 'when moved by one of the posters' do
|
|
|
|
it "create one notifications, because the poster is the mover" do
|
2014-12-31 09:55:03 -05:00
|
|
|
expect { Jobs::NotifyMovedPosts.new.execute(post_ids: [p1.id, p2.id, p3.id], moved_by_id: p1.user_id) }.to change(moved_post_notifications, :count).by(1)
|
2013-02-05 14:16:51 -05:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
end
|
|
|
|
|
|
|
|
end
|