(#8917) Fix shell_expand_guest_path capability
Prior to this commit, when the guest capability attempted to expand a path with spaces it would quote the path passed in. However if the path also had a relative path those quotes would end up making `printf` ignore it and not properly expand the path fully. This commit updates that to first escape the quotes of a path and then pass in the new path to be expanded.
This commit is contained in:
parent
4ddac2d023
commit
0ac26be4ef
|
@ -4,7 +4,8 @@ module VagrantPlugins
|
|||
class ShellExpandGuestPath
|
||||
def self.shell_expand_guest_path(machine, path)
|
||||
real_path = nil
|
||||
machine.communicate.execute("printf \"#{path}\"") do |type, data|
|
||||
path = path.gsub(/ /, '\ ')
|
||||
machine.communicate.execute("printf #{path}") do |type, data|
|
||||
if type == :stdout
|
||||
real_path ||= ""
|
||||
real_path += data
|
||||
|
|
|
@ -4,7 +4,8 @@ module VagrantPlugins
|
|||
class ShellExpandGuestPath
|
||||
def self.shell_expand_guest_path(machine, path)
|
||||
real_path = nil
|
||||
machine.communicate.execute("printf \"#{path}\"",
|
||||
path = path.gsub(/ /, '\ ')
|
||||
machine.communicate.execute("printf #{path}",
|
||||
shell: "sh") do |type, data|
|
||||
if type == :stdout
|
||||
real_path ||= ""
|
||||
|
|
|
@ -4,7 +4,8 @@ module VagrantPlugins
|
|||
class ShellExpandGuestPath
|
||||
def self.shell_expand_guest_path(machine, path)
|
||||
real_path = nil
|
||||
machine.communicate.execute("echo; printf \"#{path}\"") do |type, data|
|
||||
path = path.gsub(/ /, '\ ')
|
||||
machine.communicate.execute("echo; printf #{path}") do |type, data|
|
||||
if type == :stdout
|
||||
real_path ||= ""
|
||||
real_path += data
|
||||
|
|
|
@ -4,7 +4,8 @@ module VagrantPlugins
|
|||
class ShellExpandGuestPath
|
||||
def self.shell_expand_guest_path(machine, path)
|
||||
real_path = nil
|
||||
machine.communicate.execute("printf \"#{path}\"") do |type, data|
|
||||
path = path.gsub(/ /, '\ ')
|
||||
machine.communicate.execute("printf #{path}") do |type, data|
|
||||
if type == :stdout
|
||||
real_path ||= ""
|
||||
real_path += data
|
||||
|
|
|
@ -4,7 +4,8 @@ module VagrantPlugins
|
|||
class ShellExpandGuestPath
|
||||
def self.shell_expand_guest_path(machine, path)
|
||||
real_path = nil
|
||||
machine.communicate.execute("printf \"#{path}\"") do |type, data|
|
||||
path = path.gsub(/ /, '\ ')
|
||||
machine.communicate.execute("printf #{path}") do |type, data|
|
||||
if type == :stdout
|
||||
real_path ||= ""
|
||||
real_path += data
|
||||
|
|
|
@ -33,10 +33,11 @@ describe "VagrantPlugins::GuestDarwin::Cap::ShellExpandGuestPath" do
|
|||
|
||||
it "returns a path with a space in it" do
|
||||
path = "/home/vagrant folder/folder"
|
||||
path_with_spaces = "/home/vagrant\\ folder/folder"
|
||||
allow(machine.communicate).to receive(:execute).
|
||||
with(any_args).and_yield(:stdout, "/home/vagrant folder/folder")
|
||||
with(any_args).and_yield(:stdout, path_with_spaces)
|
||||
|
||||
expect(machine.communicate).to receive(:execute).with("printf \"#{path}\"")
|
||||
expect(machine.communicate).to receive(:execute).with("printf #{path_with_spaces}")
|
||||
cap.shell_expand_guest_path(machine, path)
|
||||
end
|
||||
end
|
||||
|
|
|
@ -33,11 +33,12 @@ describe "VagrantPlugins::GuestFreeBSD::Cap::ShellExpandGuestPath" do
|
|||
|
||||
it "returns a path with a space in it" do
|
||||
path = "/home/vagrant folder/folder"
|
||||
path_with_spaces = "/home/vagrant\\ folder/folder"
|
||||
allow(machine.communicate).to receive(:execute).
|
||||
with(any_args).and_yield(:stdout, "/home/vagrant folder/folder")
|
||||
with(any_args).and_yield(:stdout, path_with_spaces)
|
||||
|
||||
expect(machine.communicate).to receive(:execute)
|
||||
.with("printf \"#{path}\"", {:shell=>"sh"})
|
||||
.with("printf #{path_with_spaces}", {:shell=>"sh"})
|
||||
cap.shell_expand_guest_path(machine, path)
|
||||
end
|
||||
end
|
||||
|
|
|
@ -33,10 +33,11 @@ describe "VagrantPlugins::GuestLinux::Cap::ShellExpandGuestPath" do
|
|||
|
||||
it "returns a path with a space in it" do
|
||||
path = "/home/vagrant folder/folder"
|
||||
path_with_spaces = "/home/vagrant\\ folder/folder"
|
||||
allow(machine.communicate).to receive(:execute).
|
||||
with(any_args).and_yield(:stdout, "/home/vagrant folder/folder")
|
||||
with(any_args).and_yield(:stdout, path_with_spaces)
|
||||
|
||||
expect(machine.communicate).to receive(:execute).with("echo; printf \"#{path}\"")
|
||||
expect(machine.communicate).to receive(:execute).with("echo; printf #{path_with_spaces}")
|
||||
cap.shell_expand_guest_path(machine, path)
|
||||
end
|
||||
end
|
||||
|
|
|
@ -33,10 +33,11 @@ describe "VagrantPlugins::GuestNetBSD::Cap::ShellExpandGuestPath" do
|
|||
|
||||
it "returns a path with a space in it" do
|
||||
path = "/home/vagrant folder/folder"
|
||||
path_with_spaces = "/home/vagrant\\ folder/folder"
|
||||
allow(machine.communicate).to receive(:execute).
|
||||
with(any_args).and_yield(:stdout, "/home/vagrant folder/folder")
|
||||
with(any_args).and_yield(:stdout, path_with_spaces)
|
||||
|
||||
expect(machine.communicate).to receive(:execute).with("printf \"#{path}\"")
|
||||
expect(machine.communicate).to receive(:execute).with("printf #{path_with_spaces}")
|
||||
cap.shell_expand_guest_path(machine, path)
|
||||
end
|
||||
end
|
||||
|
|
|
@ -33,10 +33,11 @@ describe "VagrantPlugins::GuestOpenBSD::Cap::ShellExpandGuestPath" do
|
|||
|
||||
it "returns a path with a space in it" do
|
||||
path = "/home/vagrant folder/folder"
|
||||
path_with_spaces = "/home/vagrant\\ folder/folder"
|
||||
allow(machine.communicate).to receive(:execute).
|
||||
with(any_args).and_yield(:stdout, "/home/vagrant folder/folder")
|
||||
with(any_args).and_yield(:stdout, path_with_spaces)
|
||||
|
||||
expect(machine.communicate).to receive(:execute).with("printf \"#{path}\"")
|
||||
expect(machine.communicate).to receive(:execute).with("printf #{path_with_spaces}")
|
||||
cap.shell_expand_guest_path(machine, path)
|
||||
end
|
||||
end
|
||||
|
|
Loading…
Reference in New Issue