mirror of
https://github.com/discourse/discourse.git
synced 2024-12-12 02:23:42 +08:00
493d437e79
* Remove outdated option
04078317ba
* Use the non-globally exposed RSpec syntax
https://github.com/rspec/rspec-core/pull/2803
* Use the non-globally exposed RSpec syntax, cont
https://github.com/rspec/rspec-core/pull/2803
* Comply to strict predicate matchers
See:
- https://github.com/rspec/rspec-expectations/pull/1195
- https://github.com/rspec/rspec-expectations/pull/1196
- https://github.com/rspec/rspec-expectations/pull/1277
59 lines
2.0 KiB
Ruby
59 lines
2.0 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
RSpec.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
|