Sha256: 3bb2f030671b569dad32761cc3136fdffbb9f40c330ea617d7957cecc39601f8

Contents?: true

Size: 1.03 KB

Versions: 8

Compression:

Stored size: 1.03 KB

Contents

require 'log4r'
require 'timeout'

module VagrantPlugins
  module Vmpooler
    module Action
      # This action will wait for a machine to reach a specific state or quit by timeout.
      class WaitForState
        def initialize(app, env, state, timeout)
          @app = app
          @logger = Log4r::Logger.new('vagrant_vmpooler::action::wait_for_state')
          @state = Array.new(state).flatten
          @timeout = timeout
        end

        def call(env)
          env[:result] = true
          state = env[:machine].state.id.to_sym

          if @state.include?(state)
            @logger.info("Machine already at status #{ state.to_s }")
          else
            @logger.info("Waiting for machine to reach state...")
            begin
              Timeout.timeout(@timeout) do
                sleep 2 until @state.include?(env[:machine].state.id)
              end
            rescue Timeout::Error
              env[:result] = false
            end

            @app.call(env)
          end
        end
      end
    end
  end
end

Version data entries

8 entries across 8 versions & 1 rubygems

Version Path
vagrant-vmpooler-0.2.0 lib/vagrant-vmpooler/action/wait_for_state.rb
vagrant-vmpooler-0.1.9 lib/vagrant-vmpooler/action/wait_for_state.rb
vagrant-vmpooler-0.1.8 lib/vagrant-vmpooler/action/wait_for_state.rb
vagrant-vmpooler-0.1.7 lib/vagrant-vmpooler/action/wait_for_state.rb
vagrant-vmpooler-0.1.6 lib/vagrant-vmpooler/action/wait_for_state.rb
vagrant-vmpooler-0.1.5 lib/vagrant-vmpooler/action/wait_for_state.rb
vagrant-vmpooler-0.1.4 lib/vagrant-vmpooler/action/wait_for_state.rb
vagrant-vmpooler-0.1.2 lib/vagrant-vmpooler/action/wait_for_state.rb