gpt4 book ai didi

ruby-on-rails-3 - Rspec/Capybara/Selenium 测试在查找不应该存在的 Assets 路径时失败

转载 作者:行者123 更新时间:2023-12-04 07:15:05 25 4
gpt4 key购买 nike

我正在创建一个使用 jstree 的 Rails 应用程序。现在我正在尝试在 rspec 测试中测试 jstree 的功能,使用 capybara 和 selenium 驱动程序(js:true)。测试是:

scenario "the object associated with the data-pane is selected in the tree", js: true do 
visit surveyor_path
using_wait_time(20) { expect(page).to have_selector("##{obj.class.name}_#{obj.id.to_s}") }
end

这是在一个shared_example中,obj是一个与测试相关的对象(在本例中是测量员)。我的 js 树应该生成 id 为“_”的节点。所以我期待像“Surveyor_1”这样的东西。

运行时出现如下错误:

Failure/Error: Unable to find matching line from backtrace
ActionController::RoutingError:
No route matches [GET] "/surveyors/themes/default/style.css"
# /Users/chrisgat/.rvm/gems/ruby-1.9.3-p194/gems/actionpack-3.2.8/lib/action_dispatch/middleware/debug_exceptions.rb:21:in `call'
# /Users/chrisgat/.rvm/gems/ruby-1.9.3-p194/gems/actionpack-3.2.8/lib/action_dispatch/middleware/show_exceptions.rb:56:in `call'
# /Users/chrisgat/.rvm/gems/ruby-1.9.3-p194/gems/railties-3.2.8/lib/rails/rack/logger.rb:26:in `call_app'
# /Users/chrisgat/.rvm/gems/ruby-1.9.3-p194/gems/railties-3.2.8/lib/rails/rack/logger.rb:16:in `call'
# /Users/chrisgat/.rvm/gems/ruby-1.9.3-p194/gems/actionpack-3.2.8/lib/action_dispatch/middleware/request_id.rb:22:in `call'
# /Users/chrisgat/.rvm/gems/ruby-1.9.3-p194/gems/rack-1.4.1/lib/rack/methodoverride.rb:21:in `call'
# /Users/chrisgat/.rvm/gems/ruby-1.9.3-p194/gems/rack-1.4.1/lib/rack/runtime.rb:17:in `call'
# /Users/chrisgat/.rvm/gems/ruby-1.9.3-p194/gems/activesupport-3.2.8/lib/active_support/cache/strategy/local_cache.rb:72:in `call'
# /Users/chrisgat/.rvm/gems/ruby-1.9.3-p194/gems/rack-1.4.1/lib/rack/lock.rb:15:in `call'
# /Users/chrisgat/.rvm/gems/ruby-1.9.3-p194/gems/actionpack-3.2.8/lib/action_dispatch/middleware/static.rb:62:in `call'
# /Users/chrisgat/.rvm/gems/ruby-1.9.3-p194/gems/railties-3.2.8/lib/rails/engine.rb:479:in `call'
# /Users/chrisgat/.rvm/gems/ruby-1.9.3-p194/gems/railties-3.2.8/lib/rails/application.rb:223:in `call'
# /Users/chrisgat/.rvm/gems/ruby-1.9.3-p194/gems/rack-1.4.1/lib/rack/builder.rb:134:in `call'
# /Users/chrisgat/.rvm/gems/ruby-1.9.3-p194/gems/rack-1.4.1/lib/rack/urlmap.rb:64:in `block in call'
# /Users/chrisgat/.rvm/gems/ruby-1.9.3-p194/gems/rack-1.4.1/lib/rack/urlmap.rb:49:in `each'
# /Users/chrisgat/.rvm/gems/ruby-1.9.3-p194/gems/rack-1.4.1/lib/rack/urlmap.rb:49:in `call'
# /Users/chrisgat/.rvm/gems/ruby-1.9.3-p194/gems/capybara-2.0.1/lib/capybara/server.rb:19:in `call'
# /Users/chrisgat/.rvm/gems/ruby-1.9.3-p194/gems/rack-1.4.1/lib/rack/handler/webrick.rb:59:in `service'
# /Users/chrisgat/.rvm/rubies/ruby-1.9.3-p194/lib/ruby/1.9.1/webrick/httpserver.rb:138:in `service'
# /Users/chrisgat/.rvm/rubies/ruby-1.9.3-p194/lib/ruby/1.9.1/webrick/httpserver.rb:94:in `run'
# /Users/chrisgat/.rvm/rubies/ruby-1.9.3-p194/lib/ruby/1.9.1/webrick/server.rb:191:in `block in start_thread'

事情是这样的,/surveyors/themes/default/style.css 首先不应该是一条路线。它正在寻找的 Assets 位于 assets/themes/default/style.css 中。这是一个 js-tree 特定的样式表。在测试中插入一些调试器语句,我可以验证页面确实有选择器。如果页面确实有选择器,我只会得到异常......也就是说,如果我将 have_selector 的内容更改为 “BadSelector”,测试将定期失败(没有找到选择器)。 js-tree 功能在手动查看时有效。

预先感谢您的帮助

Rails 3.2.8 Rspec 2.12 capybara 2.0

最佳答案

Echo,这里有人吗?不,看起来我在给自己写信。

如果其他人遇到此问题,我确实找到了解决方法,但我不能 100% 确定根本原因。当我“安装”jstree 时,我只是将它转储到 Assets 管道 (javascript) 中。这在开发中运行良好,但在测试中运行不佳(见上文)。 Jstree 使用其主题插件加载样式表,而不是将它们直接放在样式表文件夹中。在测试中,无论出于何种原因,它生成的路径都以当前页面的路径为前缀。我使用 jstree rails gem 解决了这个问题,它明确引用了用于样式表的目录。问题解决了。

关于ruby-on-rails-3 - Rspec/Capybara/Selenium 测试在查找不应该存在的 Assets 路径时失败,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13942428/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com