Cucumber,Capybara,Rails 3,302发现重定向问题

时间:2011-05-06 20:18:35

标签: ruby-on-rails-3 cucumber capybara http-status-code-302

我是Capybara的新手,但我正在尝试用它来测试(用黄瓜)我正在从rails 2转换为rails 3的应用程序。但是,我在测试登录时会遇到奇怪的行为。我有一个黄瓜登录执行以下操作的步骤:

visit login_path
fill_in 'Email', :with => 'test@example.com'
fill_in 'Password', :with => 'XXXXXXXXX'
click_button 'Log in'

当这个自定义步骤运行时,黄瓜会给我以下错误:

  
    

找不到UserSessionsController的动作'index'     一个AbstractController :: ActionNotFound)

  

日志输出如下:

Started GET "/login" for 127.0.0.1 at Fri May 06 15:48:42 -0400 2011
Processing by UserSessionsController#new as HTML
Redirected to https://www.example.com/login
Completed 302 Found in 1ms

Started GET "/login" for 127.0.0.1 at Fri May 06 15:48:42 -0400 2011
Processing by UserSessionsController#new as HTML
Rendered user_sessions/new.html.erb within layouts/promo (15.8ms)
Completed 200 OK in 38ms (Views: 24.5ms | ActiveRecord: 2.9ms)

Started POST "/user_sessions" for 127.0.0.1 at Fri May 06 15:48:42 -0400 2011
Processing by UserSessionsController#create as HTML
Parameters: {"commit"=>"Log in", "user_session"=>{"password"=>"[FILTERED]", "email"=>"test@example.com"}, "utf8"=>"✓"}
Redirected to https://www.example.com/user_sessions
Completed 302 Found in 1ms

Started GET "/user_sessions" for 127.0.0.1 at Fri May 06 15:48:42 -0400 2011 
SQL (0.6ms)  ROLLBACK

所以这是我的问题:
为什么/ login GET然后重定向到/ login ??? 为什么POST到/ user_sessions也会被重定向到自身(导致我看到的错误)???

一切都在开发中完美无缺,我看不到302状态代码。它可能很简单,但我没有看到它。

编辑: 提交后5分钟,我意识到这是导致重定向的SSL_requirement插件。当我注释掉“ssl_required”时,测试通过了。我将不得不对Capybara进行更多的研究,以找出如何配置它,除非有人提出答案。

编辑答案(因为它不会让我发布一个8小时): 我找到了答案。正如我在编辑中所述,问题是由于SSL要求而导致的重定向。可以在此处找到对问题的非常好的描述:https://github.com/jnicklas/capybara/issues/85。目前的解决方案是一个适合我的补丁,可以在这里找到:https://gist.github.com/466411

1 个答案:

答案 0 :(得分:1)

我找到了答案。正如我在编辑中所述,问题是由于SSL要求而导致的重定向。可以在此处找到对问题的非常好的描述:https://github.com/jnicklas/capybara/issues/85。目前的解决方案是一个适合我的补丁,可以在这里找到:https://gist.github.com/466411