discourse/spec/components/jobs/notify_moved_posts_spec.rb

37 lines
1.3 KiB
Ruby
Raw Normal View History

2013-02-06 03:16:51 +08:00
require 'spec_helper'
require 'jobs/process_post'
describe Jobs::NotifyMovedPosts do
it "raises an error without post_ids" do
lambda { Jobs::NotifyMovedPosts.new.execute(moved_by_id: 1234) }.should raise_error(Discourse::InvalidParameters)
end
it "raises an error without moved_by_id" do
lambda { Jobs::NotifyMovedPosts.new.execute(post_ids: [1,2,3]) }.should raise_error(Discourse::InvalidParameters)
end
context 'with post ids' do
let!(:p1) { Fabricate(:post) }
let!(:p2) { Fabricate(:post, user: Fabricate(:evil_trout), topic: p1.topic) }
let!(:p3) { Fabricate(:post, user: p1.user, topic: p1.topic) }
let(:admin) { Fabricate(:admin) }
2013-03-01 20:07:44 +08:00
let(:moved_post_notifications) { Notification.where(notification_type: Notification.types[:moved_post]) }
2013-02-06 03:16:51 +08:00
it "should create two notifications" do
lambda { Jobs::NotifyMovedPosts.new.execute(post_ids: [p1.id, p2.id, p3.id], moved_by_id: admin.id) }.should change(moved_post_notifications, :count).by(2)
end
context 'when moved by one of the posters' do
it "create one notifications, because the poster is the mover" do
lambda { Jobs::NotifyMovedPosts.new.execute(post_ids: [p1.id, p2.id, p3.id], moved_by_id: p1.user_id) }.should change(moved_post_notifications, :count).by(1)
end
end
end
end