module Selenium::WebDriver::Platform
def assert_executable(path)
def assert_executable(path) assert_file(path) return if File.executable? path raise Error::WebDriverError, "not executable: #{path.inspect}" end
def assert_file(path)
def assert_file(path) return if File.file? path raise Error::WebDriverError, "not a file: #{path.inspect}" end
def bitsize
def bitsize @bitsize ||= if defined?(FFI::Platform::ADDRESS_SIZE) FFI::Platform::ADDRESS_SIZE elsif defined?(FFI) FFI.type_size(:pointer) == 4 ? 32 : 64 elsif jruby? Integer(ENV_JAVA['sun.arch.data.model']) else 1.size == 4 ? 32 : 64 end end
def ci
def ci if ENV['TRAVIS'] :travis elsif ENV['JENKINS'] :jenkins elsif ENV['APPVEYOR'] :appveyor elsif ENV['GITHUB_ACTIONS'] :github end end
def cygwin?
def cygwin? RUBY_PLATFORM.include?('cygwin') end
def cygwin_path(path, **opts)
def cygwin_path(path, **opts) flags = [] opts.each { |k, v| flags << "--#{k}" if v } `cygpath #{flags.join ' '} "#{path}"`.strip end
def engine
def engine @engine ||= RUBY_ENGINE.to_sym end
def exit_hook
def exit_hook pid = Process.pid at_exit { yield if Process.pid == pid } end
def find_binary(*binary_names)
def find_binary(*binary_names) paths = ENV['PATH'].split(File::PATH_SEPARATOR) if windows? binary_names.map! { |n| "#{n}.exe" } binary_names.dup.each { |n| binary_names << n.gsub('exe', 'bat') } end binary_names.each do |binary_name| paths.each do |path| full_path = File.join(path, binary_name) full_path = unix_path(full_path) if windows? exe = Dir.glob(full_path).find { |f| File.executable?(f) } return exe if exe end end nil end
def find_in_program_files(*binary_names)
def find_in_program_files(*binary_names) paths = [ ENV.fetch('PROGRAMFILES', '\\Program Files'), ENV.fetch('ProgramFiles(x86)', '\\Program Files (x86)'), ENV.fetch('ProgramW6432', '\\Program Files') ] paths.each do |root| binary_names.each do |name| exe = File.join(root, name) return exe if File.executable?(exe) end end nil end
def home
def home @home ||= Dir.home end
def interfaces
def interfaces interfaces = Socket.getaddrinfo('localhost', 8080).map { |e| e[3] } interfaces += ['0.0.0.0', Platform.ip] interfaces.compact.uniq end
def ip
def ip orig = Socket.do_not_reverse_lookup Socket.do_not_reverse_lookup = true begin UDPSocket.open do |s| s.connect '8.8.8.8', 53 return s.addr.last end ensure Socket.do_not_reverse_lookup = orig end rescue Errno::ENETUNREACH, Errno::EHOSTUNREACH # no external ip end
def jruby?
def jruby? engine == :jruby end
def linux?
def linux? os == :linux end
def localhost
def localhost info = Socket.getaddrinfo 'localhost', 80, Socket::AF_INET, Socket::SOCK_STREAM return info[0][3] unless info.empty? raise Error::WebDriverError, "unable to translate 'localhost' for TCP + IPv4" end
def mac?
def mac? os == :macosx end
def make_writable(file)
def make_writable(file) File.chmod 0o766, file end
def null_device
def null_device File::NULL end
def os
def os host_os = RbConfig::CONFIG['host_os'] @os ||= case host_os when /mswin|msys|mingw|cygwin|bccwin|wince|emc/ :windows when /darwin|mac os/ :macosx when /linux/ :linux when /solaris|bsd/ :unix else raise Error::WebDriverError, "unknown os: #{host_os.inspect}" end end
def ruby_version
def ruby_version RUBY_VERSION end
def truffleruby?
def truffleruby? engine == :truffleruby end
def unix_path(path)
def unix_path(path) path.tr(File::ALT_SEPARATOR, File::SEPARATOR) end
def windows?
def windows? os == :windows end
def windows_path(path)
def windows_path(path) path.tr(File::SEPARATOR, File::ALT_SEPARATOR) end
def wrap_in_quotes_if_necessary(str)
def wrap_in_quotes_if_necessary(str) windows? && !cygwin? ? %("#{str}") : str end
def wsl?
def wsl? return false unless linux? File.read('/proc/version').downcase.include?('microsoft') rescue Errno::EACCES # the file cannot be accessed on Linux on DeX false end