This is part of the Semicolon&Sons Code Diary - consisting of lessons learned on the job. You're in the testing category.
Last Updated: 2025-01-18
Imagine you interacted with the user
object with these 2-calls:
user.set_paid_through_date(1.year.from_now)
user.save!
To mock this, you'd need two stubs.
user = stub
paid_through_stub = stub
allow(user).to receive(:set_paid_through_date) { paid_through_stub }
allow(paid_through_stub).to receive(:save) { true }
Compare this approach to the following code which collapses the setting and saving into one method:
# user.rb
def pay_through(date)
self.set_paid_through_date(date)
self.save!
end
Now the caller is simplified
user.pay_through(1.year.from_now)
And the tests become much simpler as a result:
user = stub
allow(user).to receive(:pay_through) { true }
To create good, easily tested designs, limit the amount of messages that you send to objects.