# frozen_string_literal: true require 'rails_helper' describe PostBookmarkable do fab!(:user) { Fabricate(:user) } fab!(:guardian) { Guardian.new(user) } fab!(:private_category) { Fabricate(:private_category, group: Fabricate(:group)) } let!(:post1) { Fabricate(:post) } let!(:post2) { Fabricate(:post) } let!(:bookmark1) { Fabricate(:bookmark, user: user, bookmarkable: post1, name: "something i gotta do") } let!(:bookmark2) { Fabricate(:bookmark, user: user, bookmarkable: post2) } let!(:bookmark3) { Fabricate(:bookmark) } let!(:topic_user1) { Fabricate(:topic_user, user: user, topic: post1.topic) } let!(:topic_user2) { Fabricate(:topic_user, user: user, topic: post2.topic) } subject { RegisteredBookmarkable.new(PostBookmarkable) } describe "#perform_list_query" do it "returns all the user's bookmarks" do expect(subject.perform_list_query(user, guardian).map(&:id)).to match_array([bookmark1.id, bookmark2.id]) end it "does not return bookmarks for posts where the user does not have access to the topic category" do bookmark1.bookmarkable.topic.update(category: private_category) expect(subject.perform_list_query(user, guardian).map(&:id)).to match_array([bookmark2.id]) end it "does not return bookmarks for posts where the user does not have access to the private message" do bookmark1.bookmarkable.update(topic: Fabricate(:private_message_topic)) expect(subject.perform_list_query(user, guardian).map(&:id)).to match_array([bookmark2.id]) end end describe "#perform_search_query" do before do SearchIndexer.enable end it "returns bookmarks that match by name" do ts_query = Search.ts_query(term: "gotta", ts_config: "simple") expect(subject.perform_search_query(subject.perform_list_query(user, guardian), "%gotta%", ts_query).map(&:id)).to match_array([bookmark1.id]) end it "returns bookmarks that match by post search data (topic title or post content)" do post2.update(raw: "some post content") post2.topic.update(title: "a great topic title") ts_query = Search.ts_query(term: "post content", ts_config: "simple") expect(subject.perform_search_query(subject.perform_list_query(user, guardian), "%post content%", ts_query).map(&:id)).to match_array([bookmark2.id]) ts_query = Search.ts_query(term: "great topic", ts_config: "simple") expect(subject.perform_search_query(subject.perform_list_query(user, guardian), "%great topic%", ts_query).map(&:id)).to match_array([bookmark2.id]) ts_query = Search.ts_query(term: "blah", ts_config: "simple") expect(subject.perform_search_query(subject.perform_list_query(user, guardian), "%blah%", ts_query).map(&:id)).to eq([]) end end describe "#can_send_reminder?" do it "cannot send reminder if the post or topic is deleted" do expect(subject.can_send_reminder?(bookmark1)).to eq(true) bookmark1.bookmarkable.trash! bookmark1.reload expect(subject.can_send_reminder?(bookmark1)).to eq(false) Post.with_deleted.find_by(id: bookmark1.bookmarkable_id).recover! bookmark1.reload bookmark1.bookmarkable.topic.trash! bookmark1.reload expect(subject.can_send_reminder?(bookmark1)).to eq(false) end end describe "#reminder_handler" do it "creates a notification for the user with the correct details" do expect { subject.send_reminder_notification(bookmark1) }.to change { Notification.count }.by(1) notif = user.notifications.last expect(notif.notification_type).to eq(Notification.types[:bookmark_reminder]) expect(notif.topic_id).to eq(bookmark1.bookmarkable.topic_id) expect(notif.post_number).to eq(bookmark1.bookmarkable.post_number) expect(notif.data).to eq( { title: bookmark1.bookmarkable.topic.title, bookmarkable_url: bookmark1.bookmarkable.url, display_username: bookmark1.user.username, bookmark_name: bookmark1.name, bookmark_id: bookmark1.id }.to_json ) end end describe "#can_see?" do it "returns false if the post is in a private category or private message the user cannot see" do expect(subject.can_see?(guardian, bookmark1)).to eq(true) bookmark1.bookmarkable.topic.update(category: private_category) expect(subject.can_see?(guardian, bookmark1)).to eq(false) bookmark1.bookmarkable.update(topic: Fabricate(:private_message_topic)) expect(subject.can_see?(guardian, bookmark1)).to eq(false) end end end