use Retryable for virtualbox customize + defaults

when up-ing several boxes at once, VBoxManage modifyvm gets cranky and throws random lock errors. this adds the existing retryable logic to
the customize and sane_defaults actions, both of which fire a bunch of
modifyvm commands, all of which are fine to run multiple times.
This commit is contained in:
Andy Fowler 2013-11-09 18:16:47 -05:00
parent a92e03cf4c
commit b13122cab7
7 changed files with 24 additions and 10 deletions

View File

@ -25,11 +25,12 @@ module VagrantPlugins
arg.to_s
end
result = env[:machine].provider.driver.execute_command(processed_command)
if result.exit_code != 0
begin
env[:machine].provider.driver.execute_command(processed_command + [:retryable => true])
rescue Vagrant::Errors::VBoxManageError => e
raise Vagrant::Errors::VMCustomizationFailed, {
:command => processed_command.inspect,
:error => result.stderr
:command => command,
:error => e.inspect
}
end
end

View File

@ -55,11 +55,19 @@ module VagrantPlugins
# the given string to the log, and also includes the exit status in
# the log message.
#
# We assume every command is idempotent and pass along the `retryable`
# flag. This is because VBoxManage is janky about running simultaneously
# on the same box, and if we up multiple boxes at the same time, a bunch
# of modifyvm commands get fired
#
# @param [Array] command Command to run
# @param [String] log Log message to write.
def attempt_and_log(command, log)
result = @env[:machine].provider.driver.execute_command(command)
@logger.info("#{log} (exit status = #{result.exit_code})")
begin
@env[:machine].provider.driver.execute_command(command + [:retryable => true])
rescue Vagrant::Errors::VBoxManageError => e
@logger.info("#{log} (error = #{e.inspect})")
end
end
# This uses some heuristics to determine if the NAT DNS proxy should

View File

@ -108,6 +108,11 @@ module VagrantPlugins
# Execute a raw command straight through to VBoxManage.
#
# Accepts a :retryable => true option if the command should be retried
# upon failure.
#
# Raises a VBoxManage error if it fails.
#
# @param [Array] command Command to execute.
def execute_command(command)
end

View File

@ -129,7 +129,7 @@ module VagrantPlugins
end
def execute_command(command)
raw(*command)
execute(*command)
end
def export(path)

View File

@ -129,7 +129,7 @@ module VagrantPlugins
end
def execute_command(command)
raw(*command)
execute(*command)
end
def export(path)

View File

@ -127,7 +127,7 @@ module VagrantPlugins
end
def execute_command(command)
raw(*command)
execute(*command)
end
def export(path)

View File

@ -127,7 +127,7 @@ module VagrantPlugins
end
def execute_command(command)
raw(*command)
execute(*command)
end
def export(path)