如何从此回复中获取状态?

时间:2012-02-15 22:38:49

标签: ruby-on-rails ruby rspec httpwebrequest

我试图给一些宝石写简单的测试:https://github.com/regedarek/soup-client

我在控制台中运行时有这个响应:

    ruby-1.9.2-p290 :022 > c.login
    I, [2012-02-15T23:12:09.681772 #12908] INFO -- : post https://www.soup.io/login
    D, [2012-02-15T23:12:09.681854 #12908] DEBUG -- request: Content-Type: "application/x-www-form-urlencoded"
    I, [2012-02-15T23:12:10.157908 #12908] INFO -- Status: 302
    D, [2012-02-15T23:12:10.158054 #12908] DEBUG -- response: server: "nginx/0.7.67"
    date: "Wed, 15 Feb 2012 22:12:11 GMT"
    content-type: "text/html; charset=utf-8"
    connection: "close"
    ...
    content-length: "94"
    status: "302"
    ...
    location: "http://soup-client.soup.io/?sessid=995f610405f8afe029b9038da6c22132"
    content-length: "0"
    status: "302"
    ...
    set-cookie: "soup_session_id=995f610405f8afe029b9038da6c22132; path=/; expires=Sun, 15 Feb 2032 22:12:13 GMT; HttpOnly"
    status: "200"
    content-length: "16024"

我想对此进行测试,但如何从此响应中获取状态?

我已经尝试了c.login["status"].should == 200,但它无效:

ruby-1.9.2-p290 :025 >   c.login["status"]

...

status: "200"
vary: "Accept-Encoding"
content-length: "15700"
NoMethodError: undefined method `[]' for nil:NilClass
    from (irb):25
    from /home/rege/.rvm/rubies/ruby-1.9.2-p290/bin/irb:16:in `<main>'

这是c.login.inspect - &gt;的输出。 https://gist.github.com/1842529

1 个答案:

答案 0 :(得分:0)

当你标记rspec时,我会给你一个rspec答案:

get '/login'
last_response.status.should == 200