Sha256: aaf631894e13a9c7e0c94abf8135618ec2c8da51873de899154eb715df7259eb

Contents?: true

Size: 1.01 KB

Versions: 2

Compression:

Stored size: 1.01 KB

Contents

module Polonium
  module WaitFor
    Context = Struct.new(:message)
    # Poll continuously for the return value of the block to be true. You can use this to assert that a client side
    # or server side condition was met.
    #   wait_for do
    #     User.count == 5
    #   end
    def wait_for(params={})
      timeout = params[:timeout] || default_wait_for_time
      message = params[:message] || "Timeout exceeded"
      configuration = Context.new(message)
      begin_time = time_class.now
      while (time_class.now - begin_time) < timeout
        return if yield(configuration)
        sleep 0.25
      end
      flunk(configuration.message + " (after #{timeout} sec)")
      true
    end

    def default_wait_for_time
      5
    end

    def time_class
      Time
    end

    # The default Selenium Core client side timeout.
    def default_timeout
      @default_timeout ||= 20000
    end
    attr_writer :default_timeout

    def flunk(message)
      raise Test::Unit::AssertionFailedError, message
    end
  end
end

Version data entries

2 entries across 2 versions & 1 rubygems

Version Path
polonium-0.1.0 lib/polonium/wait_for.rb
polonium-0.1.1 lib/polonium/wait_for.rb