Mocking and stubbing Rails' has_many association

I’m somewhat new to testing and rspec. And I’m struggling a bit with
the application of Mocks and Stubs in a Rails application. I think I’m
beginning to grasp it, but I’m stuck on how to spec the following:

I have a User model which has a has_many relationship to Trip models,
and the implementation is taken from #75 Complex Forms Part 3 - RailsCasts
So I have the following methods in my User model to handle the nested
Trip attributes that are passed to the User model:

def new_trip_attributes=(trip_attributes)
trip_attributes.each do |attributes|
trips.build(attributes)
end
end

def existing_trip_attributes=(trip_attributes)
trips.reject(&:new_record?).each do |trip|
attributes = trip_attributes[trip.id.to_s]
if attributes
trip.attributes = attributes
else
trips.delete(trip)
end
end
end

Part of my problem is probably that I’m not doing true T/B driven
development, but trying to spec Ryan’s implmentation. Anyway for the
new_trip_attributes= method I’ve come up with the following spec:

it “should use new trip attributes to add Trips to the trips
association” do
@user.stub_association!(:trips, :build => mock_model(Trip, :save =>
true))
@user.new_trip_attributes = trip_attributes
end

(I found the stub_association! method here:
Easy AR association stubbing - RSpec - Ruby-Forum)
This seems to work, though I’m not sure that the single example is
sufficient coverage for that method…

But where I’m really running into trouble is with the
existing_trip_attributes= method. I’ve been trying to puzzle through
it using this thread as a guideline:
http://www.ruby-forum.com/topic/138342

These are the examples I came up with to cover the method

it “should ignore new associated trip records”

it “should update the associated existing trip”

it “should delete the associated existing trip, if there are no
attributes for it”

I’m really not sure what to mock, what to stub or even if my confusion
is an indication that the method implementation should be different.
Beyond my specific implementation question, It would be great to hear
from more experienced Rspec users on how to discern the difference
between ones capability with the tool (Rspec), vs. the tool’s feedback
that the implementation needs to be changed.

I have studied the first three peepcode rspec episodes as well as the
altered beast specs Parked at Loopia
and done a bit of searching and reading through the list archives. The
Altered beast specs are enlightening, but they make use of some
extensions to Rspec and I would rather not confuse myself with trying
to learn those extensions at the same time. Any other suggestions for
open source rails projects with good specs to learn from would be
appreciated as well.

Thanks in advance for any suggestions you might have.


Eirik Dentz Sinclair