Sha256: ff3dddad29dc705c5c0e81ec777dff6bb6e846fc4a4f26f8455a258401922d00
Contents?: true
Size: 1.55 KB
Versions: 5
Compression:
Stored size: 1.55 KB
Contents
require 'thor' require 'pathname' require 'parallel' require 'guignol' require 'guignol/configuration' require 'guignol/models/instance' require 'core_ext/array/collect_key' module Guignol::Commands class Base def initialize(patterns, options = {}) @configs = select_configs(patterns) @options = options end # Run the block for each server in +configs+ (in parallel). def run before_run(@configs) or return results = {} Parallel.each(@configs, parallel_options) do |name,config| instance = Guignol::Models::Instance.new(name, config) results[name] = run_on_server(instance, @options) end after_run(results) end protected # Override in subclasses def before_run(configs) ; true ; end # Override in subclasses def after_run(data) ; true ; end def shell Guignol::Shell.shared_shell end def synchronize (@mutex ||= Mutex.new).synchronize do yield end end private def parallel_options if RUBY_VERSION >= '1.9.3' # 1.9.3 has bugs with Excon / SSL connections { :in_threads => 0 } else { :in_threads => @configs.size } end end # Put all the servers matching one of the +names+ in +configs+. def select_configs(patterns) patterns = patterns.map { |pattern| pattern.kind_of?(String) ? Regexp.new(pattern) : pattern } Guignol.configuration.delete_if { |name,config| patterns.none? { |pattern| name.to_s =~ pattern } } end end end
Version data entries
5 entries across 5 versions & 1 rubygems