Forum: Ruby on Rails Wierd NomethodError

Posted by Roelof Wobben (roelof)
on 2012-11-03 21:44
(Received via mailing list)
Hello,

I have my source here : https://github.com/roelof1967/tamara

When I do cucumber I get this error message :
Then he should see "Welcome, Aslak"         #
features/step_definitions/login_steps.rb:27
      undefined method `messages' for nil:NilClass (NoMethodError)
      ./features/step_definitions/login_steps.rb:28:in `/^he should see
"(.*?)"$/'
      features/login.feature:6:in `Then he should see "Welcome, Aslak"'

Which I find wierd because I have a method messages made in my class 
Output.

Roelof
Posted by Colin Law (Guest)
on 2012-11-03 21:59
(Received via mailing list)
On 3 November 2012 20:43, roelof <rwobben@hotmail.com> wrote:
>       features/login.feature:6:in `Then he should see "Welcome, Aslak"'
>
> Which I find wierd because I have a method messages made in my class Output.

You have the messages method, but the error is saying that the object
you are calling it on is nil.  So on the line that is calling
something.messages then the something is nil.  You have to work out
why it is nil.

Colin
Posted by Roelof Wobben (roelof)
on 2012-11-04 09:09
(Received via mailing list)
The only thing I can think of is that output is not created.
But that cannot be the reason because there is a function create which
contains Ouput.new which is the same as Output.create.

Roelof


Op zaterdag 3 november 2012 21:59:16 UTC+1 schreef Colin Law het 
volgende:
Posted by Matt Jones (Guest)
on 2012-11-05 00:53
(Received via mailing list)
On Saturday, 3 November 2012 16:43:19 UTC-4, roelof wrote:
> "(.*?)"$/'
>       features/login.feature:6:in `Then he should see "Welcome, Aslak"'
>
> Which I find wierd because I have a method messages made in my class
> Output.
>
>
I don't see where you're initializing @output anywhere in that file - 
it's
going to be hard to call methods on an uninitialized instance 
variable...

--Matt Jones
Posted by Colin Law (Guest)
on 2012-11-05 06:48
(Received via mailing list)
On 4 November 2012 12:03, Roelof Wobben <rwobben@hotmail.com> wrote:
>> Please don't top post, it makes it difficult to follow the thread.
>
>
> The error message can be found here  : https://gist.github.com/4008123
> And the relevant code can be found here :
> 
https://github.com/roelof1967/tamara/blob/master/f...

That is a different error message to the one you originally posted.

What is the line
messages << message
supposed to do.  What is the variable messages?

Have a look at the Rails Guide on debugging, it will show you
techniques that you can use to debug your code and work out what is
going wrong.

Colin
Posted by Roelof Wobben (roelof)
on 2012-11-05 07:40
(Received via mailing list)
Hello,

Im initializing that file here :

def output
@output ||= Output.new
end

in the class Output.

Roelof

Op maandag 5 november 2012 00:52:22 UTC+1 schreef Matt Jones het 
volgende:
Posted by Roelof Wobben (roelof)
on 2012-11-05 10:37
(Received via mailing list)
Op zondag 4 november 2012 13:44:57 UTC+1 schreef Colin Law het volgende:
> >>
> >> > contains Ouput.new which is the same as Output.create.
>
> That is a different error message to the one you originally posted.
>
> What is the line
> messages << message
> supposed to do.  What is the variable messages?
>

The variable messages is a array containing the all the messages.
The variable message does contain the message.
I took this part of the Rspec book.



>
> Have a look at the Rails Guide on debugging, it will show you
> techniques that you can use to debug your code and work out what is
> going wrong.
>
>
I will look into it and hope I can find a solution to this problem.
Posted by Colin Law (Guest)
on 2012-11-05 11:55
(Received via mailing list)
On 4 November 2012 17:45, Roelof Wobben <rwobben@hotmail.com> wrote:
> ...
> Message come from here.
>
> Then he should see "Welcome, Aslak"
>
> Then /^he should see "(.*?)"$/ do |message|
> @output.messages.should include (message)
> end

I have no idea what you are saying now.  Is this a different problem?
If so then again post the error message and the relevant code.  Just
put the code inline here unless it is long, it is easier to comment
here than if you have put it somewhere else.  You only need to post
the relevant 10 or 20 lines.

Colin

PS Just send it to the list, no need to copy me.
Posted by Roelof Wobben (roelof)
on 2012-11-05 12:50
(Received via mailing list)
Op zondag 4 november 2012 18:52:46 UTC+1 schreef Colin Law het volgende:
> > end
>
> I have no idea what you are saying now.  Is this a different problem?
> If so then again post the error message and the relevant code.  Just
> put the code inline here unless it is long, it is easier to comment
> here than if you have put it somewhere else.  You only need to post
> the relevant 10 or 20 lines.
>
> Colin
>

No I try to answer where message is coming from.
Message is as I understand from the step-definition and should include 
the
text "Welcome asLak"

Roelof
Posted by Colin Law (Guest)
on 2012-11-05 14:27
(Received via mailing list)
On 4 November 2012 18:46, roelof <rwobben@hotmail.com> wrote:
>> > @output.messages.should include (message)
>
> No I try to answer where message is coming from.
> Message is as I understand from the step-definition and should include the
> text "Welcome asLak"

Sorry, you still have not explained the problem.  Explain what is
happening, what should be happening, and show us the code that should
do what you expect.  Without that information we can do nothing.

You are still sending a copy to me by the way, which is undesirable.

Colin
Posted by Roelof Wobben (roelof)
on 2012-11-05 14:43
(Received via mailing list)
Op zondag 4 november 2012 21:25:15 UTC+1 schreef Colin Law het volgende:
> >> > Then he should see "Welcome, Aslak"
> >>
> >> Colin
> >
> >
> > No I try to answer where message is coming from.
> > Message is as I understand from the step-definition and should include
> the
> > text "Welcome asLak"
>
> Sorry, you still have not explained the problem.  Explain what is
> happening,


What happen is that I see the error message.


> what should be happening


What schould be happen is that the message "Welcome Aslak" is being seen 
as
the user Aslak is loggin in succesfull.



> , and show us the code that should
> do what you expect.
>

I will give you the cucumber code.


Scenario: log in as existing user
Given a user "Aslak@tamarawobben.nl" exists
When he logs in
Then he should see "Welcome, Aslak"

step-definition part :


class Output
def messages
@messages ||= []
end
 def puts(message)
messages << message
end
 def output
@output ||= Output.new
end
end

Then /^he should see "(.*?)"$/ do |message|
@output.messages.should include (message)
end


Roelof
Posted by Valery Kvon (Guest)
on 2012-11-05 15:34
(Received via mailing list)
when you call @output.messages.should include (message)
@output is nil

call (@output ||= Output.new).messages.should include (message)
Posted by Colin Law (Guest)
on 2012-11-05 15:49
(Received via mailing list)
On 4 November 2012 20:40, roelof <rwobben@hotmail.com> wrote:
>> >> >
>> >> the relevant 10 or 20 lines.
>> happening,
>
> Given a user "Aslak@tamarawobben.nl" exists
> def puts(message)
> messages << message

It is difficult to help if you don't read and try to understand the
attempts to help you.  As I have said before you have not initialised
the local variable messages.  You have initialised the class instance
variable @messages, but that is not the same variable.

In addition I have asked twice if not three times that you do not send
me personally a copy of your emails.  Just send it to the list please,
I do not need two copies.

Colin
Posted by Roelof Wobben (roelof)
on 2012-11-05 15:50
(Received via mailing list)
Op maandag 5 november 2012 15:34:05 UTC+1 schreef addagger het volgende:
>
> when you call @output.messages.should include (message)
> @output is nil
>
> call (@output ||= Output.new).messages.should include (message)
>
> That worked but can you explain what this does ?

Roelof
Posted by Valery Kvon (Guest)
on 2012-11-05 15:55
(Received via mailing list)
get instance variable @output, and when its nil assigns an object 
Output.new
Posted by Darren Holland (Guest)
on 2012-11-07 14:44
(Received via mailing list)
Class for output should have been:

class Output
  def messages
    @messages ||= []
  end
  def puts(message)
    messages << message
  end
end

def output
  @output ||= Output.new
end
Posted by Matt Jones (Guest)
on 2012-11-08 16:05
(Received via mailing list)
On Monday, 5 November 2012 01:40:06 UTC-5, roelof wrote:
>
>

This method doesn't make any sense - you need to create an Output 
instance
to call it on, then it creates an Output instance. I'd suggest you 
review a
good Ruby reference to sort out your understanding of how objects work.

More to the point, what is the Output class supposed to DO? Your 
cucumber
step seemed to be expecting that messages would be sent to an Output
object, but I don't see any indication of how that was supposed to 
happen...

--Matt Jones

--Matt Jones
Please log in before posting. Registration is free and takes only a minute.
Existing account (Switch to SSL-encrypted connection)
NEW: Do you have a Google/GoogleMail or Yahoo account? No registration required!
Log in with Google account | Log in with Yahoo account
No account? Register here.