From e28721baf275891ab8cb4e91e33877d52f5f26e8 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Rafael=20Mendon=C3=A7a=20Fran=C3=A7a?= Date: Thu, 19 Feb 2015 09:08:10 -0200 Subject: Copy edit the suppressor documentation [ci skip] --- activerecord/CHANGELOG.md | 26 ++++++++++++------------ activerecord/lib/active_record/suppressor.rb | 30 ++++++++++++++-------------- activerecord/test/cases/suppressor_test.rb | 1 - 3 files changed, 28 insertions(+), 29 deletions(-) diff --git a/activerecord/CHANGELOG.md b/activerecord/CHANGELOG.md index e52c142dc2..57d135d1aa 100644 --- a/activerecord/CHANGELOG.md +++ b/activerecord/CHANGELOG.md @@ -1,29 +1,29 @@ -* Add ActiveRecord::Base.suppress to prevent the receiver from being saved +* Add `ActiveRecord::Base.suppress` to prevent the receiver from being saved during the given block. For example, here's a pattern of creating notifications when new comments are posted. (The notification may in turn trigger an email, a push notification, or just appear in the UI somewhere): - class Comment < ActiveRecord::Base - belongs_to :commentable, polymorphic: true - after_create -> { Notification.create! comment: self, - recipients: commentable.recipients } - end + class Comment < ActiveRecord::Base + belongs_to :commentable, polymorphic: true + after_create -> { Notification.create! comment: self, + recipients: commentable.recipients } + end That's what you want the bulk of the time. New comment creates a new Notification. But there may well be off cases, like copying a commentable and its comments, where you don't want that. So you'd have a concern something like this: - module Copyable - def copy_to(destination) - Notification.suppress do - # Copy logic that creates new comments that we do not want triggering - # notifications. + module Copyable + def copy_to(destination) + Notification.suppress do + # Copy logic that creates new comments that we do not want triggering + # notifications. + end + end end - end - end *Michael Ryan* diff --git a/activerecord/lib/active_record/suppressor.rb b/activerecord/lib/active_record/suppressor.rb index b47f02143c..5c46d7cc9c 100644 --- a/activerecord/lib/active_record/suppressor.rb +++ b/activerecord/lib/active_record/suppressor.rb @@ -5,26 +5,26 @@ module ActiveRecord # For example, here's a pattern of creating notifications when new comments # are posted. (The notification may in turn trigger an email, a push # notification, or just appear in the UI somewhere): - # - # class Comment < ActiveRecord::Base - # belongs_to :commentable, polymorphic: true - # after_create -> { Notification.create! comment: self, - # recipients: commentable.recipients } - # end - # + # + # class Comment < ActiveRecord::Base + # belongs_to :commentable, polymorphic: true + # after_create -> { Notification.create! comment: self, + # recipients: commentable.recipients } + # end + # # That's what you want the bulk of the time. New comment creates a new # Notification. But there may well be off cases, like copying a commentable # and its comments, where you don't want that. So you'd have a concern # something like this: - # - # module Copyable - # def copy_to(destination) - # Notification.suppress do - # # Copy logic that creates new comments that we do not want - # # triggering notifications. + # + # module Copyable + # def copy_to(destination) + # Notification.suppress do + # # Copy logic that creates new comments that we do not want + # # triggering notifications. + # end # end # end - # end module Suppressor extend ActiveSupport::Concern @@ -38,7 +38,7 @@ module ActiveRecord end # Ignore saving events if we're in suppression mode. - def save!(*args) + def save!(*args) # :nodoc: SuppressorRegistry.suppressed[self.class.name] ? self : super end end diff --git a/activerecord/test/cases/suppressor_test.rb b/activerecord/test/cases/suppressor_test.rb index 011d712bb8..1c449d42fe 100644 --- a/activerecord/test/cases/suppressor_test.rb +++ b/activerecord/test/cases/suppressor_test.rb @@ -3,7 +3,6 @@ require 'models/notification' require 'models/user' class SuppressorTest < ActiveRecord::TestCase - def test_suppresses_creation_of_record_generated_by_callback assert_difference -> { User.count } do assert_no_difference -> { Notification.count } do -- cgit v1.2.3