# frozen_string_literal: true require 'rails_helper' require_relative '../support/assign_allowed_group' require_relative '../fabricators/assign_hook_fabricator.rb' describe 'integration tests' do before do SiteSetting.assign_enabled = true end it 'preloads data in topic list' do admin = Fabricate(:admin) post = create_post list = TopicList.new("latest", admin, [post.topic]) TopicList.preload([post.topic], list) # should not explode for now end describe 'for a private message' do let(:post) { Fabricate(:private_message_post) } let(:pm) { post.topic } let(:user) { pm.allowed_users.first } let(:user2) { pm.allowed_users.last } let(:channel) { "/private-messages/assigned" } fab!(:group) { Fabricate(:group, assignable_level: Group::ALIAS_LEVELS[:everyone]) } include_context 'A group that is allowed to assign' before do add_to_assign_allowed_group(user) add_to_assign_allowed_group(user2) group.add(user) group.add(user2) end def assert_publish_topic_state(topic, user: nil, group: nil) messages = MessageBus.track_publish do yield end message = messages.find { |m| m.channel == channel } expect(message.data[:topic_id]).to eq(topic.id) expect(message.user_ids).to eq([user.id]) if user expect(message.group_ids).to eq([group.id]) if group end it 'publishes the right message on archive and move to inbox' do assigner = Assigner.new(pm, user) assigner.assign(user) assert_publish_topic_state(pm, user: user) do UserArchivedMessage.archive!(user.id, pm.reload) end assert_publish_topic_state(pm, user: user) do UserArchivedMessage.move_to_inbox!(user.id, pm.reload) end end it 'publishes the right message on archive and move to inbox for groups' do assigner = Assigner.new(pm, user) assigner.assign(group) assert_publish_topic_state(pm, group: group) do GroupArchivedMessage.archive!(group.id, pm.reload) end assert_publish_topic_state(pm, group: group) do GroupArchivedMessage.move_to_inbox!(group.id, pm.reload) end end it "unassign and assign user if unassign_on_group_archive" do SiteSetting.unassign_on_group_archive = true assigner = Assigner.new(pm, user) assigner.assign(user) GroupArchivedMessage.archive!(group.id, pm.reload) expect(pm.assignment.active).to be false GroupArchivedMessage.move_to_inbox!(group.id, pm.reload) expect(pm.assignment.active).to be true expect(pm.assignment.assigned_to).to eq(user) end it "unassign and assign group if unassign_on_group_archive" do SiteSetting.unassign_on_group_archive = true assigner = Assigner.new(pm, user) assigner.assign(group) GroupArchivedMessage.archive!(group.id, pm.reload) expect(pm.assignment.active).to be false GroupArchivedMessage.move_to_inbox!(group.id, pm.reload) expect(pm.assignment.active).to be true expect(pm.assignment.assigned_to).to eq(group) end end describe "on assign_topic event" do let(:post) { Fabricate(:post) } let(:topic) { post.topic } let(:admin) { Fabricate(:admin) } let(:user1) { Fabricate(:user) } let(:user2) { Fabricate(:user) } include_context 'A group that is allowed to assign' before do add_to_assign_allowed_group(user1) add_to_assign_allowed_group(user2) end it "assigns topic" do DiscourseEvent.trigger(:assign_topic, topic, user1, admin) expect(topic.assignment.assigned_to_id).to eq(user1.id) DiscourseEvent.trigger(:assign_topic, topic, user2, admin) expect(topic.assignment.assigned_to_id).to eq(user1.id) DiscourseEvent.trigger(:assign_topic, topic, user2, admin, true) expect(topic.assignment.assigned_to_id).to eq(user2.id) end it "triggers a webhook for assigned and unassigned" do Fabricate(:assign_web_hook) DiscourseEvent.trigger(:assign_topic, topic, user2, admin, true) job_args = Jobs::EmitWebHookEvent.jobs[0]["args"].first expect(job_args["event_name"]).to eq("assigned") payload = JSON.parse(job_args["payload"]) expect(payload["topic_id"]).to eq(topic.id) expect(payload["assigned_to_id"]).to eq(user2.id) DiscourseEvent.trigger(:unassign_topic, topic, admin) job_args = Jobs::EmitWebHookEvent.jobs[1]["args"].first expect(job_args["event_name"]).to eq("unassigned") payload = JSON.parse(job_args["payload"]) expect(payload["topic_id"]).to eq(topic.id) expect(payload["unassigned_to_id"]).to eq(user2.id) end end context 'already assigned' do fab!(:post) { Fabricate(:post) } fab!(:post_2) { Fabricate(:post, topic: post.topic) } let(:topic) { post.topic } fab!(:user) { Fabricate(:user) } include_context 'A group that is allowed to assign' it 'does not allow to assign topic if post is already assigned' do add_to_assign_allowed_group(user) assigner = Assigner.new(post, user) response = assigner.assign(user) expect(response[:success]).to be true assigner = Assigner.new(post_2, user) response = assigner.assign(user) expect(response[:success]).to be true assigner = Assigner.new(topic, user) response = assigner.assign(user) expect(response[:success]).to be false expect(response[:reason]).to eq(:already_assigned) end end context 'move post' do fab!(:old_topic) { Fabricate(:topic) } fab!(:post) { Fabricate(:post, topic: old_topic) } fab!(:user) { Fabricate(:user) } fab!(:assignment) { Assignment.create!(target_id: post.id, target_type: "Post", topic_id: old_topic.id, assigned_by_user: user, assigned_to: user) } let(:new_topic) { Fabricate(:topic) } it 'assignment becomes topic assignment when new topic' do post.update!(topic: new_topic) DiscourseEvent.trigger(:post_moved, post, old_topic.id) assignment.reload expect(assignment.topic_id).to eq(new_topic.id) expect(assignment.target_type).to eq("Topic") expect(assignment.target_id).to eq(new_topic.id) end it 'assigment is still post assignment when not first post' do post.update!(topic: new_topic, post_number: "3") DiscourseEvent.trigger(:post_moved, post, old_topic.id) assignment.reload expect(assignment.topic_id).to eq(new_topic.id) expect(assignment.target_type).to eq("Post") expect(assignment.target_id).to eq(post.id) end end end