Class: Culerity::RemoteBrowserProxy
- Inherits:
-
RemoteObjectProxy
- Object
- RemoteObjectProxy
- Culerity::RemoteBrowserProxy
- Defined in:
- lib/culerity/remote_browser_proxy.rb
Instance Method Summary collapse
-
#confirm(bool, &block) ⇒ Object
Specify whether to accept or reject all confirm js dialogs for the code in the block that’s run.
-
#initialize(io, browser_options = {}) ⇒ RemoteBrowserProxy
constructor
A new instance of RemoteBrowserProxy.
-
#wait_until(time_to_wait = 30, &block) ⇒ Object
Calls the block until it returns true or
time_to_wait
is reached. -
#wait_while(time_to_wait = 30, &block) ⇒ Object
Calls the block until it doesn’t return true or
time_to_wait
is reached.
Methods inherited from RemoteObjectProxy
#exit, #id, #method_missing, #send_remote
Constructor Details
#initialize(io, browser_options = {}) ⇒ RemoteBrowserProxy
Returns a new instance of RemoteBrowserProxy.
3 4 5 6 7 8 9 |
# File 'lib/culerity/remote_browser_proxy.rb', line 3 def initialize(io, = {}) @io = io #sets the remote receiver to celerity for the new_browser message. @remote_object_id = "celerity".inspect #celerity server will create a new browser which shall receive the remote calls from now on. @remote_object_id = new_browser().inspect end |
Dynamic Method Handling
This class handles dynamic methods through the method_missing method in the class Culerity::RemoteObjectProxy
Instance Method Details
#confirm(bool, &block) ⇒ Object
Specify whether to accept or reject all confirm js dialogs for the code in the block that’s run.
48 49 50 51 52 53 54 |
# File 'lib/culerity/remote_browser_proxy.rb', line 48 def confirm(bool, &block) blk = "lambda { #{bool} }" self.send_remote(:add_listener, :confirm) { blk } block.call self.send_remote(:remove_listener, :confirm, lambda {blk}) end |
#wait_until(time_to_wait = 30, &block) ⇒ Object
Calls the block until it returns true or time_to_wait
is reached. time_to_wait
is 30 seconds by default
Returns true upon success Raises Timeout::Error when time_to_wait
is reached.
18 19 20 21 22 23 24 25 |
# File 'lib/culerity/remote_browser_proxy.rb', line 18 def wait_until time_to_wait=30, &block Timeout.timeout(time_to_wait) do until block.call sleep 0.1 end end true end |
#wait_while(time_to_wait = 30, &block) ⇒ Object
Calls the block until it doesn’t return true or time_to_wait
is reached. time_to_wait
is 30 seconds by default
Returns true upon success Raises Timeout::Error when time_to_wait
is reached.
34 35 36 37 38 39 40 41 |
# File 'lib/culerity/remote_browser_proxy.rb', line 34 def wait_while time_to_wait=30, &block Timeout.timeout(time_to_wait) do while block.call sleep 0.1 end end true end |