very interesting thought there :-) , thrown a spanner in my works now

On 02/02/2010 13:19, Nicolás Sanguinetti wrote:
The problem is that you're passing a hash with symbols as keys, and
rails takes the params and converts it to a HashWithIndifferentAccess,
which actually stores the keys as strings.

One thing you might try to solve your problem is do this:

it "should create new client" do
  client = Client.plan.with_indifferent_access
  Client.should_receive(:new).with(client)
  post 'create' , :client => client
end

I guess that will probably solve it.

On an unrelated note—and here's to opening a huge can of worms :)—I
usually dislike stubbing/mocking to do these simple tests. I tend to
like testing more the behavior of my controllers, so for a valid
create, I would write this test:

it "adds a new client" do
  lambda { post :create, :client => Client.plan }.should
change(Client, :count).by(1)
end

Since this doesn't rely on the implementation (calling
Client.new(params) — which might change to
current_user.clients.new(params), and maybe some business logic is
added along the way and it turns into current_user.add_client(params)
at some point), it tells me that the action, provided valid
parameters, is working, and at the same time will resist a
refactoring.

(This is considering your action is a "standard" create action for a
rails controller)

But again, this is *my* usual approach, there are good reasons both in
favor of not mocking and in favor of mocking the behavior of your
models. I just like the ones in favor of not mocking a bit more :)

Cheers

On Tue, Feb 2, 2010 at 10:26 AM, Stephen Smithstone
<stephen.smithst...@gmail.com> wrote:
  
cheers for the response , seem that attributes is missing from hash on my
system

all i did was the blueprint with a standard hash

client = { :title => "Mr }

client.attributes

NoMethodError: undefined method `attributes' for {:title=>"Mr"}:Hash

is attributes added on by rails ?

if so my setup must be wrong

On 2 February 2010 12:07, J. B. Rainsberger <jbrainsber...@gmail.com> wrote:
    
On Tue, Feb 2, 2010 at 04:24, Stephen Smithstone <ssmithst...@me.com>
wrote:

      
A bit stuck here being new to ruby and rspec
        
Welcome. I hope you like the experience. Good news: we've seen what
you've done a thousand times and so it's quite easy to explain.

      
it "should create new client" do
    // creates me a hash of generated values using Foregey
    client = Client.plan
    // specify that I should be creating a new client with the hash
values
from client
    Client.should_receive(:new).with(client)
    //post to the server
    post 'create' , :client => client
end

in my controller

def create
    client = Client.new(params[:client])
end

now this is failing with

Spec::Mocks::MockExpectationError: <Client(id: integer, created_at:
datetime, updated_at: datetime, title: string, lastname: string,
firstname:
string, email: string) (class)> received :new with unexpected arguments
  expected: ({:title=>"Mr", :firstname=>"Ernest", :lastname=>"Burke",
:email=>"rgarr...@blogtag.info"})
       got: ({"title"=>"Mr", "lastname"=>"Burke", "firstname"=>"Ernest",
"email"=>"rgarr...@blogtag.info"})

is there a way to specify to use symbols instead of the strings as keys,
as
I dont want to be doing

:client => { "title" => client.title , ............ }

as the client model may change over time
        
Try Client.should_receive(:new).with(client.attributes), because the
#attributes method turns a model into a Hash of symbol to value. It
uses string keys instead of symbol keys, but that shouldn't hurt you.

Good luck.
--
J. B. (Joe) Rainsberger :: http://www.jbrains.ca ::
http://blog.thecodewhisperer.com
Diaspar Software Services :: http://www.diasparsoftware.com
Author, JUnit Recipes
2005 Gordon Pask Award for contribution to Agile practice :: Agile
2010: Learn. Practice. Explore.
_______________________________________________
rspec-users mailing list
rspec-users@rubyforge.org
http://rubyforge.org/mailman/listinfo/rspec-users
      

_______________________________________________
rspec-users mailing list
rspec-users@rubyforge.org
http://rubyforge.org/mailman/listinfo/rspec-users

    
_______________________________________________
rspec-users mailing list
rspec-users@rubyforge.org
http://rubyforge.org/mailman/listinfo/rspec-users

Reply via email to