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