4

Cucumber で実行されるテストを自動化するために、Capybara を通じて Selenium を使用しています。CDN のコンテンツを参照するページを読み込んでいます。必要以上のリクエストを作成して、理由もなく CDN にアクセスすることには興味がありません。そのドメインへのリクエストを何らかの形で無視するように Selenium を構成したいと思います。

Celerity には次のようなメソッドがあります。

Browser.ignore_pattern("regex pattern")

これは、一致する作成されたリクエストを無視します。この機能を何らかの形で再現したいと考えています。DNS をオーバーライドして 0.0.0.0 にする方法や、内部 Selenium プロキシを構成する他の方法はありますか?

4

1 に答える 1

2

https://github.com/jarib/browsermob-proxy-rbにある browsermob-proxy-rb gem を使用して、CDN をブラックリストに登録できるはずです。

以下は、主に github リストの README から盗用されたものです。

require 'selenium/webdriver'
require 'browsermob/proxy'

server = BrowserMob::Proxy::Server.new("/path/to/download/browsermob-proxy") #=> #<BrowserMob::Proxy::Server:0x000001022c6ea8 ...>
server.start

proxy = server.create_proxy #=> #<BrowserMob::Proxy::Client:0x0000010224bdc0 ...>

profile = Selenium::WebDriver::Firefox::Profile.new #=> #<Selenium::WebDriver::Firefox::Profile:0x000001022bf748 ...>

# This is the line I added
proxy.blacklist(/path.to.CDN.com/)

profile.proxy = proxy.selenium_proxy

driver = Selenium::WebDriver.for :firefox, :profile => profile

driver.get "http://www.yoursite.com"
于 2013-01-23T19:04:29.723 に答える