2013-05-09 86 views
0

使用:導軌3.2.13,黃瓜(1.2.3),硒 - 的webdriver(2.31.0),水豚(2.0.3)滑軌+黃瓜+硒:測試失敗一起,分別傳遞

我在移動網站上工作,需要使用硒來測試JavaScript功能。然而,當我嘗試運行黃瓜測試一起,緊隨@javascript標記測試的測試與此失敗:

 The action 'assets' could not be found for SiteController (AbstractController::ActionNotFound) 
     /Users/emai/.rvm/gems/[email protected]/gems/actionpack-3.2.13/lib/abstract_controller/base.rb:116:in `process' 
     /Users/emai/.rvm/gems/[email protected]/gems/actionpack-3.2.13/lib/abstract_controller/rendering.rb:45:in `process' 
     /Users/emai/.rvm/gems/[email protected]/gems/actionpack-3.2.13/lib/action_controller/metal.rb:203:in `dispatch' 
     /Users/emai/.rvm/gems/[email protected]/gems/actionpack-3.2.13/lib/action_controller/metal/rack_delegation.rb:14:in `dispatch' 
     /Users/emai/.rvm/gems/[email protected]/gems/actionpack-3.2.13/lib/action_controller/metal.rb:246:in `block in action' 
     /Users/emai/.rvm/gems/[email protected]/gems/actionpack-3.2.13/lib/action_dispatch/routing/route_set.rb:73:in `call' 
     /Users/emai/.rvm/gems/[email protected]/gems/actionpack-3.2.13/lib/action_dispatch/routing/route_set.rb:73:in `dispatch' 
     /Users/emai/.rvm/gems/[email protected]/gems/actionpack-3.2.13/lib/action_dispatch/routing/route_set.rb:36:in `call' 
     /Users/emai/.rvm/gems/[email protected]/gems/journey-1.0.4/lib/journey/router.rb:68:in `block in call' 
     /Users/emai/.rvm/gems/[email protected]/gems/journey-1.0.4/lib/journey/router.rb:56:in `each' 
     /Users/emai/.rvm/gems/[email protected]/gems/journey-1.0.4/lib/journey/router.rb:56:in `call' 
     /Users/emai/.rvm/gems/[email protected]/gems/actionpack-3.2.13/lib/action_dispatch/routing/route_set.rb:612:in `call' 
     /Users/emai/.rvm/gems/[email protected]/gems/warden-1.2.1/lib/warden/manager.rb:35:in `block in call' 
     /Users/emai/.rvm/gems/[email protected]/gems/warden-1.2.1/lib/warden/manager.rb:34:in `catch' 
     /Users/emai/.rvm/gems/[email protected]/gems/warden-1.2.1/lib/warden/manager.rb:34:in `call' 
     /Users/emai/.rvm/gems/[email protected]/gems/actionpack-3.2.13/lib/action_dispatch/middleware/best_standards_support.rb:17:in `call' 
     /Users/emai/.rvm/gems/[email protected]/gems/rack-1.4.5/lib/rack/etag.rb:23:in `call' 
     /Users/emai/.rvm/gems/[email protected]/gems/rack-1.4.5/lib/rack/conditionalget.rb:25:in `call' 
     /Users/emai/.rvm/gems/[email protected]/gems/actionpack-3.2.13/lib/action_dispatch/middleware/head.rb:14:in `call' 
     /Users/emai/.rvm/gems/[email protected]/gems/actionpack-3.2.13/lib/action_dispatch/middleware/params_parser.rb:21:in `call' 
     /Users/emai/.rvm/gems/[email protected]/gems/actionpack-3.2.13/lib/action_dispatch/middleware/flash.rb:242:in `call' 
     /Users/emai/.rvm/gems/[email protected]/gems/rack-1.4.5/lib/rack/session/abstract/id.rb:210:in `context' 
     /Users/emai/.rvm/gems/[email protected]sherry3/gems/rack-1.4.5/lib/rack/session/abstract/id.rb:205:in `call' 
     /Users/emai/.rvm/gems/[email protected]/gems/actionpack-3.2.13/lib/action_dispatch/middleware/cookies.rb:341:in `call' 
     /Users/emai/.rvm/gems/[email protected]/gems/activerecord-3.2.13/lib/active_record/query_cache.rb:64:in `call' 
     /Users/emai/.rvm/gems/[email protected]/gems/activerecord-3.2.13/lib/active_record/connection_adapters/abstract/connection_pool.rb:479:in `call' 
     /Users/emai/.rvm/gems/[email protected]/gems/actionpack-3.2.13/lib/action_dispatch/middleware/callbacks.rb:28:in `block in call' 
     /Users/emai/.rvm/gems/[email protected]/gems/activesupport-3.2.13/lib/active_support/callbacks.rb:405:in `_run__1123647381172448721__call__979271738568178806__callbacks' 
     /Users/emai/.rvm/gems/[email protected]/gems/activesupport-3.2.13/lib/active_support/callbacks.rb:405:in `__run_callback' 
     /Users/emai/.rvm/gems/[email protected]/gems/activesupport-3.2.13/lib/active_support/callbacks.rb:385:in `_run_call_callbacks' 
     /Users/emai/.rvm/gems/[email protected]/gems/activesupport-3.2.13/lib/active_support/callbacks.rb:81:in `run_callbacks' 
     /Users/emai/.rvm/gems/[email protected]/gems/actionpack-3.2.13/lib/action_dispatch/middleware/callbacks.rb:27:in `call' 
     /Users/emai/.rvm/gems/[email protected]/gems/actionpack-3.2.13/lib/action_dispatch/middleware/remote_ip.rb:31:in `call' 
     /Users/emai/.rvm/gems/[email protected]/gems/actionpack-3.2.13/lib/action_dispatch/middleware/debug_exceptions.rb:16:in `call' 
     /Users/emai/.rvm/gems/[email protected]/gems/actionpack-3.2.13/lib/action_dispatch/middleware/show_exceptions.rb:56:in `call' 
     /Users/emai/.rvm/gems/[email protected]/gems/cucumber-rails-1.3.1/lib/cucumber/rails/action_controller.rb:10:in `call' 
     /Users/emai/.rvm/gems/[email protected]/gems/railties-3.2.13/lib/rails/rack/logger.rb:32:in `call_app' 
     /Users/emai/.rvm/gems/[email protected]/gems/railties-3.2.13/lib/rails/rack/logger.rb:16:in `block in call' 
     /Users/emai/.rvm/gems/[email protected]/gems/activesupport-3.2.13/lib/active_support/tagged_logging.rb:22:in `tagged' 
     /Users/emai/.rvm/gems/[email protected]/gems/railties-3.2.13/lib/rails/rack/logger.rb:16:in `call' 
     /Users/emai/.rvm/gems/[email protected]/gems/actionpack-3.2.13/lib/action_dispatch/middleware/request_id.rb:22:in `call' 
     /Users/emai/.rvm/gems/[email protected]/gems/rack-1.4.5/lib/rack/methodoverride.rb:21:in `call' 
     /Users/emai/.rvm/gems/[email protected]/gems/rack-1.4.5/lib/rack/runtime.rb:17:in `call' 
     /Users/emai/.rvm/gems/[email protected]/gems/activesupport-3.2.13/lib/active_support/cache/strategy/local_cache.rb:72:in `call' 
     /Users/emai/.rvm/gems/[email protected]/gems/rack-1.4.5/lib/rack/lock.rb:15:in `call' 
     /Users/emai/.rvm/gems/[email protected]/gems/actionpack-3.2.13/lib/action_dispatch/middleware/static.rb:63:in `call' 
     /Users/emai/.rvm/gems/[email protected]/gems/railties-3.2.13/lib/rails/engine.rb:479:in `call' 
     /Users/emai/.rvm/gems/[email protected]/gems/railties-3.2.13/lib/rails/application.rb:223:in `call' 
     /Users/emai/.rvm/gems/[email protected]/gems/rack-1.4.5/lib/rack/builder.rb:134:in `call' 
     /Users/emai/.rvm/gems/[email protected]/gems/rack-1.4.5/lib/rack/urlmap.rb:64:in `block in call' 
     /Users/emai/.rvm/gems/[email protected]/gems/rack-1.4.5/lib/rack/urlmap.rb:49:in `each' 
     /Users/emai/.rvm/gems/[email protected]/gems/rack-1.4.5/lib/rack/urlmap.rb:49:in `call' 
     /Users/emai/.rvm/gems/[email protected]/gems/capybara-2.0.3/lib/capybara/server.rb:19:in `call' 
     /Users/emai/.rvm/gems/[email protected]/gems/rack-1.4.5/lib/rack/handler/webrick.rb:59:in `service' 
     /Users/emai/.rvm/rubies/ruby-1.9.3-p362/lib/ruby/1.9.1/webrick/httpserver.rb:138:in `service' 
     /Users/emai/.rvm/rubies/ruby-1.9.3-p362/lib/ruby/1.9.1/webrick/httpserver.rb:94:in `run' 
     /Users/emai/.rvm/rubies/ruby-1.9.3-p362/lib/ruby/1.9.1/webrick/server.rb:191:in `block in start_thread' 

我猜東西在我的通配符路線match ':action(/:id)' => "site"被觸發assets。但是,當我在textmate中執行command + shift + F(在整個項目中查找關鍵字)時,我只能在視圖中找到對資產的一個引用,並且對它進行註釋並不會執行任何操作。

我也嘗試過改變黃瓜在我的ENV文件中使用截斷,而不是交易:

來源: Cucumber::Rails::Database.javascript_strategy = :transaction 到: Cucumber::Rails::Database.javascript_strategy = :truncation

,但沒有奏效。這是一個錯誤?或者我的測試/視圖有問題嗎?硒還有另一種選擇,我可以嘗試使用JavaScript進行測試嗎?

更新:試圖安裝capybara-webkit,但遇到錯誤。

Nets-Mac-Pro:sl-mobile emai$ bundle install 
    ... 
    ... 

    Gem::Installer::ExtensionBuildError: ERROR: Failed to build gem native extension. 

      /Users/emai/.rvm/rubies/ruby-1.9.3-p362/bin/ruby extconf.rb 
    Command 'qmake -spec macx-g++' not available 


    Gem files will remain installed in /Users/emai/.rvm/gems/[email protected]/gems/capybara-webkit-0.14.2 for inspection. 
    Results logged to /Users/emai/.rvm/gems/[email protected]/gems/capybara-webkit-0.14.2/./gem_make.out 
+0

我使用[capybara-webkit](https://github.com/thoughtbot/capybara-webkit) – cortex 2013-05-09 14:08:29

+0

我試過安裝它,但它給了我一個錯誤。我會粘貼它 – Edmund 2013-05-09 14:12:35

+0

嘗試[this](http://stackoverflow.com/questions/8365764/error-installing-gem-capybara-webkit/11570002#11570002)或[this](http://stackoverflow.com/問題/ 11354656 /錯誤錯誤錯誤安裝,水豚,WebKit的/ 11622193#11622193)。 – cortex 2013-05-09 14:27:20

回答

0

所以我最終搞明白了。黃瓜失敗了,因爲還沒有從我的舊項目中遷移過來的圖像(我將這個項目從Rails 2升級到Rails 3,所以很多文件還沒有移動過)。我有指向這些圖像的常量,當這些資產沒有找到時,它導致Cucumber失敗。所以要警告!