32 lines
920 B
Ruby
32 lines
920 B
Ruby
require "log4r"
|
|
|
|
module Vagrant
|
|
module Util
|
|
module Retryable
|
|
# Retries a given block a specified number of times in the
|
|
# event the specified exception is raised. If the retries
|
|
# run out, the final exception is raised.
|
|
#
|
|
# This code is adapted slightly from the following blog post:
|
|
# http://blog.codefront.net/2008/01/14/retrying-code-blocks-in-ruby-on-exceptions-whatever/
|
|
def retryable(opts=nil)
|
|
logger = nil
|
|
opts = { :tries => 1, :on => Exception }.merge(opts || {})
|
|
|
|
begin
|
|
return yield
|
|
rescue *opts[:on] => e
|
|
if (opts[:tries] -= 1) > 0
|
|
logger = Log4r::Logger.new("vagrant::util::retryable")
|
|
logger.info("Retryable exception raised: #{e.inspect}")
|
|
|
|
sleep opts[:sleep].to_f if opts[:sleep]
|
|
retry
|
|
end
|
|
raise
|
|
end
|
|
end
|
|
end
|
|
end
|
|
end
|