Sha256: d313711eeaadee32f4586ba02f33919ceeec195c23ae1bf0a0f843a7a0c33761

Contents?: true

Size: 1.87 KB

Versions: 16

Compression:

Stored size: 1.87 KB

Contents

module Beaker
  module DSL
    # These are simple patterns that appear frequently in beaker test
    # code, and are provided to simplify test construction.
    #
    #
    # It requires the class it is mixed into to provide the attribute
    # `hosts` which contain the hosts to search, these should implement
    # {Beaker::Host}'s interface. They, at least, must have #[]
    # and #to_s available and provide an array when #[]('roles') is called.
    #
    module Patterns
      # Execute a block selecting the hosts that match with the provided criteria
      # @param [Array<Host>, Host, String, Symbol] hosts_or_filter A host role as a String or Symbol that can be
      #                                                used to search for a set of Hosts,  a host name
      #                                                as a String that can be used to search for
      #                                                a set of Hosts, or a {Host}
      #                                                or Array<{Host}> to run the block against
      # @param [Hash{Symbol=>String}] opts Options to alter execution.
      # @option opts [Boolean] :run_in_parallel Whether to run on each host in parallel.
      # @param [Block] block This method will yield to a block of code passed by the caller
      #
      # @return [Array<Result>, Result, nil] An array of results, a result object, or nil.
      #   Check {Beaker::Shared::HostManager#run_block_on} for more details on this.
      def block_on hosts_or_filter, opts = {}, &block
        block_hosts = nil
        if defined? hosts
          block_hosts = hosts
        end
        filter = nil
        if hosts_or_filter.is_a? String or hosts_or_filter.is_a? Symbol
          filter = hosts_or_filter
        else
          block_hosts = hosts_or_filter
        end
        run_block_on block_hosts, filter, opts, &block
      end
    end
  end
end

Version data entries

16 entries across 16 versions & 1 rubygems

Version Path
beaker-6.4.1 lib/beaker/dsl/patterns.rb
beaker-6.4.0 lib/beaker/dsl/patterns.rb
beaker-6.3.0 lib/beaker/dsl/patterns.rb
beaker-6.2.0 lib/beaker/dsl/patterns.rb
beaker-6.1.0 lib/beaker/dsl/patterns.rb
beaker-5.8.1 lib/beaker/dsl/patterns.rb
beaker-5.8.0 lib/beaker/dsl/patterns.rb
beaker-5.7.0 lib/beaker/dsl/patterns.rb
beaker-5.6.0 lib/beaker/dsl/patterns.rb
beaker-5.5.0 lib/beaker/dsl/patterns.rb
beaker-5.4.0 lib/beaker/dsl/patterns.rb
beaker-5.3.1 lib/beaker/dsl/patterns.rb
beaker-5.3.0 lib/beaker/dsl/patterns.rb
beaker-5.2.0 lib/beaker/dsl/patterns.rb
beaker-5.1.0 lib/beaker/dsl/patterns.rb
beaker-5.0.0 lib/beaker/dsl/patterns.rb