Sha256: 586d6b3b490137cee5860dc41ce9da9ab1075c6091ab90db3b856736e324d96e

Contents?: true

Size: 945 Bytes

Versions: 1

Compression:

Stored size: 945 Bytes

Contents

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

Version data entries

1 entries across 1 versions & 1 rubygems

Version Path
vagrant-cloudstack-1.2.0 vendor/bundle/bundler/gems/vagrant-c84e05fd063f/lib/vagrant/util/retryable.rb