草庐IT

Selenium原理

全部标签

ruby - 如何在 selenium-webdriver 中获取网页的当前 URL

我正在使用seleniumwebdriver在浏览器上做一些自动化。现在需要获取当前在浏览器中打开的页面的当前url。我写了下面的代码但是给我错误:element=driver.find_element:name=>"btnSearch"element.clickall_table_data=driver.find_elements(:tag_name,"td")all_table_data.eachdo|td|putstd.textendprintdriver.get_url但它给我一个错误:filedownload.rb:30:in`':undefinedmethod`get_ur

ruby-on-rails - Ruby - 无法在 45 秒内绑定(bind)到锁定端口 7054 (Selenium::WebDriver::Error::WebDriverError)

我最近开始在尝试运行任何Cucumber测试时看到此错误消息。我做了一些研究并发现了其他一些类似的此错误实例,但其中大多数是与浏览器相关的问题。我在此输出中没有看到任何特定于浏览器的错误消息:unabletobindtolockingport7054within45seconds(Selenium::WebDriver::Error::WebDriverError)我看到这里发布的另一个问题已得到解答(Aseleniumwebdriverexception),但该解决方案对我不起作用。运行“lsof-iTCP:7054”不会产生任何输出。以防万一有人提出这个建议,我已经多次重启我的机器

mysql - Rails 数据库连接池的工作原理

我正在学习Rails数据库连接池概念。在Rails应用程序中,我将池大小定义为5。我对连接池大小的理解如下。当服务器启动时,rails会自动创建n个在database.yml文件中定义的连接。在我的例子中,它将创建5个连接,因为池大小为5。在每个http请求上,如果需要访问数据库,rails将使用连接池中的可用连接来处理请求。但我的问题是,如果我一次达到1000个请求,那么大部分请求将无法访问数据库连接,因为我的连接池大小只有5个。我上面对rails连接池的理解对吗??谢谢, 最佳答案 目的:数据库连接不是线程安全的;所以Activ

ElasticSearch——刷盘原理流程

ElasticSearch——刷盘原理流程刷盘原理流程名词和操作解释相关设置刷盘原理流程整个过程会分成几步:数据会同时写入buffer缓冲区和translog日志文件buffer缓冲区满了或者到时间了(默认1s),就会将其中的数据转换成新的segment并写入系统文件缓存,这一步叫refresh其中后台会自动合并小的segment成大的segment;这一步叫段合并当translog达到大小的阈值(默认512M)或者flush默认时长(30m),则会执行flush操作:内存中数据写入新的segment放入缓存(清空内存区)一个commitpoint写入磁盘,表示哪些segment已写入磁盘将缓

ruby - 我如何在 Ruby 中使用 Selenium ?

我用FirefoxSelenium做了一些测试,然后将它导出到Ruby。尽管测试在Firefox中运行良好,但我在Ruby中运行相同的套件时遇到了问题。我尝试运行他们拥有的示例程序之一,但我也遇到了相同的连接被拒绝错误。这是我在尝试运行他们的google_test套件时遇到的错误。tellingsen$rubygoogle_test.rbLoadedsuitegoogle_testStartedEFinishedin0.001558seconds.1)Error:test_page_search(ExampleTest):Errno::ECONNREFUSED:Connectionre

ruby-on-rails - Ruby selenium webdriver 无法找到 Mozilla geckodriver

我在我的开发目录中安装了geckodriverls|grepgeckodrivergeckodrivergeckodriver-v0.11.1-linux64.tar.gz我还导出到$PATH变量exportPATH=$PATH:~/Development/geckodriver但是当我尝试在项目的rails控制台上初始化webdriver的实例时,我得到了这个driver=Selenium::WebDriver.for:firefoxSelenium::WebDriver::Error::WebDriverError:UnabletofindMozillageckodriver.Pl

ruby - Selenium 滚动元素进入(中心) View

当一个元素在selenium的View之外并且试图与之交互时,selenium通常会首先隐式地将元素滚动到View中。这很棒,只是烦人的是它通常将元素放入View中。我的意思是,如果元素位于窗口下方,它会向下滚动足够多直到元素刚好与窗口边缘接壤。通常这很好,但是当在周围有边框的网站上工作时,这将导致许多此类错误Selenium::WebDriver::Error::UnknownError:unknownerror:Elementisnotclickableatpoint(438,747).Otherelementwouldreceivetheclick:...因为通常网页的边框都在它

ruby - selenium 2.4.0,如何检查是否存在警报

在使用selenium2.4.0之前,我使用了以下代码:alert=page.driver.browser.switch_to.alertifalert.text....endSelenium2.4.0包含更改“*当没有警报时在switch_to.alert中提升。”,所以我得到一个Noalertispresent(Selenium::WebDriver::Error::NoAlertOpenError)异常。如何使用selenium-web-driver2.4.0检查是否存在警报? 最佳答案 这是一个选项:driver.switc

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:

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/