Sha256: a13d77098580d27f448ad14384ee0e616f28fe3d5f36ab4d5a58baa2fd1df166

Contents?: true

Size: 1.09 KB

Versions: 1

Compression:

Stored size: 1.09 KB

Contents

require 'open3'

module Percheron
  module Actions
    class ExecLocal

      include Base

      def initialize(container, scripts, description)
        @container = container
        @scripts = scripts
        @description = description
      end

      def execute!
        results = []
        results << execute_scripts!
        results.compact.empty? ? nil : container
      end

      private

        attr_reader :container, :scripts, :description

        def execute_scripts!
          $logger.debug "Executing #{description} scripts '#{scripts.inspect}' locally"
          scripts.each do |script|
            in_working_directory(base_dir) do
              execute_command!('/bin/bash -x %s 2>&1' % Pathname.new(File.expand_path(script)))
            end
          end
        end

        def execute_command!(command)
          $logger.info "Executing #{description} '#{command}' locally"
          Open3.popen2e(command) do |stdin, stdout_stderr, wait_thr|
            while line = stdout_stderr.gets
              $logger.debug line.strip
            end
          end
        end

    end
  end
end

Version data entries

1 entries across 1 versions & 1 rubygems

Version Path
percheron-0.6.4 lib/percheron/actions/exec_local.rb