Class: Vagrant::LXC::Action::Boot
- Inherits:
-
Object
- Object
- Vagrant::LXC::Action::Boot
- Defined in:
- lib/vagrant-lxc/action/boot.rb
Instance Method Summary collapse
- #call(env) ⇒ Object
-
#initialize(app, env) ⇒ Boot
constructor
A new instance of Boot.
-
#wait_for_boot ⇒ Object
Stolen from on VagrantPlugins::ProviderVirtualBox::Action::Boot.
Constructor Details
#initialize(app, env) ⇒ Boot
Returns a new instance of Boot.
5 6 7 |
# File 'lib/vagrant-lxc/action/boot.rb', line 5 def initialize(app, env) @app = app end |
Instance Method Details
#call(env) ⇒ Object
9 10 11 12 13 14 15 16 17 18 19 20 21 |
# File 'lib/vagrant-lxc/action/boot.rb', line 9 def call(env) @env = env config = env[:machine].provider_config config.customize 'utsname', env[:machine].id env[:ui].info I18n.t("vagrant_lxc.messages.starting") env[:machine].provider.driver.start(config.customizations) raise Vagrant::Errors::VMFailedToBoot if !wait_for_boot @app.call env end |
#wait_for_boot ⇒ Object
Stolen from on VagrantPlugins::ProviderVirtualBox::Action::Boot
24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 |
# File 'lib/vagrant-lxc/action/boot.rb', line 24 def wait_for_boot @env[:ui].info I18n.t("vagrant_lxc.messages.waiting_for_start") @env[:machine].config.ssh.max_tries.to_i.times do |i| if @env[:machine].communicate.ready? @env[:ui].info I18n.t("vagrant_lxc.messages.container_ready") return true end # Return true so that the vm_failed_to_boot error doesn't # get shown return true if @env[:interrupted] # TODO: Find out if there is a command to check if the machine is # starting, `lxc-monitor` shows this information, but I've # never seen it on `lxc-info` which is what it is being used # to determine container status # If the VM is not starting or running, something went wrong # and we need to show a useful error. state = @env[:machine].provider.state.id raise Vagrant::Errors::VMFailedToRun if state != :starting && state != :running sleep 2 if !@env["vagrant.test"] end @env[:ui].error I18n.t("vagrant.actions.vm.boot.failed") false end |