Class: OpsBuild::Utils
- Inherits:
-
Object
- Object
- OpsBuild::Utils
- Defined in:
- lib/ops_build/utils.rb
Class Method Summary collapse
Class Method Details
.execute(cmd, log_level: :debug, log_prefix: '', raise_on_failure: true) ⇒ Object
3 4 5 6 7 8 9 10 11 12 13 14 15 16 |
# File 'lib/ops_build/utils.rb', line 3 def self.execute(cmd, log_level: :debug, log_prefix: '', raise_on_failure: true) OpsBuild.logger.debug("Running command '#{cmd}'") _, out, wait_thr = Open3.popen2e(cmd) while line = out.gets OpsBuild.logger.__send__(log_level, "#{log_prefix} #{line}") end code = wait_thr.value.exitstatus # #value is blocking call raise "Error executing '#{cmd}'. Exit code: #{code}" if code != 0 && raise_on_failure out.close code end |