2024-05-22 11:50:21 -04:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
RSpec.describe BookmarksBulkAction do
|
|
|
|
fab!(:user) { Fabricate(:user, refresh_auto_groups: true) }
|
|
|
|
fab!(:user_2) { Fabricate(:user, refresh_auto_groups: true) }
|
|
|
|
fab!(:bookmark_1) { Fabricate(:bookmark, user: user) }
|
|
|
|
fab!(:bookmark_2) { Fabricate(:bookmark, user: user) }
|
|
|
|
|
|
|
|
describe "#delete" do
|
|
|
|
describe "when user is not the bookmark owner" do
|
|
|
|
it "does NOT delete the bookmarks" do
|
|
|
|
bba = BookmarksBulkAction.new(user_2, [bookmark_1.id, bookmark_2.id], type: "delete")
|
|
|
|
expect { bba.perform! }.to raise_error Discourse::InvalidAccess
|
|
|
|
|
|
|
|
expect(Bookmark.where(id: bookmark_1.id)).to_not be_empty
|
|
|
|
expect(Bookmark.where(id: bookmark_2.id)).to_not be_empty
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe "when user is the bookmark owner" do
|
|
|
|
it "deletes the bookmarks" do
|
|
|
|
bba = BookmarksBulkAction.new(user, [bookmark_1.id, bookmark_2.id], type: "delete")
|
|
|
|
bba.perform!
|
|
|
|
|
|
|
|
expect(Bookmark.where(id: bookmark_1.id)).to be_empty
|
|
|
|
expect(Bookmark.where(id: bookmark_2.id)).to be_empty
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe "#clear_reminder" do
|
|
|
|
fab!(:bookmark_with_reminder) { Fabricate(:bookmark_next_business_day_reminder, user: user) }
|
|
|
|
|
|
|
|
describe "when user is not the bookmark owner" do
|
|
|
|
it "does NOT clear the reminder" do
|
|
|
|
bba = BookmarksBulkAction.new(user_2, [bookmark_with_reminder], type: "clear_reminder")
|
|
|
|
expect { bba.perform! }.to raise_error Discourse::InvalidAccess
|
|
|
|
expect(Bookmark.find_by_id(bookmark_with_reminder).reminder_set_at).to_not be_nil
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe "when user is the bookmark owner" do
|
|
|
|
it "deletes the bookmarks" do
|
|
|
|
expect do
|
|
|
|
bba = BookmarksBulkAction.new(user, [bookmark_with_reminder.id], type: "clear_reminder")
|
|
|
|
bba.perform!
|
2024-05-28 09:21:33 -04:00
|
|
|
end.to change { Bookmark.find_by_id(bookmark_with_reminder.id).reminder_set_at }.to(
|
|
|
|
nil,
|
|
|
|
).and change { Bookmark.find_by_id(bookmark_with_reminder.id).reminder_at }.to(nil)
|
2024-05-22 11:50:21 -04:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|