Module: Watir::EventuallyPresent

Included in:
Alert, Element, Window
Defined in:
lib/watir-webdriver/wait.rb

Overview

Convenience methods for things that eventually become present.

Includers should implement a public #present? and a (possibly private) #selector_string method.

Instance Method Summary collapse

Instance Method Details

#wait_until_present(timeout = 30) ⇒ Object

Waits until the element is present.

Examples:

browser.button(:id => 'foo').wait_until_present

Parameters:

  • timeout (Fixnum) (defaults to: 30)

    seconds to wait before timing out

See Also:



148
149
150
151
# File 'lib/watir-webdriver/wait.rb', line 148

def wait_until_present(timeout = 30)
  message = "waiting for #{selector_string} to become present"
  Watir::Wait.until(timeout, message) { present? }
end

#wait_while_present(timeout = 30) ⇒ Object

Waits while the element is present.

Examples:

browser.button(:id => 'foo').wait_while_present

Parameters:

  • timeout (Integer) (defaults to: 30)

    seconds to wait before timing out

See Also:



165
166
167
168
169
170
# File 'lib/watir-webdriver/wait.rb', line 165

def wait_while_present(timeout = 30)
  message = "waiting for #{selector_string} to disappear"
  Watir::Wait.while(timeout, message) { present? }
rescue Selenium::WebDriver::Error::ObsoleteElementError
  # it's not present
end

#when_present(timeout = 30) ⇒ Object

Waits until the element is present.

Examples:

browser.button(:id => 'foo').when_present.click
browser.div(:id => 'bar').when_present { |div| ... }
browser.p(:id => 'baz').when_present(60).text

Parameters:

  • timeout (Fixnum) (defaults to: 30)

    seconds to wait before timing out

See Also:



125
126
127
128
129
130
131
132
133
134
# File 'lib/watir-webdriver/wait.rb', line 125

def when_present(timeout = 30)
  message = "waiting for #{selector_string} to become present"

  if block_given?
    Watir::Wait.until(timeout, message) { present? }
    yield self
  else
    WhenPresentDecorator.new(self, timeout, message)
  end
end