Revert "Instead of using Kernel#system, use custom piped solution"

This reverts commit 171f4184c0.
This commit is contained in:
Mitchell Hashimoto 2010-09-29 23:38:07 -07:00
parent c30b5f4093
commit 0fcc1150c5
8 changed files with 26 additions and 102 deletions

View File

@ -2,8 +2,6 @@
- SSH gives proper error message if VM is not running. [GH-167] - SSH gives proper error message if VM is not running. [GH-167]
- Fix some issues with undefined constants in command errors. - Fix some issues with undefined constants in command errors.
- Replaced `Kernel#system` calls with custom `Vagrant::Util::Sh` method to
fix strange error issues.
## 0.6.1, 0.6.2, 0.6.3 (September 27, 2010) ## 0.6.1, 0.6.2, 0.6.3 (September 27, 2010)

View File

@ -4,15 +4,10 @@ module Vagrant
class BSD < Base class BSD < Base
include Util include Util
include Util::Retryable include Util::Retryable
include Util::Sh
def nfs? def nfs?
retryable(:tries => 10, :on => TypeError) do retryable(:tries => 10, :on => TypeError) do
_, status = sh("which nfsd") system("which nfsd > /dev/null 2>&1")
# Sometimes the status is nil for some reason. In that case, force a retry
raise TypeError.new("Bad status code") if !status
status.success?
end end
end end
@ -30,22 +25,22 @@ module Vagrant
output.split("\n").each do |line| output.split("\n").each do |line|
# This should only ask for administrative permission once, even # This should only ask for administrative permission once, even
# though its executed in multiple subshells. # though its executed in multiple subshells.
sh(%Q[sudo su root -c "echo '#{line}' >> /etc/exports"]) system(%Q[sudo su root -c "echo '#{line}' >> /etc/exports"])
end end
# We run restart here instead of "update" just in case nfsd # We run restart here instead of "update" just in case nfsd
# is not starting # is not starting
sh("sudo nfsd restart") system("sudo nfsd restart")
end end
def nfs_cleanup def nfs_cleanup
return if !File.exist?("/etc/exports") return if !File.exist?("/etc/exports")
_, status = sh("cat /etc/exports | grep 'VAGRANT-BEGIN: #{env.vm.uuid}'") system("cat /etc/exports | grep 'VAGRANT-BEGIN: #{env.vm.uuid}' > /dev/null 2>&1")
if status.success? if $?.to_i == 0
# Use sed to just strip out the block of code which was inserted # Use sed to just strip out the block of code which was inserted
# by Vagrant # by Vagrant
sh("sudo sed -e '/^# VAGRANT-BEGIN: #{env.vm.uuid}/,/^# VAGRANT-END: #{env.vm.uuid}/ d' -i bak /etc/exports") system("sudo sed -e '/^# VAGRANT-BEGIN: #{env.vm.uuid}/,/^# VAGRANT-END: #{env.vm.uuid}/ d' -i bak /etc/exports")
end end
end end
end end

View File

@ -4,16 +4,11 @@ module Vagrant
class Linux < Base class Linux < Base
include Util include Util
include Util::Retryable include Util::Retryable
include Util::Sh
def nfs? def nfs?
retryable(:tries => 10, :on => TypeError) do retryable(:tries => 10, :on => TypeError) do
# Check procfs to see if NFSd is a supported filesystem # Check procfs to see if NFSd is a supported filesystem
_, status = sh("cat /proc/filesystems | grep nfsd") system("cat /proc/filesystems | grep nfsd > /dev/null 2>&1")
# Sometimes the status is nil for some reason. In that case, force a retry
raise TypeError.new("Bad status code") if !status
status.success?
end end
end end
@ -29,22 +24,22 @@ module Vagrant
output.split("\n").each do |line| output.split("\n").each do |line|
# This should only ask for administrative permission once, even # This should only ask for administrative permission once, even
# though its executed in multiple subshells. # though its executed in multiple subshells.
sh(%Q[sudo su root -c "echo '#{line}' >> /etc/exports"]) system(%Q[sudo su root -c "echo '#{line}' >> /etc/exports"])
end end
# We run restart here instead of "update" just in case nfsd # We run restart here instead of "update" just in case nfsd
# is not starting # is not starting
sh("sudo /etc/init.d/nfs-kernel-server restart") system("sudo /etc/init.d/nfs-kernel-server restart")
end end
def nfs_cleanup def nfs_cleanup
return if !File.exist?("/etc/exports") return if !File.exist?("/etc/exports")
_, status = sh("cat /etc/exports | grep 'VAGRANT-BEGIN: #{env.vm.uuid}'") system("cat /etc/exports | grep 'VAGRANT-BEGIN: #{env.vm.uuid}' > /dev/null 2>&1")
if status.success? if $?.to_i == 0
# Use sed to just strip out the block of code which was inserted # Use sed to just strip out the block of code which was inserted
# by Vagrant # by Vagrant
sh("sudo sed -e '/^# VAGRANT-BEGIN: #{env.vm.uuid}/,/^# VAGRANT-END: #{env.vm.uuid}/ d' -ibak /etc/exports") system("sudo sed -e '/^# VAGRANT-BEGIN: #{env.vm.uuid}/,/^# VAGRANT-END: #{env.vm.uuid}/ d' -ibak /etc/exports")
end end
end end
end end

View File

@ -7,7 +7,6 @@ module Vagrant
autoload :Platform, 'vagrant/util/platform' autoload :Platform, 'vagrant/util/platform'
autoload :ResourceLogger, 'vagrant/util/resource_logger' autoload :ResourceLogger, 'vagrant/util/resource_logger'
autoload :Retryable, 'vagrant/util/retryable' autoload :Retryable, 'vagrant/util/retryable'
autoload :Sh, 'vagrant/util/sh'
autoload :StackedProcRunner, 'vagrant/util/stacked_proc_runner' autoload :StackedProcRunner, 'vagrant/util/stacked_proc_runner'
autoload :TemplateRenderer, 'vagrant/util/template_renderer' autoload :TemplateRenderer, 'vagrant/util/template_renderer'
end end

View File

@ -1,33 +0,0 @@
module Vagrant
module Util
module Sh
# Runs the given shell command, collecting STDERR and STDOUT
# into a single string and returning it. After this method,
# `$?` will be set to a `Process::Status` object.
#
# @param [String] command Command to run
# @return [Array] An array of `[output, status]` where status is `Process::Status`
def sh(command, *args)
# Use a pipe to execute the given command
rd, wr = IO.pipe
pid = fork do
rd.close
$stdout.reopen wr
$stderr.reopen wr
exec(command, *args) rescue nil
exit! 1 # Should never reach this point
end
# Close our end of the writer pipe, read the output until
# its over, and wait for the process to end.
wr.close
out = ""
out << rd.read until rd.eof?
_, status = Process.wait2(-1, Process::WNOHANG)
# Finally, return the result
[out, status]
end
end
end
end

View File

@ -9,30 +9,26 @@ class BSDHostTest < Test::Unit::TestCase
context "supporting nfs check" do context "supporting nfs check" do
should "support NFS" do should "support NFS" do
result = @instance.sh("echo") @instance.expects(:system).returns(true)
@instance.expects(:sh).returns(result)
assert @instance.nfs? assert @instance.nfs?
end end
should "not support NFS if nfsd is not found" do should "not support NFS if nfsd is not found" do
result = @instance.sh("sdalkfjasdlkfj") @instance.expects(:system).returns(false)
@instance.expects(:sh).returns(result)
assert !@instance.nfs? assert !@instance.nfs?
end end
should "retry until a boolean is returned" do should "retry until a boolean is returned" do
result = @instance.sh("echo")
seq = sequence("seq") seq = sequence("seq")
@instance.expects(:sh).once.in_sequence(seq).raises(TypeError.new("foo")) @instance.expects(:system).in_sequence(seq).raises(TypeError.new("foo"))
@instance.expects(:sh).once.in_sequence(seq).returns(result) @instance.expects(:system).in_sequence(seq).returns(true)
assert @instance.nfs? assert @instance.nfs?
end end
end end
context "nfs export" do context "nfs export" do
setup do setup do
@instance.stubs(:sh) @instance.stubs(:system)
@ip = "foo" @ip = "foo"
@folders = "bar" @folders = "bar"
@ -45,8 +41,8 @@ class BSDHostTest < Test::Unit::TestCase
:ip => @ip, :ip => @ip,
:folders => @folders).returns(output) :folders => @folders).returns(output)
@instance.expects(:sh).times(output.split("\n").length) @instance.expects(:system).times(output.split("\n").length)
@instance.expects(:sh).with("sudo nfsd restart") @instance.expects(:system).with("sudo nfsd restart")
@instance.nfs_export(@ip, @folders) @instance.nfs_export(@ip, @folders)
end end
end end

View File

@ -10,30 +10,26 @@ class LinuxHostTest < Test::Unit::TestCase
context "supporting nfs check" do context "supporting nfs check" do
should "support NFS" do should "support NFS" do
result = @instance.sh("echo") @instance.expects(:system).returns(true)
@instance.expects(:sh).returns(result)
assert @instance.nfs? assert @instance.nfs?
end end
should "not support NFS if nfsd is not found" do should "not support NFS if nfsd is not found" do
result = @instance.sh("adosifjssdlkfj") @instance.expects(:system).returns(false)
@instance.expects(:sh).returns(result)
assert !@instance.nfs? assert !@instance.nfs?
end end
should "retry until a boolean is returned" do should "retry until a boolean is returned" do
result = @instance.sh("echo")
seq = sequence("seq") seq = sequence("seq")
@instance.expects(:sh).once.in_sequence(seq).raises(TypeError.new("foo")) @instance.expects(:system).in_sequence(seq).raises(TypeError.new("foo"))
@instance.expects(:sh).once.in_sequence(seq).returns(result) @instance.expects(:system).in_sequence(seq).returns(true)
assert @instance.nfs? assert @instance.nfs?
end end
end end
context "nfs export" do context "nfs export" do
setup do setup do
@instance.stubs(:sh) @instance.stubs(:system)
@ip = "foo" @ip = "foo"
@folders = "bar" @folders = "bar"
@ -46,8 +42,8 @@ class LinuxHostTest < Test::Unit::TestCase
:ip => @ip, :ip => @ip,
:folders => @folders).returns(output) :folders => @folders).returns(output)
@instance.expects(:sh).times(output.split("\n").length) @instance.expects(:system).times(output.split("\n").length)
@instance.expects(:sh).with("sudo /etc/init.d/nfs-kernel-server restart") @instance.expects(:system).with("sudo /etc/init.d/nfs-kernel-server restart")
@instance.nfs_export(@ip, @folders) @instance.nfs_export(@ip, @folders)
end end
end end

View File

@ -1,22 +0,0 @@
require "test_helper"
class ShUtilTest < Test::Unit::TestCase
setup do
@klass = Class.new do
extend Vagrant::Util::Sh
end
end
should "execute and return the output" do
out, _ = @klass.sh("echo 'hello'")
assert_equal "hello\n", out
end
should "populate the exit status variable" do
_, status = @klass.sh("echo")
assert status.success?
_, status = @klass.sh("sdklfjslkfj")
assert !status.success?
end
end