Class: Serverspec::Backend::Cmd
- Includes:
- PowerShell::ScriptHelper
- Defined in:
- lib/serverspec/backend/cmd.rb
Instance Method Summary collapse
Methods included from PowerShell::ScriptHelper
#add_pre_command, #build_command, #create_script, #encode_script
Methods inherited from Base
#check_zero, #commands, #method_missing, #set_commands, #set_example
Dynamic Method Handling
This class handles dynamic methods through the method_missing method in the class Serverspec::Backend::Base
Instance Method Details
#execute_script(script) ⇒ Object
20 21 22 23 24 25 26 27 28 29 30 31 32 |
# File 'lib/serverspec/backend/cmd.rb', line 20 def execute_script script ps_script = %Q{powershell -encodedCommand #{encode_script(script)}} if Open3.respond_to? :capture3 stdout, stderr, status = Open3.capture3(ps_script) # powershell still exits with 0 even if there are syntax errors, although it spits the error out into stderr # so we have to resort to return an error exit code if there is anything in the standard error status = 1 if status == 0 and !stderr.empty? { :stdout => stdout, :stderr => stderr, :status => status } else stdout = `#{ps_script} 2>&1` { :stdout => stdout, :stderr => nil, :status => $? } end end |
#run_command(cmd, opts = {}) ⇒ Object
8 9 10 11 12 13 14 15 16 17 18 |
# File 'lib/serverspec/backend/cmd.rb', line 8 def run_command(cmd, opts={}) script = create_script(cmd) result = execute_script script if @example @example.[:command] = script @example.[:stdout] = result[:stdout] + result[:stderr] end { :stdout => result[:stdout], :stderr => result[:stderr], :exit_status => result[:status], :exit_signal => nil } end |