module Selenium module WebDriver module Support # # @api private # class EventFiringBridge def initialize(delegate, listener) @delegate = delegate if listener.respond_to? :call @listener = BlockEventListener.new(listener) else @listener = listener end end def get(url) dispatch(:navigate_to, url) { @delegate.get(url) } end def goForward dispatch(:navigate_forward) { @delegate.goForward } end def goBack dispatch(:navigate_back) { @delegate.goBack } end def clickElement(ref) dispatch(:click, create_element(ref)) { @delegate.clickElement(ref) } end def clearElement(ref) dispatch(:change_value_of, create_element(ref)) { @delegate.clearElement(ref) } end def sendKeysToElement(ref, keys) dispatch(:change_value_of, create_element(ref)) { @delegate.sendKeysToElement(ref, keys) } end def find_element_by(how, what, parent = nil) e = dispatch(:find, how, what) { @delegate.find_element_by how, what, parent } Element.new self, e.ref end def find_elements_by(how, what, parent = nil) es = dispatch(:find, how, what) { @delegate.find_elements_by(how, what, parent) } es.map { |e| Element.new self, e.ref } end def executeScript(script, *args) dispatch(:execute_script, script) { @delegate.executeScript(script, *args) } end def quit dispatch(:quit) { @delegate.quit } end def close dispatch(:close) { @delegate.close } end private def create_element(ref) # hmm. we're not passing self here to not fire events for potential calls made by the listener Element.new @delegate, ref end def dispatch(name, *args, &blk) @listener.__send__("before_#{name}", *args) returned = yield @listener.__send__("after_#{name}", *args) returned end def method_missing(meth, *args, &blk) @delegate.__send__(meth, *args, &blk) end end # EventFiringBridge end # Support end # WebDriver end # Selenium