class VagrantPlugins::Openstack::Action::WaitForServerToBeActive

Public Class Methods

new(app, _env, retry_interval = 3) click to toggle source
# File lib/vagrant-openstack-provider/action/wait_active.rb, line 10
def initialize(app, _env, retry_interval = 3)
  @app    = app
  @logger = Log4r::Logger.new('vagrant_openstack::action::start_server')
  @retry_interval = retry_interval
end

Public Instance Methods

execute(env) click to toggle source
# File lib/vagrant-openstack-provider/action/wait_active.rb, line 16
def execute(env)
  if env[:machine].id
    env[:ui].info(I18n.t('vagrant_openstack.waiting_start'))
    client = env[:openstack_client].nova
    config = env[:machine].provider_config
    Timeout.timeout(config.server_active_timeout, Errors::Timeout) do
      while client.get_server_details(env, env[:machine].id)['status'] != 'ACTIVE'
        sleep @retry_interval
        @logger.info('Waiting for server to be active')
      end
    end
  end
  @app.call(env)
end