Cucumber / Capybara错误:arguments [0]未定义(Selenium :: WebDriver :: Error :: JavascriptError)

时间:2015-01-15 09:16:46

标签: ruby selenium cucumber capybara capybara-webkit

我一直在终端上运行我的测试一段时间没有任何问题。:

黄瓜创造\新\ Game.feature

其中包含以下内容:

Feature: Create New Game

  Background: 
    Given I am logged in

  Scenario: Cleanup & New Game 01
    Then I Delete all test Games

红宝石:

Given(/^I am logged in$/) do
  el = first("button[ttag='account_dropdown_btn']", :visible => true)
  if el.nil?
    logMeIn("user@user1.com","pa55w0rd")
  end
end

logMeIn定义为:

# Logs the user in with given credentials
def logMeIn(username, password)
  page.driver.browser.manage.window.maximize
  visit ENV['BASE_URL']
  fill_in 'j_username', :with => username
  fill_in 'j_password', :with => password
  click_button 'Login'
end

以上都没有从测试工作到现在发生变化。 今天,当我开始测试时,一旦Firefox打开,我立即得到:

  Background:            # features/Create New Game.feature:4
    Given I am logged in # features/step_definitions/Generic Steps.rb:1
      arguments[0] is undefined (Selenium::WebDriver::Error::JavascriptError)

正如你所看到的,它在第一行失败了。我不知道为什么。

我更新了所有宝石,以确保一切都很新鲜,但这不起作用。我认为这可能是一个浏览器问题,因为我的系统今天早上自动更新到Firefox 35.0。我卸载并尝试了34但它仍然是同样的问题。这些代码都没有改变。

我不知道其他什么错误配置可能导致这种情况,因为我没有改变任何东西。

任何人都可以帮助进一步解决此错误吗?

4 个答案:

答案 0 :(得分:17)

是的,问题在于Firefox 35.降级到版本34.也许这就是你降级的方式。我只是运行新的DMG安装程序并确认覆盖现有的应用程序。

直接链接:https://download-installer.cdn.mozilla.net/pub/firefox/releases/34.0.5/mac/en-US/Firefox%2034.0.5.dmg(从https://support.mozilla.org/en-US/kb/install-older-version-of-firefox引用的链接)

有关此问题的更多信息,请访问:https://code.google.com/p/selenium/issues/detail?id=8387

答案 1 :(得分:4)

正如Justin Ko所述,这是Firefox 35和Selenium-WebDriver 2.44.0的错误。 Selenium项目有一张发行票,在撰写本文时,还有一个包含修复程序的预发布gem(2.45.0.dev3)。

https://code.google.com/p/selenium/issues/detail?id=8390

答案 2 :(得分:3)

正如其他人所说,Firefox 35中存在错误。 为避免这种情况,我发现配置Capybara在Chrome中运行Selenium测试最容易。因此,如果您不需要在Firefox中运行测试,则可以使用chromedriver。

有一个gem可以轻松搞定。

答案 3 :(得分:0)

这里的firefox驱动程序也有同样的问题。

Caused by: org.openqa.selenium.WebDriverException: arguments[0] is undefined
Command duration or timeout: 24 milliseconds
Build info: version: '2.44.0', revision: '76d78cf323ce037c5f92db6c1bba601c2ac43ad8', time: '2014-10-23 13:11:40'
System info: host: '', ip: '', os.name: 'Windows 7', os.arch: 'amd64', os.version: '6.1', java.version: '1.7.0_71'
Session ID: 49a4f55c-33b7-4ab8-aea5-cb3bb98041e1
Driver info: org.openqa.selenium.firefox.FirefoxDriver
Capabilities [{platform=WINDOWS, acceptSslCerts=true, javascriptEnabled=true, cssSelectorsEnabled=true, databaseEnabled=true, browserName=firefox, handlesAlerts=true, nativeEvents=false, webStorageEnabled=true, rotatable=false, locationContextEnabled=true, applicationCacheEnabled=true, takesScreenshot=true, version=35.0.1}]
    at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method)
    at sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:57)
    at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:45)
    at java.lang.reflect.Constructor.newInstance(Constructor.java:526)
    at org.openqa.selenium.remote.ErrorHandler.createThrowable(ErrorHandler.java:204)
    at org.openqa.selenium.remote.ErrorHandler.throwIfResponseFailed(ErrorHandler.java:156)
    at org.openqa.selenium.remote.RemoteWebDriver.execute(RemoteWebDriver.java:599)
    at org.openqa.selenium.remote.RemoteWebDriver.executeScript(RemoteWebDriver.java:508)

将firefox降级为34.0.5并点击Javascript:

executeScript("arguments[0].click();", el);

再次像魅力一样工作。

点击工作是非常重要的,因为本机点击太不可靠了。