1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109
|
# frozen_string_literal: true
# Licensed to the Software Freedom Conservancy (SFC) under one
# or more contributor license agreements. See the NOTICE file
# distributed with this work for additional information
# regarding copyright ownership. The SFC licenses this file
# to you under the Apache License, Version 2.0 (the
# "License"); you may not use this file except in compliance
# with the License. You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing,
# software distributed under the License is distributed on an
# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
# KIND, either express or implied. See the License for the
# specific language governing permissions and limitations
# under the License.
module Selenium
module WebDriver
#
# Base class implementing default behavior of service object,
# responsible for storing a service manager configuration.
#
class Service
class << self
attr_reader :driver_path
def chrome(**)
Chrome::Service.new(**)
end
def firefox(**)
Firefox::Service.new(**)
end
def ie(**)
IE::Service.new(**)
end
alias internet_explorer ie
def edge(**)
Edge::Service.new(**)
end
alias microsoftedge edge
alias msedge edge
def safari(**)
Safari::Service.new(**)
end
def driver_path=(path)
Platform.assert_executable path if path.is_a?(String)
@driver_path = path
end
end
attr_accessor :host, :executable_path, :port, :log, :args
alias extra_args args
#
# End users should use a class method for the desired driver, rather than using this directly.
#
# @api private
#
def initialize(path: nil, port: nil, log: nil, args: nil)
port ||= self.class::DEFAULT_PORT
args ||= []
path ||= env_path
@executable_path = path
@host = Platform.localhost
@port = Integer(port)
@log = case log
when :stdout
$stdout
when :stderr
$stderr
else
log
end
@args = args
raise Error::WebDriverError, "invalid port: #{@port}" if @port < 1
end
def launch
@executable_path ||= env_path || find_driver_path
ServiceManager.new(self).tap(&:start)
end
def shutdown_supported
self.class::SHUTDOWN_SUPPORTED
end
def find_driver_path
default_options = WebDriver.const_get("#{self.class.name&.split('::')&.[](2)}::Options").new
DriverFinder.new(default_options, self).driver_path
end
def env_path
ENV.fetch(self.class::DRIVER_PATH_ENV_KEY, nil)
end
end # Service
end # WebDriver
end # Selenium
|