Class: Selenium::WebDriver::Driver

Inherits:
Object
  • Object
show all
Includes:
SearchContext
Defined in:
lib/selenium/webdriver/common/driver.rb

Overview

The main class through which you control the browser.

Constant Summary

Constants included from SearchContext

SearchContext::FINDERS

Class Method Summary collapse

Instance Method Summary collapse

Methods included from SearchContext

#find_element, #find_elements

Constructor Details

#initialize(bridge) ⇒ Driver

This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.

A new Driver instance with the given bridge. End users should use Selenium::WebDriver.for instead of using this directly.

[View source]

53
54
55
56
57
58
59
60
# File 'lib/selenium/webdriver/common/driver.rb', line 53

def initialize(bridge)
  @bridge = bridge

  # TODO: refactor this away
  unless bridge.driver_extensions.empty?
    extend(*bridge.driver_extensions)
  end
end

Class Method Details

.for(browser, *args) ⇒ Object

This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.

[View source]

24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
# File 'lib/selenium/webdriver/common/driver.rb', line 24

def for(browser, *args)
  bridge = case browser
           when :firefox, :ff
             Firefox::Bridge.new(*args)
           when :remote
             Remote::Bridge.new(*args)
           when :ie, :internet_explorer
             IE::Bridge.new(*args)
           when :chrome
             Chrome::Bridge.new(*args)
           when :android
             Android::Bridge.new(*args)
           when :iphone
             IPhone::Bridge.new(*args)
           else
             raise ArgumentError, "unknown driver: #{browser.inspect}"
           end

   new(bridge)
end

Instance Method Details

#[](sel) ⇒ WebDriver::Element

Get the first element matching the given selector. If given a String or Symbol, it will be used as the id of the element.

Examples:

driver['someElementId']    #=> #<WebDriver::Element:0x1011c3b88>
driver[:tag_name => 'div'] #=> #<WebDriver::Element:0x1011c3b88>

Parameters:

  • id (String, Hash)

    or selector

Returns:

[View source]

256
257
258
259
260
261
262
# File 'lib/selenium/webdriver/common/driver.rb', line 256

def [](sel)
  if sel.kind_of?(String) || sel.kind_of?(Symbol)
    sel = { :id => sel }
  end

  find_element sel
end

#browserObject

[View source]

274
275
276
# File 'lib/selenium/webdriver/common/driver.rb', line 274

def browser
  bridge.browser
end

#capabilitiesObject

[View source]

278
279
280
# File 'lib/selenium/webdriver/common/driver.rb', line 278

def capabilities
  bridge.capabilities
end

#closeObject

Close the current window, or the browser if no windows are left.

[View source]

163
164
165
# File 'lib/selenium/webdriver/common/driver.rb', line 163

def close
  bridge.close
end

#current_urlString

Get the URL of the current page

Returns:

[View source]

107
108
109
# File 'lib/selenium/webdriver/common/driver.rb', line 107

def current_url
  bridge.getCurrentUrl
end

#execute_async_script(script, *args) ⇒ WebDriver::Element, ...

Execute an asynchronous piece of JavaScript in the context of the currently selected frame or window. Unlike executing execute_script (synchronous JavaScript), scripts executed with this method must explicitly signal they are finished by invoking the provided callback. This callback is always injected into the executed function as the last argument.

Parameters:

  • script (String)

    JavaSCript source to execute

  • *args (WebDriver::Element, Integer, Float, Boolean, NilClass, String, Array)

    Arguments to the script. May be empty.

Returns:

[View source]

219
220
221
# File 'lib/selenium/webdriver/common/driver.rb', line 219

def execute_async_script(script, *args)
  bridge.executeAsyncScript(script, *args)
end

#execute_script(script, *args) ⇒ WebDriver::Element, ... Also known as: script

Execute the given JavaScript

Parameters:

  • script (String)

    JavaScript source to execute

  • *args (WebDriver::Element, Integer, Float, Boolean, NilClass, String, Array)

    Arguments will be available in the given script in the ‘arguments’ pseudo-array.

Returns:

[View source]

200
201
202
# File 'lib/selenium/webdriver/common/driver.rb', line 200

def execute_script(script, *args)
  bridge.executeScript(script, *args)
end

#get(url) ⇒ Object

Opens the specified URL in the browser.

[View source]

97
98
99
# File 'lib/selenium/webdriver/common/driver.rb', line 97

def get(url)
  navigate.to(url)
end

#inspectObject

[View source]

62
63
64
# File 'lib/selenium/webdriver/common/driver.rb', line 62

def inspect
  '#<%s:0x%x browser=%s>' % [self.class, hash*2, bridge.browser.inspect]
end

#manageOptions

Returns:

See Also:

[View source]

89
90
91
# File 'lib/selenium/webdriver/common/driver.rb', line 89

def manage
  @manage ||= WebDriver::Options.new(bridge)
end

Returns:

See Also:

[View source]

71
72
73
# File 'lib/selenium/webdriver/common/driver.rb', line 71

def navigate
  @navigate ||= WebDriver::Navigation.new(bridge)
end

#page_sourceString

Get the source of the current page

Returns:

[View source]

127
128
129
# File 'lib/selenium/webdriver/common/driver.rb', line 127

def page_source
  bridge.getPageSource
end

#quitObject

Quit the browser

[View source]

155
156
157
# File 'lib/selenium/webdriver/common/driver.rb', line 155

def quit
  bridge.quit
end

#refObject

This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.

See Also:

[View source]

270
271
272
# File 'lib/selenium/webdriver/common/driver.rb', line 270

def ref
  nil
end

#switch_toTargetLocator

Returns:

See Also:

[View source]

80
81
82
# File 'lib/selenium/webdriver/common/driver.rb', line 80

def switch_to
  @switch_to ||= WebDriver::TargetLocator.new(bridge)
end

#titleString

Get the title of the current page

Returns:

[View source]

117
118
119
# File 'lib/selenium/webdriver/common/driver.rb', line 117

def title
  bridge.getTitle
end

#visible=(bool) ⇒ Object

Set the visibility of the browser. Not applicable for all browsers.

Parameters:

  • (Boolean)
[View source]

147
148
149
# File 'lib/selenium/webdriver/common/driver.rb', line 147

def visible=(bool)
  bridge.setBrowserVisible bool
end

#visible?Boolean

Get the visibility of the browser. Not applicable for all browsers.

Returns:

  • (Boolean)
[View source]

137
138
139
# File 'lib/selenium/webdriver/common/driver.rb', line 137

def visible?
  bridge.getBrowserVisible
end

#window_handleString

Get the current window handle

Returns:

[View source]

184
185
186
# File 'lib/selenium/webdriver/common/driver.rb', line 184

def window_handle
  bridge.getCurrentWindowHandle
end

#window_handlesArray

Get the window handles of open browser windows.

Returns:

  • (Array)

See Also:

[View source]

174
175
176
# File 'lib/selenium/webdriver/common/driver.rb', line 174

def window_handles
  bridge.getWindowHandles
end