On Nov 29, 2011, at 2:32 PM, Patrick J. Collins wrote:

> In the app I am working on, there are a lot of observers for various models
> which call Event.create! to log stuff...  So within a particular example,
> various records might be created in order to test behavior-- and this would
> result in several events being created.
> 
> So say, I have a spec that does:
> 
> it "creates an event when sharing a post" do
>  user = create_user                # this will make an event record of type 
> "user created"
>  post = create_post(:user => user) # this will make an event record of type 
> "post created"
>  post.share!
> 
>  # check to see that Event has a "post shared" event
> end
> 
> ...
> 
> Normally I would just do Event.last.event_type.should == "post shared"
> 
> However, if the Event model has it's default_scope set to order records in a
> certain way, that test might fail.
> 
> So I could do:
> 
> Event.unscoped.last.event_type.should == "post shared"
> 
> But then I begin thinking maybe it should be more like this:
> 
> it "creates an event when sharing a post" do
>  Event.exists?(:event_type => "post shared").should be_false
> 
>  user = create_user # this will make an event record of type "user created"
>  post = create_post(:user => user) # this will make an event record of type 
> "post created"
>  post.share!
> 
>  Event.exists?(:event_type => "post shared").should be_true
> end
> 
> ...  I'm just not sure what's the best way to go, and if there's a convention
> for this sort of thing?


I'm not aware of a solid convention for this. I tend to avoid the pairing of 
the 1st and last lines of the 2nd example.

Are the events associated to the posts at all? If so you could specify 
post.events.map(&:event_type).should include("post shared") or some such.
_______________________________________________
rspec-users mailing list
rspec-users@rubyforge.org
http://rubyforge.org/mailman/listinfo/rspec-users

Reply via email to