jjzjj

selenium-server

全部标签

ruby - 在缓存中找不到元素 - 页面可能在查找后发生了变化(Selenium::WebDriver::Error::StaleElementReferenceError)

我正在尝试单击stackoveflow水平菜单上的所有链接(问题、标签、用户、徽章、未回答)。我有这段代码,但它点击了第一个链接(这个链接是问题),然后打印1,然后出现错误。这可能有什么问题?require'watir-webdriver'classStackoverflowdefclick_all_nav_linksb=Watir::Browser.newb.goto"http://stackoverflow.com"counter=0b.div(:id=>'hmenus').div(:class=>'navmainnavs').ul.lis.eachdo|li|li.a.click

ruby-on-rails - 使用 `rails server` 和 `rackup` 有什么区别?

我注意到的唯一区别是railsserver在端口3000上启动服务器,而rackup在端口9292上启动服务器。还有其他区别吗?是否有一个而不是另一个的用例? 最佳答案 railsserver是启动服务器(通常是WEBrick)的命令,位于rails中。.rackup是rack附带的命令中间并使用config.ru中的设置并根据这些设置启动服务器。这是一个标准(它将适用于其他框架和基于Rack的应用程序)并且通常用于生产服务器。需要注意的一个区别是,如果您使用railss启动服务器,那么您将在终端中看到输出。根据我的经验,在生产中,

ruby - 无法使用 ruby​​ selenium webdriver 连接到浏览器

我尝试使用ruby​​seleniumwebdriver运行一些基本的自动化测试。相同的代码在我的家用电脑上运行良好,但在我的工作电脑上运行失败,因为它位于代理(不需要身份验证)之后。driver=Selenium::WebDriver.for:firefox,:profile=>'默认'我得到的错误是:C:/Ruby193/lib/ruby/gems/1.9.1/gems/selenium-webdriver-2.24.0/lib/selenium/webdriver/remote/http/common.rb:66:in`create_response':unexpectedres

ruby-on-rails - 有没有办法做类似 rails server --sandbox 的事情?

有没有办法在沙盒模式下运行railsserver?我希望在服务器停止后回滚在Rails应用程序上所做的所有更改。例如,执行命令railsconsole--sandbox。 最佳答案 没有内置方法可以做到这一点。您可以在沙盒模式(railsc-s)中启动Rails控制台,但不能在服务器中启动。但是...如果您想要回滚的更改只是您数据中的更改,您只需编写种子数据并在每次运行服务器时用它们填充数据库。 关于ruby-on-rails-有没有办法做类似railsserver--sandbox的事

ruby - 使用 Cucumber 或 RSpec+Selenium 创建最终用户文档?

关闭。这个问题不符合StackOverflowguidelines.它目前不接受答案。我们不允许提问寻求书籍、工具、软件库等的推荐。您可以编辑问题,以便用事实和引用来回答。关闭4年前。Improvethisquestion有没有人尝试从您的cucumber场景中创建最终用户(可能在线,可能打印)帮助/文档?或者使用RSpec和SeleniumRC的功能截取屏幕截图以用于文档?对于Cucumber,我想象的是这样的:Scenario:IfyouwanttoaddalinkGivenIamontheeditblogpostpageWhenIpressthe"addlink"buttonAn

ruby - 卡皮斯特拉诺 3 : use server custom variable in task

我有多阶段多服务器设置,在我的任务中我需要使用服务器名称例如在stagin.rb我有:set:stage,:staging#Defineserversserver'xxx.xx.xx.xxx',user:'deploy',roles:%w{app},name:'app1'server'xxx.xx.xx.yyy',user:'deploy',roles:%w{app},name:'app2'我想在我的任务中使用那个“名称”变量:task:configuredoonroles(:app),in::paralleldo#howdoIgetservernamehere?endend

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 - 是否可以在 Heroku Cedar 上运行 capybara-webkit(即 fork 的 webkit_server)?

我需要在Rails应用程序中运行capybara-webkit以启用带有JavaScript支持的headlessWeb浏览(即不用于测试/CI目的,webrat或其他验收测试驱动程序/框架将不起作用)。我想知道这在Heroku部署中是否可行,特别是因为它需要QtWebKit以及通过套接字通信forkwebkit_server进程的能力。我愿意接受关于如何在Heroku上进行这项工作的创造性想法(例如,一组workerdynos)。我希望有人能更好地处理Heroku环境中存在的限制,或者可以断然排除这种可能性,这样我就可以在必要时转向AWSEC2。搜索这个往往会发现很多关于CI服务器的

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

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

ruby - 从 Ruby 中的 Capybara 运行时,webkit_server 会定期挂起

我遇到了一个问题,当访问一个URL时,带有Capybara和capybara-webkit的webkit_server实例在headless连接到本地Xvfb屏幕时挂起。这似乎是在反复访问不同的URL并执行查找程序几分钟后发生的。(我将capybara用于普通Ruby中的屏幕抓取应用程序,而不是用于测试。)我已经确认网站挂起时仍然可以访问(例如,通过命令行上的curl或wget)。我还尝试将调用访问和后续查找器的Ruby代码包装在超时block中,以便在等待60秒后访问新的URL,但是在第一次发生这种情况后任何visit()尝试都会失败。解决此问题的唯一方法是同时终止调用Capybar