+++ /dev/null
-#!/usr/bin/env rspec
-
-require 'spec_helper'
-
-module MCollective
- describe Shell do
- describe "#initialize" do
- it "should set locale by default" do
- s = Shell.new("date")
- s.environment.should == {"LC_ALL" => "C"}
- end
-
- it "should merge environment and keep locale" do
- s = Shell.new("date", :environment => {"foo" => "bar"})
- s.environment.should == {"LC_ALL" => "C", "foo" => "bar"}
- end
-
- it "should allow locale to be overridden" do
- s = Shell.new("date", :environment => {"LC_ALL" => "TEST", "foo" => "bar"})
- s.environment.should == {"LC_ALL" => "TEST", "foo" => "bar"}
- end
-
- it "should set no environment when given nil" do
- s = Shell.new("date", :environment => nil)
- s.environment.should == {}
- end
-
- it "should save the command" do
- s = Shell.new("date")
- s.command.should == "date"
- end
-
- it "should check the cwd exist" do
- expect {
- s = Shell.new("date", :cwd => "/nonexistant")
- }.to raise_error("Directory /nonexistant does not exist")
- end
-
- it "should warn of illegal stdin" do
- expect {
- s = Shell.new("date", :stdin => nil)
- }.to raise_error("stdin should be a String")
- end
-
- it "should warn of illegal stdout" do
- expect {
- s = Shell.new("date", :stdout => nil)
- }.to raise_error("stdout should support <<")
- end
-
- it "should warn of illegal stderr" do
- expect {
- s = Shell.new("date", :stderr => nil)
- }.to raise_error("stderr should support <<")
- end
-
- it "should set stdout" do
- s = Shell.new("date", :stdout => "stdout")
- s.stdout.should == "stdout"
- end
-
- it "should set stderr" do
- s = Shell.new("date", :stderr => "stderr")
- s.stderr.should == "stderr"
- end
-
- it "should set stdin" do
- s = Shell.new("date", :stdin => "hello world")
- s.stdin.should == "hello world"
- end
- end
-
- describe "#runcommand" do
- it "should run the command" do
- Shell.any_instance.stubs("systemu").returns(true).once.with("date", "stdout" => '', "stderr" => '', "env" => {"LC_ALL" => "C"}, 'cwd' => Dir.tmpdir)
- s = Shell.new("date")
- s.runcommand
- end
-
- it "should set stdin, stdout and status" do
- s = Shell.new('ruby -e "STDERR.puts \"stderr\"; STDOUT.puts \"stdout\""')
- s.runcommand
- s.stdout.should == "stdout\n"
- s.stderr.should == "stderr\n"
- s.status.exitstatus.should == 0
- end
-
- it "should report correct exitcode" do
- s = Shell.new('ruby -e "exit 1"')
- s.runcommand
-
- s.status.exitstatus.should == 1
- end
-
- it "shold have correct environment" do
- s = Shell.new('ruby -e "puts ENV[\'LC_ALL\'];puts ENV[\'foo\'];"', :environment => {"foo" => "bar"})
- s.runcommand
- s.stdout.should == "C\nbar\n"
- end
-
- it "should save stdout in custom stdout variable" do
- out = "STDOUT"
-
- s = Shell.new('echo foo', :stdout => out)
- s.runcommand
-
- s.stdout.should == "STDOUTfoo\n"
- out.should == "STDOUTfoo\n"
- end
-
- it "should save stderr in custom stderr variable" do
- out = "STDERR"
-
- s = Shell.new('ruby -e "STDERR.puts \"foo\""', :stderr => out)
- s.runcommand
-
- s.stderr.should == "STDERRfoo\n"
- out.should == "STDERRfoo\n"
- end
-
- it "should run in the correct cwd" do
- s = Shell.new('ruby -e "puts Dir.pwd"', :cwd => Dir.tmpdir)
-
- s.runcommand
-
- s.stdout.should == "#{Dir.tmpdir}\n"
- end
-
- it "should send the stdin" do
- s = Shell.new('ruby -e "puts STDIN.gets"', :stdin => "hello world")
- s.runcommand
-
- s.stdout.should == "hello world\n"
- end
-
- it "should support multiple lines of stdin" do
- s = Shell.new('ruby -e "puts STDIN.gets;puts;puts STDIN.gets"', :stdin => "first line\n2nd line")
- s.runcommand
-
- s.stdout.should == "first line\n\n2nd line\n"
- end
- end
- end
-end