mirror of
https://github.com/discourse/discourse.git
synced 2024-12-03 09:53:38 +08:00
c9dab6fd08
It's very easy to forget to add `require 'rails_helper'` at the top of every core/plugin spec file, and omissions can cause some very confusing/sporadic errors. By setting this flag in `.rspec`, we can remove the need for `require 'rails_helper'` entirely.
59 lines
2.0 KiB
Ruby
59 lines
2.0 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
describe Notifications::ConsolidateNotifications do
|
|
describe '#before_consolidation_callbacks' do
|
|
fab!(:user) { Fabricate(:user) }
|
|
let(:rule) do
|
|
described_class.new(
|
|
from: Notification.types[:liked],
|
|
to: Notification.types[:liked],
|
|
consolidation_window: 10.minutes,
|
|
consolidated_query_blk: Proc.new do |notifications|
|
|
notifications.where("(data::json ->> 'consolidated')::bool")
|
|
end,
|
|
threshold: 1
|
|
).set_mutations(set_data_blk: Proc.new { |n| n.data_hash.merge(consolidated: true) })
|
|
end
|
|
|
|
it 'applies a callback when consolidating a notification' do
|
|
rule.before_consolidation_callbacks(
|
|
before_consolidation_blk: Proc.new do |_, data|
|
|
data[:consolidation_callback_called] = true
|
|
end
|
|
)
|
|
|
|
rule.consolidate_or_save!(build_like_notification)
|
|
rule.consolidate_or_save!(build_like_notification)
|
|
|
|
consolidated_notification = Notification.where(user: user).last
|
|
|
|
expect(consolidated_notification.data_hash[:consolidation_callback_called]).to eq(true)
|
|
end
|
|
|
|
it 'applies a callback when updating a consolidated notification' do
|
|
rule.before_consolidation_callbacks(
|
|
before_update_blk: Proc.new do |_, data|
|
|
data[:update_callback_called] = true
|
|
end
|
|
)
|
|
|
|
rule.consolidate_or_save!(build_like_notification)
|
|
rule.consolidate_or_save!(build_like_notification)
|
|
|
|
consolidated_notification = Notification.where(user: user).last
|
|
|
|
expect(consolidated_notification.data_hash[:update_callback_called]).to be_nil
|
|
|
|
rule.consolidate_or_save!(build_like_notification)
|
|
|
|
consolidated_notification = Notification.where(user: user).last
|
|
|
|
expect(consolidated_notification.data_hash[:update_callback_called]).to eq(true)
|
|
end
|
|
|
|
def build_like_notification
|
|
Fabricate.build(:notification, user: user, notification_type: Notification.types[:liked], data: {}.to_json)
|
|
end
|
|
end
|
|
end
|