Sha256: 04781f7c931762af2535426b6151eb52cb713993a397eb6cbd6044ac19c26009

Contents?: true

Size: 1.69 KB

Versions: 1

Compression:

Stored size: 1.69 KB

Contents

require 'capybara'
require 'selenium-webdriver'

require 'capybara/chromedriver/logger/test_hooks'
require 'capybara/chromedriver/logger/version'
require 'capybara/chromedriver/logger/js_error'
require 'capybara/chromedriver/logger/message'
require 'capybara/chromedriver/logger/collector'

module Capybara
  module Chromedriver
    module Logger
      extend self

      def build_capabilities(loggingPrefs: { browser: 'ALL' }, **options)
        options[:chromeOptions] ||= {}

        if options[:chromeOptions][:w3c]
          warn "warning: Setting chromeOptions.w3c to true makes it not "\
            "possible to get console.log messages from Chrome.\n\n"\
            "Please see: https://github.com/SeleniumHQ/selenium/issues/7270"
        else
          options[:chromeOptions][:w3c] = false
        end

        if loggingPrefs[:browser] != 'ALL'
          warn "warning: loggingPrefs needs to contain { browser: 'ALL' } "\
            "when using Logger#build_capabilities"
        end

        options[:loggingPrefs] = loggingPrefs

        # Support Chrome 75+
        # see: https://github.com/SeleniumHQ/selenium/issues/7342
        options["goog:loggingPrefs"] = loggingPrefs

        ::Selenium::WebDriver::Remote::Capabilities.chrome(options)
      end

      def filters
        @filters || []
      end

      def filters=(filters)
        @filters = filters
      end

      def filter_levels
        @filter_levels || []
      end

      def filter_levels=(filters)
        @filter_levels = filters && filters.map(&:upcase).map(&:to_s)
      end

      def raise_js_errors?
        !!@raise_js_errors
      end

      def raise_js_errors=(value)
        @raise_js_errors = value
      end
    end
  end
end

Version data entries

1 entries across 1 versions & 1 rubygems

Version Path
capybara-chromedriver-logger-0.3.0 lib/capybara/chromedriver/logger.rb