草庐IT

Selenium元素定位

全部标签

ruby - selenium webdriver 异常

我在使用Seleniumwebdriver时遇到错误。我的平台是macOS。这是我的异常日志。ruby-1.9.2-p0>Selenium::WebDriver.for:firefoxSelenium::WebDriver::Error::WebDriverError:unabletobindtolockingport7054within45secondsfrom/Users/Apple/.rvm/gems/ruby-1.9.2-p0/gems/selenium-webdriver-0.1.0/lib/selenium/webdriver/firefox/socket_lock.rb:

arrays - 从数组中删除并返回 Ruby 中删除的元素

如何从数组中删除一些元素并选择它们?例如:classFoodefinitialize@a=[1,2,3,4,5,6,7,8,9]enddefget_areturn@aendendfoo=Foo.newb=foo.get_a.sth{|e|e[1,2,3]pfoo.get_a#=>[4,5,6,7,8,9,10]我可以用什么代替foo.get_a.sth? 最佳答案 如果不需要保留a的对象id:a=[1,2,3,4,5,6,7,8,9,10]b,a=a.partition{|e|e[1,2,3]a#=>[4,5,6,7,8,9,10]

arrays - 过滤以从数组中排除元素

尝试从数组中过滤一些条目。不能保证它们在master数组中,所以我正在通过迭代进行测试。total=['alpha','bravo','charlie','delta','echo']hide=['charlie','echo']pick=[]foriintotalif!hide.include?(i)putsipick.push(i)endendputspick这是行不通的。有没有更好的方法来提供这种过滤器? 最佳答案 Ruby允许您在两个数组上使用公共(public)实例方法来获取它们的相交或互斥元素:a1=['alpha','

ruby - 在 W3C 模式下(Selenium::WebDriver::Error::UnknownCommandError)无法在 Cucumber Ruby 中使用 Selenium ChromeDriver 调用非 W3C 标准命令

我们有CucumberRuby自动化框架,我们在Jenkins上的Docker中对Chromeheadless浏览器运行了一些测试。几天前,我们开始收到错误“此版本的ChromeDriver仅支持Chrome版本75”,这次我们使用ChromeDriver2.46并使用以下命令使用google-chrome-unstable浏览器:#ChromeRUNwget-q-O-https://dl-ssl.google.com/linux/linux_signing_key.pub|apt-keyadd-RUNecho"debhttp://dl.google.com/linux/chrome/

ruby-on-rails - Ruby - 数组 A 是否包含数组 B 的所有元素

这个问题在这里已经有了答案:Howtodetermineifonearraycontainsallelementsofanotherarray(8个答案)关闭3年前。有什么方法可以检查数组A是否包含数组B的所有元素?

ruby - 即使在 selenium ruby​​ 脚本完成后如何让浏览器保持打开状态

我正在使用带有selenium网络驱动程序的ruby​​脚本来自动登录网页。问题是脚本完成后它也会关闭浏览器。即使在脚本完成后,我也想保持浏览器打开。有什么方法可以让我在测试后对浏览器窗口执行其他操作后保持浏览器打开?我就是这样做的。ifbrowser=="Firefox"driver=Selenium::WebDriver.for:firefoxendifstack=="example.com"driver.get"http://www.example.com/tests/endelement=driver.find_element:name=>"email"element.clea

ruby:如何在数组中找到非唯一元素并打印每个元素的出现次数?

我有a=["a","d","c","b","b","c","c"]并且需要打印类似的东西(按出现次数降序排列):c:3b:2我理解第一部分(发现非唯一)是:b=a.select{|e|a.count(e)>1}=>["c","b","b","c","c"]或putsb.select{|e,c|[e,a.count(e)]}.uniqcb如何按出现次数倒序输出每个非唯一值? 最佳答案 putsa.uniq.map{|e|[a.count(e),e]}.select{|c,_|c>1}.sort.reverse.map{|c,e|"#{

ruby - 使用 Poltergeist 时如何获取元素的 HTML?

我正在使用带有Poltergeist驱动程序的Capybara。我的问题是:如何获取节点的HTML(字符串)?我读到过使用RackTest驱动程序你可以像这样得到它:find("table").native#=>nativeNokogirielementfind("table").native.to_html#=>"..."但是Poltergeist在节点上调用#native会返回Capybara::Poltergeist::Node,而不是原生的Nokogiri元素。然后在Capybara::Poltergeist::Node上再次调用#native再次返回相同的Capybara::

ruby - 使用 Nokogiri 插入和删除 XML 节点和元素

我想提取XML文件的一部分,并记下我提取了该文件中的某些部分,例如“这里提取了一些东西”。我正尝试用Nokogiri来做这件事,但似乎并没有真正记录如何:删除的所有child更改inner_text那个完整的元素有什么线索吗? 最佳答案 Nokogiri让这一切变得非常简单。使用thisdocument例如,以下代码将找到所有vitamins标签,删除它们的子标签(以及子标签的子标签等),并将它们的内部文本更改为“Childrenremoved”。require'nokogiri'io=File.open('sample.xml',

ruby - cucumber / capybara vs Selenium ?

关闭。这个问题是opinion-based.它目前不接受答案。想要改进这个问题?更新问题,以便editingthispost可以用事实和引用来回答它.关闭8年前。Improvethisquestion前几天,我向我公司的一位测试人员展示了我用Cucumber编写的一些测试(2个功能,5个场景)。然后他问了我无法回答的问题:Howisthisbetterthanseleniumoranyotherfunctionalitytestrecordingtool?我知道Cucumber是一种不同的技术,它处于不同的测试级别,但我不明白为什么我要费心编写和维护Cucumber/Capybara测