Sha256: f0a20d72bca595b7bcf6a5bb6caba571c910c234272dec6ba1f3a47213ea95f2
Contents?: true
Size: 1 KB
Versions: 1
Compression:
Stored size: 1 KB
Contents
require 'log4r' require 'timeout' require 'vagrant-openstack-illuin-provider/action/abstract_action' module VagrantPlugins module Openstack module Action class WaitForServerToStop < AbstractAction def initialize(app, _env, retry_interval = 3) @app = app @logger = Log4r::Logger.new('vagrant_openstack::action::stop_server') @retry_interval = retry_interval end def execute(env) if env[:machine].id env[:ui].info(I18n.t('vagrant_openstack.waiting_stop')) client = env[:openstack_client].nova config = env[:machine].provider_config Timeout.timeout(config.server_stop_timeout, Errors::Timeout) do while client.get_server_details(env, env[:machine].id)['status'] != 'SHUTOFF' sleep @retry_interval @logger.info('Waiting for server to stop') end end end @app.call(env) end end end end end
Version data entries
1 entries across 1 versions & 1 rubygems
Version | Path |
---|---|
vagrant-openstack-illuin-provider-0.12.0 | lib/vagrant-openstack-illuin-provider/action/wait_stop.rb |