3

jstreeを利用したRailsアプリを作成しています。現在、selenium ドライバー (js: true) でカピバラを使用して、rspec テストで jstree の機能をテストしようとしています。テストは次のとおりです。

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/themes/default/style.cssます。これは js-tree 固有のスタイル シートです。テストでいくつかのデバッガー ステートメントをプラグインすると、ページにセレクターがあることを確認できます。ページにセレクターがある場合にのみ例外が発生します...つまり、の内容をに変更するhave_selector"BadSelector"、テストは定期的に失敗します(セレクターが見つかりませんでした)。js-tree 機能は、手動で表示すると機能します。

よろしくお願いいたします。

Rails 3.2.8 Rspec 2.12 カピバラ 2.0

4

1 に答える 1

3

エコー、誰かここにいますか?いいえ、私は自分自身に書いているようです。

他の誰かがこの問題に遭遇した場合、根本的な原因を 100% 確信しているわけではありませんが、私はそれを修正する方法を見つけました。jstree を「インストール」したとき、単純にアセット パイプライン (javascript) にダンプしました。これは開発では問題なく機能しましたが、テストでは機能しませんでした (上記を参照)。Jstree は、テーマ プラグインを使用して、スタイル シートをスタイルシート フォルダーに直接配置するのではなく、スタイル シートを読み込みます。テストでは、何らかの理由で、生成されたパスが現在のページのパスの前に付けられます。スタイルシートに使用するディレクトリを明示的に参照するjstree rails gemを使用して、これを回避しました。問題が解決しました。

于 2012-12-27T22:39:51.620 に答える