Ich möchte die Antwort von @luizbranco verbessern, um den Rückruf nach dem Speichern beim Erstellen anderer Benutzer wiederverwendbarer zu machen.
FactoryGirl.define do
factory :user do
first_name "Luiz"
last_name "Branco"
#...
after(:build) { |user|
user.class.skip_callback(:create,
:after,
:run_something1,
:run_something2)
}
trait :with_after_save_callback do
after(:build) { |user|
user.class.set_callback(:create,
:after,
:run_something1,
:run_something2)
}
end
end
end
Laufen ohne after_save-Rückruf:
FactoryGirl.create(:user)
Ausführen mit after_save-Rückruf:
FactoryGirl.create(:user, :with_after_save_callback)
In meinem Test ziehe ich es vor, Benutzer standardmäßig ohne Rückruf zu erstellen, da die verwendeten Methoden zusätzliche Dinge ausführen, die ich normalerweise in meinen Testbeispielen nicht möchte.
---------- UPDATE ------------ Ich habe die Verwendung von skip_callback eingestellt, da in der Testsuite einige Inkonsistenzprobleme aufgetreten sind.
Alternative Lösung 1 (Verwendung von Stub und Unstub):
after(:build) { |user|
user.class.any_instance.stub(:run_something1)
user.class.any_instance.stub(:run_something2)
}
trait :with_after_save_callback do
after(:build) { |user|
user.class.any_instance.unstub(:run_something1)
user.class.any_instance.unstub(:run_something2)
}
end
Alternative Lösung 2 (mein bevorzugter Ansatz):
after(:build) { |user|
class << user
def run_something1; true; end
def run_something2; true; end
end
}
trait :with_after_save_callback do
after(:build) { |user|
class << user
def run_something1; super; end
def run_something2; super; end
end
}
end
:on => :create
Validierung überspringen möchten , verwenden Sieafter(:build) { |user| user.class.skip_callback(:validate, :create, :after, :run_something) }