tnargav 1.3.5 → 1.3.6
Sign up to get free protection for your applications and to get access to all the features.
- data/lib/vagrant/action.rb +45 -0
- data/lib/vagrant/action/builder.rb +174 -0
- data/lib/vagrant/action/builtin/box_add.rb +92 -0
- data/lib/vagrant/action/builtin/call.rb +67 -0
- data/lib/vagrant/action/builtin/config_validate.rb +30 -0
- data/lib/vagrant/action/builtin/confirm.rb +39 -0
- data/lib/vagrant/action/builtin/destroy_confirm.rb +21 -0
- data/lib/vagrant/action/builtin/env_set.rb +24 -0
- data/lib/vagrant/action/builtin/graceful_halt.rb +82 -0
- data/lib/vagrant/action/builtin/handle_box_url.rb +86 -0
- data/lib/vagrant/action/builtin/handle_forwarded_port_collisions.rb +134 -0
- data/lib/vagrant/action/builtin/lock.rb +57 -0
- data/lib/vagrant/action/builtin/mixin_provisioners.rb +43 -0
- data/lib/vagrant/action/builtin/nfs.rb +128 -0
- data/lib/vagrant/action/builtin/provision.rb +79 -0
- data/lib/vagrant/action/builtin/provisioner_cleanup.rb +35 -0
- data/lib/vagrant/action/builtin/set_hostname.rb +27 -0
- data/lib/vagrant/action/builtin/ssh_exec.rb +42 -0
- data/lib/vagrant/action/builtin/ssh_run.rb +43 -0
- data/lib/vagrant/action/builtin/wait_for_communicator.rb +84 -0
- data/lib/vagrant/action/general/package.rb +103 -0
- data/lib/vagrant/action/hook.rb +107 -0
- data/lib/vagrant/action/runner.rb +69 -0
- data/lib/vagrant/action/warden.rb +104 -0
- data/lib/vagrant/batch_action.rb +113 -0
- data/lib/vagrant/box.rb +97 -0
- data/lib/vagrant/box_collection.rb +393 -0
- data/lib/vagrant/cli.rb +74 -0
- data/lib/vagrant/config.rb +61 -0
- data/lib/vagrant/config/loader.rb +222 -0
- data/lib/vagrant/config/v1.rb +9 -0
- data/lib/vagrant/config/v1/dummy_config.rb +13 -0
- data/lib/vagrant/config/v1/loader.rb +105 -0
- data/lib/vagrant/config/v1/root.rb +60 -0
- data/lib/vagrant/config/v2.rb +9 -0
- data/lib/vagrant/config/v2/dummy_config.rb +13 -0
- data/lib/vagrant/config/v2/loader.rb +141 -0
- data/lib/vagrant/config/v2/root.rb +111 -0
- data/lib/vagrant/config/v2/util.rb +21 -0
- data/lib/vagrant/config/version_base.rb +80 -0
- data/lib/vagrant/environment.rb +819 -0
- data/lib/vagrant/errors.rb +614 -0
- data/lib/vagrant/guest.rb +172 -0
- data/lib/vagrant/hosts.rb +28 -0
- data/lib/vagrant/machine.rb +319 -0
- data/lib/vagrant/machine_state.rb +45 -0
- data/lib/vagrant/plugin.rb +6 -0
- data/lib/vagrant/plugin/v1.rb +19 -0
- data/lib/vagrant/plugin/v1/command.rb +169 -0
- data/lib/vagrant/plugin/v1/communicator.rb +98 -0
- data/lib/vagrant/plugin/v1/config.rb +112 -0
- data/lib/vagrant/plugin/v1/errors.rb +15 -0
- data/lib/vagrant/plugin/v1/guest.rb +92 -0
- data/lib/vagrant/plugin/v1/host.rb +66 -0
- data/lib/vagrant/plugin/v1/manager.rb +131 -0
- data/lib/vagrant/plugin/v1/plugin.rb +229 -0
- data/lib/vagrant/plugin/v1/provider.rb +68 -0
- data/lib/vagrant/plugin/v1/provisioner.rb +50 -0
- data/lib/vagrant/plugin/v2.rb +22 -0
- data/lib/vagrant/plugin/v2/command.rb +237 -0
- data/lib/vagrant/plugin/v2/communicator.rb +119 -0
- data/lib/vagrant/plugin/v2/components.rb +47 -0
- data/lib/vagrant/plugin/v2/config.rb +136 -0
- data/lib/vagrant/plugin/v2/errors.rb +15 -0
- data/lib/vagrant/plugin/v2/guest.rb +23 -0
- data/lib/vagrant/plugin/v2/host.rb +66 -0
- data/lib/vagrant/plugin/v2/manager.rb +173 -0
- data/lib/vagrant/plugin/v2/plugin.rb +226 -0
- data/lib/vagrant/plugin/v2/provider.rb +69 -0
- data/lib/vagrant/plugin/v2/provisioner.rb +53 -0
- data/lib/vagrant/registry.rb +78 -0
- data/lib/vagrant/ui.rb +215 -0
- data/lib/vagrant/util.rb +12 -0
- data/lib/vagrant/util/ansi_escape_code_remover.rb +34 -0
- data/lib/vagrant/util/busy.rb +59 -0
- data/lib/vagrant/util/counter.rb +24 -0
- data/lib/vagrant/util/downloader.rb +151 -0
- data/lib/vagrant/util/file_checksum.rb +38 -0
- data/lib/vagrant/util/file_mode.rb +12 -0
- data/lib/vagrant/util/hash_with_indifferent_access.rb +63 -0
- data/lib/vagrant/util/is_port_open.rb +38 -0
- data/lib/vagrant/util/line_ending_helpers.rb +14 -0
- data/lib/vagrant/util/network_ip.rb +28 -0
- data/lib/vagrant/util/platform.rb +101 -0
- data/lib/vagrant/util/retryable.rb +31 -0
- data/lib/vagrant/util/safe_chdir.rb +33 -0
- data/lib/vagrant/util/safe_exec.rb +36 -0
- data/lib/vagrant/util/safe_puts.rb +31 -0
- data/lib/vagrant/util/scoped_hash_override.rb +45 -0
- data/lib/vagrant/util/ssh.rb +155 -0
- data/lib/vagrant/util/stacked_proc_runner.rb +35 -0
- data/lib/vagrant/util/string_block_editor.rb +77 -0
- data/lib/vagrant/util/subprocess.rb +294 -0
- data/lib/vagrant/util/template_renderer.rb +83 -0
- data/lib/vagrant/util/which.rb +43 -0
- data/lib/vagrant/version.rb +6 -0
- data/plugins/commands/box/command/add.rb +51 -0
- data/plugins/commands/box/command/list.rb +41 -0
- data/plugins/commands/box/command/remove.rb +57 -0
- data/plugins/commands/box/command/repackage.rb +43 -0
- data/plugins/commands/box/command/root.rb +75 -0
- data/plugins/commands/box/plugin.rb +15 -0
- data/plugins/commands/destroy/command.rb +36 -0
- data/plugins/commands/destroy/plugin.rb +18 -0
- data/plugins/commands/halt/command.rb +33 -0
- data/plugins/commands/halt/plugin.rb +18 -0
- data/plugins/commands/help/command.rb +12 -0
- data/plugins/commands/help/plugin.rb +17 -0
- data/plugins/commands/init/command.rb +40 -0
- data/plugins/commands/init/plugin.rb +18 -0
- data/plugins/commands/package/command.rb +83 -0
- data/plugins/commands/package/plugin.rb +18 -0
- data/plugins/commands/plugin/action.rb +63 -0
- data/plugins/commands/plugin/action/bundler_check.rb +25 -0
- data/plugins/commands/plugin/action/install_gem.rb +106 -0
- data/plugins/commands/plugin/action/license_plugin.rb +54 -0
- data/plugins/commands/plugin/action/list_plugins.rb +54 -0
- data/plugins/commands/plugin/action/plugin_exists_check.rb +26 -0
- data/plugins/commands/plugin/action/prune_gems.rb +149 -0
- data/plugins/commands/plugin/action/uninstall_plugin.rb +23 -0
- data/plugins/commands/plugin/command/base.rb +22 -0
- data/plugins/commands/plugin/command/install.rb +41 -0
- data/plugins/commands/plugin/command/license.rb +31 -0
- data/plugins/commands/plugin/command/list.rb +28 -0
- data/plugins/commands/plugin/command/mixin_install_opts.rb +30 -0
- data/plugins/commands/plugin/command/root.rb +80 -0
- data/plugins/commands/plugin/command/uninstall.rb +28 -0
- data/plugins/commands/plugin/command/update.rb +41 -0
- data/plugins/commands/plugin/gem_helper.rb +74 -0
- data/plugins/commands/plugin/plugin.rb +22 -0
- data/plugins/commands/plugin/state_file.rb +57 -0
- data/plugins/commands/provision/command.rb +34 -0
- data/plugins/commands/provision/plugin.rb +18 -0
- data/plugins/commands/reload/command.rb +41 -0
- data/plugins/commands/reload/plugin.rb +18 -0
- data/plugins/commands/resume/command.rb +25 -0
- data/plugins/commands/resume/plugin.rb +17 -0
- data/plugins/commands/ssh/command.rb +63 -0
- data/plugins/commands/ssh/plugin.rb +17 -0
- data/plugins/commands/ssh_config/command.rb +49 -0
- data/plugins/commands/ssh_config/plugin.rb +18 -0
- data/plugins/commands/status/command.rb +44 -0
- data/plugins/commands/status/plugin.rb +18 -0
- data/plugins/commands/suspend/command.rb +25 -0
- data/plugins/commands/suspend/plugin.rb +18 -0
- data/plugins/commands/up/command.rb +67 -0
- data/plugins/commands/up/plugin.rb +17 -0
- data/plugins/commands/up/start_mixins.rb +37 -0
- data/plugins/communicators/ssh/communicator.rb +400 -0
- data/plugins/communicators/ssh/plugin.rb +19 -0
- data/plugins/guests/arch/cap/change_host_name.rb +17 -0
- data/plugins/guests/arch/cap/configure_networks.rb +30 -0
- data/plugins/guests/arch/guest.rb +11 -0
- data/plugins/guests/arch/plugin.rb +25 -0
- data/plugins/guests/coreos/cap/change_host_name.rb +15 -0
- data/plugins/guests/coreos/cap/configure_networks.rb +72 -0
- data/plugins/guests/coreos/guest.rb +9 -0
- data/plugins/guests/coreos/plugin.rb +25 -0
- data/plugins/guests/darwin/cap/change_host_name.rb +14 -0
- data/plugins/guests/darwin/cap/configure_networks.rb +52 -0
- data/plugins/guests/darwin/cap/halt.rb +16 -0
- data/plugins/guests/darwin/cap/mount_nfs_folder.rb +25 -0
- data/plugins/guests/darwin/cap/mount_vmware_shared_folder.rb +36 -0
- data/plugins/guests/darwin/cap/shell_expand_guest_path.rb +26 -0
- data/plugins/guests/darwin/cap/verify_vmware_hgfs.rb +12 -0
- data/plugins/guests/darwin/guest.rb +15 -0
- data/plugins/guests/darwin/plugin.rb +50 -0
- data/plugins/guests/debian/cap/change_host_name.rb +19 -0
- data/plugins/guests/debian/cap/configure_networks.rb +61 -0
- data/plugins/guests/debian/guest.rb +9 -0
- data/plugins/guests/debian/plugin.rb +25 -0
- data/plugins/guests/fedora/cap/configure_networks.rb +59 -0
- data/plugins/guests/fedora/cap/network_scripts_dir.rb +15 -0
- data/plugins/guests/fedora/guest.rb +11 -0
- data/plugins/guests/fedora/plugin.rb +25 -0
- data/plugins/guests/freebsd/cap/change_host_name.rb +14 -0
- data/plugins/guests/freebsd/cap/configure_networks.rb +39 -0
- data/plugins/guests/freebsd/cap/halt.rb +16 -0
- data/plugins/guests/freebsd/cap/mount_nfs_folder.rb +14 -0
- data/plugins/guests/freebsd/guest.rb +14 -0
- data/plugins/guests/freebsd/plugin.rb +35 -0
- data/plugins/guests/gentoo/cap/change_host_name.rb +17 -0
- data/plugins/guests/gentoo/cap/configure_networks.rb +43 -0
- data/plugins/guests/gentoo/guest.rb +9 -0
- data/plugins/guests/gentoo/plugin.rb +25 -0
- data/plugins/guests/linux/cap/halt.rb +16 -0
- data/plugins/guests/linux/cap/mount_nfs.rb +38 -0
- data/plugins/guests/linux/cap/mount_virtualbox_shared_folder.rb +59 -0
- data/plugins/guests/linux/cap/read_ip_address.rb +17 -0
- data/plugins/guests/linux/cap/shell_expand_guest_path.rb +29 -0
- data/plugins/guests/linux/guest.rb +11 -0
- data/plugins/guests/linux/plugin.rb +40 -0
- data/plugins/guests/omnios/cap/change_host_name.rb +17 -0
- data/plugins/guests/omnios/guest.rb +11 -0
- data/plugins/guests/omnios/plugin.rb +20 -0
- data/plugins/guests/openbsd/cap/change_host_name.rb +14 -0
- data/plugins/guests/openbsd/cap/configure_networks.rb +40 -0
- data/plugins/guests/openbsd/cap/halt.rb +16 -0
- data/plugins/guests/openbsd/cap/mount_nfs_folder.rb +14 -0
- data/plugins/guests/openbsd/guest.rb +11 -0
- data/plugins/guests/openbsd/plugin.rb +35 -0
- data/plugins/guests/pld/cap/network_scripts_dir.rb +11 -0
- data/plugins/guests/pld/guest.rb +11 -0
- data/plugins/guests/pld/plugin.rb +20 -0
- data/plugins/guests/redhat/cap/change_host_name.rb +18 -0
- data/plugins/guests/redhat/cap/configure_networks.rb +60 -0
- data/plugins/guests/redhat/cap/network_scripts_dir.rb +11 -0
- data/plugins/guests/redhat/guest.rb +11 -0
- data/plugins/guests/redhat/plugin.rb +30 -0
- data/plugins/guests/solaris/cap/change_host_name.rb +17 -0
- data/plugins/guests/solaris/cap/configure_networks.rb +25 -0
- data/plugins/guests/solaris/cap/halt.rb +22 -0
- data/plugins/guests/solaris/cap/mount_virtualbox_shared_folder.rb +31 -0
- data/plugins/guests/solaris/config.rb +18 -0
- data/plugins/guests/solaris/guest.rb +14 -0
- data/plugins/guests/solaris/plugin.rb +40 -0
- data/plugins/guests/solaris11/cap/change_host_name.rb +25 -0
- data/plugins/guests/solaris11/cap/configure_networks.rb +32 -0
- data/plugins/guests/solaris11/cap/halt.rb +26 -0
- data/plugins/guests/solaris11/cap/mount_virtualbox_shared_folder.rb +35 -0
- data/plugins/guests/solaris11/config.rb +22 -0
- data/plugins/guests/solaris11/guest.rb +15 -0
- data/plugins/guests/solaris11/plugin.rb +44 -0
- data/plugins/guests/suse/cap/change_host_name.rb +18 -0
- data/plugins/guests/suse/cap/configure_networks.rb +60 -0
- data/plugins/guests/suse/cap/network_scripts_dir.rb +11 -0
- data/plugins/guests/suse/guest.rb +11 -0
- data/plugins/guests/suse/plugin.rb +30 -0
- data/plugins/guests/ubuntu/cap/change_host_name.rb +24 -0
- data/plugins/guests/ubuntu/cap/mount_nfs.rb +19 -0
- data/plugins/guests/ubuntu/cap/mount_virtualbox_shared_folder.rb +14 -0
- data/plugins/guests/ubuntu/guest.rb +13 -0
- data/plugins/guests/ubuntu/plugin.rb +30 -0
- data/plugins/hosts/arch/host.rb +45 -0
- data/plugins/hosts/arch/plugin.rb +15 -0
- data/plugins/hosts/bsd/host.rb +178 -0
- data/plugins/hosts/bsd/plugin.rb +15 -0
- data/plugins/hosts/fedora/host.rb +57 -0
- data/plugins/hosts/fedora/plugin.rb +15 -0
- data/plugins/hosts/freebsd/host.rb +43 -0
- data/plugins/hosts/freebsd/plugin.rb +15 -0
- data/plugins/hosts/gentoo/host.rb +26 -0
- data/plugins/hosts/gentoo/plugin.rb +15 -0
- data/plugins/hosts/linux/host.rb +128 -0
- data/plugins/hosts/linux/plugin.rb +15 -0
- data/plugins/hosts/opensuse/host.rb +36 -0
- data/plugins/hosts/opensuse/plugin.rb +15 -0
- data/plugins/hosts/slackware/host.rb +26 -0
- data/plugins/hosts/slackware/plugin.rb +15 -0
- data/plugins/hosts/windows/host.rb +17 -0
- data/plugins/hosts/windows/plugin.rb +15 -0
- data/plugins/kernel_v1/config/nfs.rb +20 -0
- data/plugins/kernel_v1/config/package.rb +17 -0
- data/plugins/kernel_v1/config/ssh.rb +46 -0
- data/plugins/kernel_v1/config/vagrant.rb +31 -0
- data/plugins/kernel_v1/config/vm.rb +187 -0
- data/plugins/kernel_v1/plugin.rb +44 -0
- data/plugins/kernel_v2/config/nfs.rb +14 -0
- data/plugins/kernel_v2/config/package.rb +13 -0
- data/plugins/kernel_v2/config/ssh.rb +68 -0
- data/plugins/kernel_v2/config/ssh_connect.rb +40 -0
- data/plugins/kernel_v2/config/vagrant.rb +13 -0
- data/plugins/kernel_v2/config/vm.rb +486 -0
- data/plugins/kernel_v2/config/vm_provisioner.rb +55 -0
- data/plugins/kernel_v2/config/vm_subvm.rb +30 -0
- data/plugins/kernel_v2/plugin.rb +44 -0
- data/plugins/providers/virtualbox/action.rb +324 -0
- data/plugins/providers/virtualbox/action/boot.rb +23 -0
- data/plugins/providers/virtualbox/action/check_accessible.rb +23 -0
- data/plugins/providers/virtualbox/action/check_created.rb +21 -0
- data/plugins/providers/virtualbox/action/check_guest_additions.rb +45 -0
- data/plugins/providers/virtualbox/action/check_running.rb +21 -0
- data/plugins/providers/virtualbox/action/check_virtualbox.rb +22 -0
- data/plugins/providers/virtualbox/action/clean_machine_folder.rb +43 -0
- data/plugins/providers/virtualbox/action/clear_forwarded_ports.rb +18 -0
- data/plugins/providers/virtualbox/action/clear_network_interfaces.rb +31 -0
- data/plugins/providers/virtualbox/action/clear_shared_folders.rb +17 -0
- data/plugins/providers/virtualbox/action/created.rb +20 -0
- data/plugins/providers/virtualbox/action/customize.rb +43 -0
- data/plugins/providers/virtualbox/action/destroy.rb +19 -0
- data/plugins/providers/virtualbox/action/destroy_unused_network_interfaces.rb +23 -0
- data/plugins/providers/virtualbox/action/discard_state.rb +20 -0
- data/plugins/providers/virtualbox/action/export.rb +57 -0
- data/plugins/providers/virtualbox/action/forced_halt.rb +25 -0
- data/plugins/providers/virtualbox/action/forward_ports.rb +89 -0
- data/plugins/providers/virtualbox/action/import.rb +54 -0
- data/plugins/providers/virtualbox/action/is_paused.rb +20 -0
- data/plugins/providers/virtualbox/action/is_running.rb +20 -0
- data/plugins/providers/virtualbox/action/is_saved.rb +20 -0
- data/plugins/providers/virtualbox/action/match_mac_address.rb +21 -0
- data/plugins/providers/virtualbox/action/message_already_running.rb +16 -0
- data/plugins/providers/virtualbox/action/message_not_created.rb +16 -0
- data/plugins/providers/virtualbox/action/message_not_running.rb +16 -0
- data/plugins/providers/virtualbox/action/message_will_not_destroy.rb +17 -0
- data/plugins/providers/virtualbox/action/network.rb +424 -0
- data/plugins/providers/virtualbox/action/package.rb +20 -0
- data/plugins/providers/virtualbox/action/package_vagrantfile.rb +33 -0
- data/plugins/providers/virtualbox/action/prepare_forwarded_port_collision_params.rb +35 -0
- data/plugins/providers/virtualbox/action/prepare_nfs_settings.rb +69 -0
- data/plugins/providers/virtualbox/action/prune_nfs_exports.rb +20 -0
- data/plugins/providers/virtualbox/action/resume.rb +25 -0
- data/plugins/providers/virtualbox/action/sane_defaults.rb +91 -0
- data/plugins/providers/virtualbox/action/set_name.rb +52 -0
- data/plugins/providers/virtualbox/action/setup_package_files.rb +51 -0
- data/plugins/providers/virtualbox/action/share_folders.rb +128 -0
- data/plugins/providers/virtualbox/action/suspend.rb +20 -0
- data/plugins/providers/virtualbox/config.rb +123 -0
- data/plugins/providers/virtualbox/driver/base.rb +374 -0
- data/plugins/providers/virtualbox/driver/meta.rb +148 -0
- data/plugins/providers/virtualbox/driver/version_4_0.rb +485 -0
- data/plugins/providers/virtualbox/driver/version_4_1.rb +485 -0
- data/plugins/providers/virtualbox/driver/version_4_2.rb +499 -0
- data/plugins/providers/virtualbox/model/forwarded_port.rb +70 -0
- data/plugins/providers/virtualbox/plugin.rb +42 -0
- data/plugins/providers/virtualbox/provider.rb +92 -0
- data/plugins/providers/virtualbox/util/compile_forwarded_ports.rb +35 -0
- data/plugins/provisioners/ansible/config.rb +89 -0
- data/plugins/provisioners/ansible/plugin.rb +23 -0
- data/plugins/provisioners/ansible/provisioner.rb +100 -0
- data/plugins/provisioners/cfengine/cap/debian/cfengine_install.rb +19 -0
- data/plugins/provisioners/cfengine/cap/linux/cfengine_installed.rb +14 -0
- data/plugins/provisioners/cfengine/cap/linux/cfengine_needs_bootstrap.rb +34 -0
- data/plugins/provisioners/cfengine/cap/redhat/cfengine_install.rb +24 -0
- data/plugins/provisioners/cfengine/config.rb +126 -0
- data/plugins/provisioners/cfengine/plugin.rb +42 -0
- data/plugins/provisioners/cfengine/provisioner.rb +135 -0
- data/plugins/provisioners/chef/config/base.rb +116 -0
- data/plugins/provisioners/chef/config/chef_client.rb +66 -0
- data/plugins/provisioners/chef/config/chef_solo.rb +94 -0
- data/plugins/provisioners/chef/plugin.rb +33 -0
- data/plugins/provisioners/chef/provisioner/base.rb +113 -0
- data/plugins/provisioners/chef/provisioner/chef_client.rb +126 -0
- data/plugins/provisioners/chef/provisioner/chef_solo.rb +195 -0
- data/plugins/provisioners/file/config.rb +29 -0
- data/plugins/provisioners/file/plugin.rb +23 -0
- data/plugins/provisioners/file/provisioner.rb +16 -0
- data/plugins/provisioners/puppet/config/puppet.rb +93 -0
- data/plugins/provisioners/puppet/config/puppet_server.rb +16 -0
- data/plugins/provisioners/puppet/plugin.rb +33 -0
- data/plugins/provisioners/puppet/provisioner/puppet.rb +146 -0
- data/plugins/provisioners/puppet/provisioner/puppet_server.rb +74 -0
- data/plugins/provisioners/salt/bootstrap-salt.sh +6 -0
- data/plugins/provisioners/salt/config.rb +105 -0
- data/plugins/provisioners/salt/errors.rb +11 -0
- data/plugins/provisioners/salt/plugin.rb +22 -0
- data/plugins/provisioners/salt/provisioner.rb +249 -0
- data/plugins/provisioners/shell/config.rb +65 -0
- data/plugins/provisioners/shell/plugin.rb +23 -0
- data/plugins/provisioners/shell/provisioner.rb +98 -0
- data/templates/commands/init/Vagrantfile.erb +118 -0
- data/templates/commands/ssh_config/config.erb +20 -0
- data/templates/config/messages.erb +14 -0
- data/templates/config/validation_failed.erb +7 -0
- data/templates/guests/arch/network_dhcp.erb +4 -0
- data/templates/guests/arch/network_static.erb +5 -0
- data/templates/guests/coreos/etcd.service.erb +10 -0
- data/templates/guests/debian/network_dhcp.erb +11 -0
- data/templates/guests/debian/network_static.erb +7 -0
- data/templates/guests/fedora/network_dhcp.erb +6 -0
- data/templates/guests/fedora/network_static.erb +12 -0
- data/templates/guests/freebsd/network_dhcp.erb +3 -0
- data/templates/guests/freebsd/network_static.erb +3 -0
- data/templates/guests/gentoo/network_dhcp.erb +4 -0
- data/templates/guests/gentoo/network_static.erb +4 -0
- data/templates/guests/openbsd/network_dhcp.erb +1 -0
- data/templates/guests/openbsd/network_static.erb +1 -0
- data/templates/guests/redhat/network_dhcp.erb +6 -0
- data/templates/guests/redhat/network_static.erb +8 -0
- data/templates/guests/suse/network_dhcp.erb +6 -0
- data/templates/guests/suse/network_static.erb +10 -0
- data/templates/locales/en.yml +1248 -0
- data/templates/nfs/exports.erb +5 -0
- data/templates/nfs/exports_freebsd.erb +5 -0
- data/templates/nfs/exports_linux.erb +7 -0
- data/templates/provisioners/chef_client/client.erb +41 -0
- data/templates/provisioners/chef_solo/solo.erb +45 -0
- data/test/acceptance/base.rb +48 -0
- data/test/acceptance/box_test.rb +99 -0
- data/test/acceptance/destroy_test.rb +37 -0
- data/test/acceptance/halt_test.rb +72 -0
- data/test/acceptance/init_test.rb +33 -0
- data/test/acceptance/networking/host_only_test.rb +37 -0
- data/test/acceptance/networking/port_forward_test.rb +125 -0
- data/test/acceptance/package_test.rb +46 -0
- data/test/acceptance/provisioning/basic_test.rb +61 -0
- data/test/acceptance/provisioning/chef_solo_test.rb +37 -0
- data/test/acceptance/provisioning/shell_test.rb +53 -0
- data/test/acceptance/resume_test.rb +17 -0
- data/test/acceptance/shared_folders_test.rb +84 -0
- data/test/acceptance/skeletons/chef_solo_basic/README.md +3 -0
- data/test/acceptance/skeletons/chef_solo_basic/cookbooks/basic/recipes/default.rb +5 -0
- data/test/acceptance/skeletons/chef_solo_json/README.md +3 -0
- data/test/acceptance/skeletons/chef_solo_json/cookbooks/basic/recipes/default.rb +6 -0
- data/test/acceptance/skeletons/provisioner_multi/README.md +3 -0
- data/test/acceptance/skeletons/provisioner_multi/cookbooks/basic/recipes/default.rb +5 -0
- data/test/acceptance/ssh_test.rb +46 -0
- data/test/acceptance/support/config.rb +42 -0
- data/test/acceptance/support/isolated_environment.rb +118 -0
- data/test/acceptance/support/matchers/have_color.rb +9 -0
- data/test/acceptance/support/matchers/match_output.rb +14 -0
- data/test/acceptance/support/matchers/succeed.rb +14 -0
- data/test/acceptance/support/network_tests.rb +29 -0
- data/test/acceptance/support/output.rb +95 -0
- data/test/acceptance/support/shared/base_context.rb +72 -0
- data/test/acceptance/support/shared/command_examples.rb +33 -0
- data/test/acceptance/support/virtualbox.rb +36 -0
- data/test/acceptance/suspend_test.rb +56 -0
- data/test/acceptance/up_basic_test.rb +33 -0
- data/test/acceptance/up_with_box_url.rb +40 -0
- data/test/acceptance/vagrant_test.rb +47 -0
- data/test/acceptance/version_test.rb +15 -0
- data/test/config/acceptance_boxes.yml +7 -0
- data/test/support/isolated_environment.rb +46 -0
- data/test/support/tempdir.rb +43 -0
- data/test/unit/base.rb +27 -0
- data/test/unit/support/dummy_provider.rb +16 -0
- data/test/unit/support/isolated_environment.rb +179 -0
- data/test/unit/support/shared/base_context.rb +104 -0
- data/test/unit/vagrant/action/builder_test.rb +242 -0
- data/test/unit/vagrant/action/builtin/call_test.rb +145 -0
- data/test/unit/vagrant/action/builtin/confirm_test.rb +36 -0
- data/test/unit/vagrant/action/builtin/env_set_test.rb +20 -0
- data/test/unit/vagrant/action/builtin/graceful_halt_test.rb +60 -0
- data/test/unit/vagrant/action/builtin/lock_test.rb +98 -0
- data/test/unit/vagrant/action/builtin/ssh_exec_test.rb +57 -0
- data/test/unit/vagrant/action/hook_test.rb +120 -0
- data/test/unit/vagrant/action/runner_test.rb +71 -0
- data/test/unit/vagrant/action/warden_test.rb +92 -0
- data/test/unit/vagrant/batch_action_test.rb +36 -0
- data/test/unit/vagrant/box_collection_test.rb +237 -0
- data/test/unit/vagrant/box_test.rb +122 -0
- data/test/unit/vagrant/cli_test.rb +28 -0
- data/test/unit/vagrant/config/loader_test.rb +184 -0
- data/test/unit/vagrant/config/v1/dummy_config_test.rb +24 -0
- data/test/unit/vagrant/config/v1/loader_test.rb +145 -0
- data/test/unit/vagrant/config/v1/root_test.rb +40 -0
- data/test/unit/vagrant/config/v2/dummy_config_test.rb +24 -0
- data/test/unit/vagrant/config/v2/loader_test.rb +151 -0
- data/test/unit/vagrant/config/v2/root_test.rb +115 -0
- data/test/unit/vagrant/config/v2/util_test.rb +21 -0
- data/test/unit/vagrant/config_test.rb +66 -0
- data/test/unit/vagrant/environment_test.rb +746 -0
- data/test/unit/vagrant/guest_test.rb +179 -0
- data/test/unit/vagrant/hosts_test.rb +37 -0
- data/test/unit/vagrant/machine_state_test.rb +26 -0
- data/test/unit/vagrant/machine_test.rb +384 -0
- data/test/unit/vagrant/plugin/v1/command_test.rb +143 -0
- data/test/unit/vagrant/plugin/v1/communicator_test.rb +9 -0
- data/test/unit/vagrant/plugin/v1/config_test.rb +50 -0
- data/test/unit/vagrant/plugin/v1/host_test.rb +5 -0
- data/test/unit/vagrant/plugin/v1/manager_test.rb +114 -0
- data/test/unit/vagrant/plugin/v1/plugin_test.rb +267 -0
- data/test/unit/vagrant/plugin/v1/provider_test.rb +18 -0
- data/test/unit/vagrant/plugin/v2/command_test.rb +238 -0
- data/test/unit/vagrant/plugin/v2/communicator_test.rb +9 -0
- data/test/unit/vagrant/plugin/v2/components_test.rb +17 -0
- data/test/unit/vagrant/plugin/v2/config_test.rb +60 -0
- data/test/unit/vagrant/plugin/v2/host_test.rb +5 -0
- data/test/unit/vagrant/plugin/v2/manager_test.rb +174 -0
- data/test/unit/vagrant/plugin/v2/plugin_test.rb +305 -0
- data/test/unit/vagrant/plugin/v2/provider_test.rb +18 -0
- data/test/unit/vagrant/registry_test.rb +128 -0
- data/test/unit/vagrant/util/ansi_escape_code_remover_test.rb +16 -0
- data/test/unit/vagrant/util/downloader_test.rb +57 -0
- data/test/unit/vagrant/util/file_checksum_test.rb +23 -0
- data/test/unit/vagrant/util/hash_with_indifferent_access_test.rb +38 -0
- data/test/unit/vagrant/util/is_port_open_test.rb +53 -0
- data/test/unit/vagrant/util/line_endings_helper_test.rb +16 -0
- data/test/unit/vagrant/util/network_ip_test.rb +17 -0
- data/test/unit/vagrant/util/retryable_test.rb +106 -0
- data/test/unit/vagrant/util/safe_chdir_test.rb +43 -0
- data/test/unit/vagrant/util/scoped_hash_override_test.rb +48 -0
- data/test/unit/vagrant/util/ssh_test.rb +30 -0
- data/test/unit/vagrant/util/string_block_editor_test.rb +106 -0
- data/test/unit/vagrant/util/which_test.rb +43 -0
- data/test/unit/vagrant_test.rb +74 -0
- data/tnargav.gemspec +1 -1
- metadata +477 -1
@@ -0,0 +1,151 @@
|
|
1
|
+
require "ostruct"
|
2
|
+
|
3
|
+
require File.expand_path("../../../../base", __FILE__)
|
4
|
+
|
5
|
+
describe Vagrant::Config::V2::Loader do
|
6
|
+
include_context "unit"
|
7
|
+
|
8
|
+
before(:each) do
|
9
|
+
# Force the V2 loader to believe that we are in V2
|
10
|
+
stub_const("Vagrant::Config::CURRENT_VERSION", "2")
|
11
|
+
end
|
12
|
+
|
13
|
+
describe "empty" do
|
14
|
+
it "returns an empty configuration object" do
|
15
|
+
result = described_class.init
|
16
|
+
result.should be_kind_of(Vagrant::Config::V2::Root)
|
17
|
+
end
|
18
|
+
end
|
19
|
+
|
20
|
+
describe "finalizing" do
|
21
|
+
it "should call `#finalize` on the configuration object" do
|
22
|
+
# Register a plugin for our test
|
23
|
+
register_plugin("2") do |plugin|
|
24
|
+
plugin.config "foo" do
|
25
|
+
Class.new do
|
26
|
+
attr_accessor :bar
|
27
|
+
|
28
|
+
def finalize!
|
29
|
+
@bar = "finalized"
|
30
|
+
end
|
31
|
+
end
|
32
|
+
end
|
33
|
+
end
|
34
|
+
|
35
|
+
# Create the proc we're testing
|
36
|
+
config_proc = Proc.new do |config|
|
37
|
+
config.foo.bar = "value"
|
38
|
+
end
|
39
|
+
|
40
|
+
# Test that it works properly
|
41
|
+
config = described_class.load(config_proc)
|
42
|
+
config.foo.bar.should == "value"
|
43
|
+
|
44
|
+
# Finalize it
|
45
|
+
described_class.finalize(config)
|
46
|
+
config.foo.bar.should == "finalized"
|
47
|
+
end
|
48
|
+
end
|
49
|
+
|
50
|
+
describe "loading" do
|
51
|
+
it "should configure with all plugin config keys loaded" do
|
52
|
+
# Register a plugin for our test
|
53
|
+
register_plugin("2") do |plugin|
|
54
|
+
plugin.config("foo") { OpenStruct }
|
55
|
+
end
|
56
|
+
|
57
|
+
# Create the proc we're testing
|
58
|
+
config_proc = Proc.new do |config|
|
59
|
+
config.foo.bar = "value"
|
60
|
+
end
|
61
|
+
|
62
|
+
# Test that it works properly
|
63
|
+
config = described_class.load(config_proc)
|
64
|
+
config.foo.bar.should == "value"
|
65
|
+
end
|
66
|
+
end
|
67
|
+
|
68
|
+
describe "merging" do
|
69
|
+
it "should merge available configuration keys" do
|
70
|
+
old = Vagrant::Config::V2::Root.new({ :foo => Object })
|
71
|
+
new = Vagrant::Config::V2::Root.new({ :bar => Object })
|
72
|
+
result = described_class.merge(old, new)
|
73
|
+
result.foo.should be_kind_of(Object)
|
74
|
+
result.bar.should be_kind_of(Object)
|
75
|
+
end
|
76
|
+
|
77
|
+
it "should merge instantiated objects" do
|
78
|
+
config_class = Class.new do
|
79
|
+
attr_accessor :value
|
80
|
+
end
|
81
|
+
|
82
|
+
old = Vagrant::Config::V2::Root.new({ :foo => config_class })
|
83
|
+
old.foo.value = "old"
|
84
|
+
|
85
|
+
new = Vagrant::Config::V2::Root.new({ :bar => config_class })
|
86
|
+
new.bar.value = "new"
|
87
|
+
|
88
|
+
result = described_class.merge(old, new)
|
89
|
+
result.foo.value.should == "old"
|
90
|
+
result.bar.value.should == "new"
|
91
|
+
end
|
92
|
+
|
93
|
+
it "should merge conflicting classes by calling `merge`" do
|
94
|
+
config_class = Class.new do
|
95
|
+
attr_accessor :value
|
96
|
+
|
97
|
+
def merge(new)
|
98
|
+
result = self.class.new
|
99
|
+
result.value = @value + new.value
|
100
|
+
result
|
101
|
+
end
|
102
|
+
end
|
103
|
+
|
104
|
+
old = Vagrant::Config::V2::Root.new({ :foo => config_class })
|
105
|
+
old.foo.value = 10
|
106
|
+
|
107
|
+
new = Vagrant::Config::V2::Root.new({ :foo => config_class })
|
108
|
+
new.foo.value = 15
|
109
|
+
|
110
|
+
result = described_class.merge(old, new)
|
111
|
+
result.foo.value.should == 25
|
112
|
+
end
|
113
|
+
end
|
114
|
+
|
115
|
+
describe "upgrading" do
|
116
|
+
it "should continue fine if the key doesn't implement upgrade" do
|
117
|
+
# Make an old V1 root object
|
118
|
+
old = Vagrant::Config::V1::Root.new({ :foo => Class.new })
|
119
|
+
|
120
|
+
# It should work fine
|
121
|
+
expect { result = described_class.upgrade(old) }.to_not raise_error
|
122
|
+
end
|
123
|
+
|
124
|
+
it "should upgrade the config if it implements the upgrade method" do
|
125
|
+
# Create the old V1 class that will be upgraded
|
126
|
+
config_class = Class.new do
|
127
|
+
attr_accessor :value
|
128
|
+
|
129
|
+
def upgrade(new)
|
130
|
+
new.foo.value = value * 2
|
131
|
+
|
132
|
+
[["foo"], ["bar"]]
|
133
|
+
end
|
134
|
+
end
|
135
|
+
|
136
|
+
# Create the new V2 plugin it is writing to
|
137
|
+
register_plugin("2") do |p|
|
138
|
+
p.config("foo") { OpenStruct }
|
139
|
+
end
|
140
|
+
|
141
|
+
# Test it out!
|
142
|
+
old = Vagrant::Config::V1::Root.new({ :foo => config_class })
|
143
|
+
old.foo.value = 5
|
144
|
+
|
145
|
+
data = described_class.upgrade(old)
|
146
|
+
data[0].foo.value.should == 10
|
147
|
+
data[1].should == ["foo"]
|
148
|
+
data[2].should == ["bar"]
|
149
|
+
end
|
150
|
+
end
|
151
|
+
end
|
@@ -0,0 +1,115 @@
|
|
1
|
+
require "set"
|
2
|
+
|
3
|
+
require File.expand_path("../../../../base", __FILE__)
|
4
|
+
|
5
|
+
describe Vagrant::Config::V2::Root do
|
6
|
+
include_context "unit"
|
7
|
+
|
8
|
+
it "should provide access to config objects" do
|
9
|
+
foo_class = Class.new
|
10
|
+
map = { :foo => foo_class }
|
11
|
+
|
12
|
+
instance = described_class.new(map)
|
13
|
+
foo = instance.foo
|
14
|
+
foo.should be_kind_of(foo_class)
|
15
|
+
instance.foo.should eql(foo)
|
16
|
+
end
|
17
|
+
|
18
|
+
it "record a missing key call if invalid key used" do
|
19
|
+
instance = described_class.new({})
|
20
|
+
expect { instance.foo }.to_not raise_error
|
21
|
+
instance.__internal_state["missing_key_calls"].include?("foo").should be
|
22
|
+
end
|
23
|
+
|
24
|
+
it "returns a dummy config for a missing key" do
|
25
|
+
instance = described_class.new({})
|
26
|
+
expect { instance.foo.foo = "bar" }.to_not raise_error
|
27
|
+
end
|
28
|
+
|
29
|
+
it "can be created with initial state" do
|
30
|
+
instance = described_class.new({}, { :foo => "bar" })
|
31
|
+
instance.foo.should == "bar"
|
32
|
+
end
|
33
|
+
|
34
|
+
it "should return internal state" do
|
35
|
+
map = { "foo" => Object, "bar" => Object }
|
36
|
+
instance = described_class.new(map)
|
37
|
+
instance.__internal_state.should == {
|
38
|
+
"config_map" => map,
|
39
|
+
"keys" => {},
|
40
|
+
"missing_key_calls" => Set.new
|
41
|
+
}
|
42
|
+
end
|
43
|
+
|
44
|
+
describe "finalization" do
|
45
|
+
it "should finalize un-used keys" do
|
46
|
+
foo_class = Class.new do
|
47
|
+
attr_accessor :foo
|
48
|
+
|
49
|
+
def finalize!
|
50
|
+
@foo = "SET"
|
51
|
+
end
|
52
|
+
end
|
53
|
+
|
54
|
+
map = { :foo => foo_class }
|
55
|
+
instance = described_class.new(map)
|
56
|
+
instance.finalize!
|
57
|
+
|
58
|
+
instance.foo.foo.should == "SET"
|
59
|
+
end
|
60
|
+
end
|
61
|
+
|
62
|
+
describe "validation" do
|
63
|
+
let(:instance) do
|
64
|
+
map = { :foo => Object, :bar => Object }
|
65
|
+
described_class.new(map)
|
66
|
+
end
|
67
|
+
|
68
|
+
it "should return nil if valid" do
|
69
|
+
instance.validate({}).should == {}
|
70
|
+
end
|
71
|
+
|
72
|
+
it "should return errors if invalid" do
|
73
|
+
errors = { "foo" => ["errors!"] }
|
74
|
+
env = { "errors" => errors }
|
75
|
+
foo = instance.foo
|
76
|
+
def foo.validate(env)
|
77
|
+
env["errors"]
|
78
|
+
end
|
79
|
+
|
80
|
+
instance.validate(env).should == errors
|
81
|
+
end
|
82
|
+
|
83
|
+
it "should merge errors via array concat if matching keys" do
|
84
|
+
errors = { "foo" => ["errors!"] }
|
85
|
+
env = { "errors" => errors }
|
86
|
+
foo = instance.foo
|
87
|
+
bar = instance.bar
|
88
|
+
def foo.validate(env)
|
89
|
+
env["errors"]
|
90
|
+
end
|
91
|
+
|
92
|
+
def bar.validate(env)
|
93
|
+
env["errors"].merge({ "bar" => ["bar"] })
|
94
|
+
end
|
95
|
+
|
96
|
+
expected_errors = {
|
97
|
+
"foo" => ["errors!", "errors!"],
|
98
|
+
"bar" => ["bar"]
|
99
|
+
}
|
100
|
+
|
101
|
+
instance.validate(env).should == expected_errors
|
102
|
+
end
|
103
|
+
|
104
|
+
it "shouldn't count empty keys" do
|
105
|
+
errors = { "foo" => [] }
|
106
|
+
env = { "errors" => errors }
|
107
|
+
foo = instance.foo
|
108
|
+
def foo.validate(env)
|
109
|
+
env["errors"]
|
110
|
+
end
|
111
|
+
|
112
|
+
instance.validate(env).should == {}
|
113
|
+
end
|
114
|
+
end
|
115
|
+
end
|
@@ -0,0 +1,21 @@
|
|
1
|
+
require File.expand_path("../../../../base", __FILE__)
|
2
|
+
|
3
|
+
require "vagrant/config/v2/util"
|
4
|
+
|
5
|
+
describe Vagrant::Config::V2::Util do
|
6
|
+
describe "merging errors" do
|
7
|
+
it "should merge matching keys and leave the rest alone" do
|
8
|
+
first = { "one" => ["foo"], "two" => ["two"] }
|
9
|
+
second = { "one" => ["bar"], "three" => ["three"] }
|
10
|
+
|
11
|
+
expected = {
|
12
|
+
"one" => ["foo", "bar"],
|
13
|
+
"two" => ["two"],
|
14
|
+
"three" => ["three"]
|
15
|
+
}
|
16
|
+
|
17
|
+
result = described_class.merge_errors(first, second)
|
18
|
+
result.should == expected
|
19
|
+
end
|
20
|
+
end
|
21
|
+
end
|
@@ -0,0 +1,66 @@
|
|
1
|
+
require File.expand_path("../../base", __FILE__)
|
2
|
+
|
3
|
+
describe Vagrant::Config do
|
4
|
+
it "should not execute the proc on configuration" do
|
5
|
+
described_class.run do
|
6
|
+
raise Exception, "Failure."
|
7
|
+
end
|
8
|
+
end
|
9
|
+
|
10
|
+
it "should capture calls to `Vagrant.configure`" do
|
11
|
+
receiver = double()
|
12
|
+
|
13
|
+
procs = described_class.capture_configures do
|
14
|
+
Vagrant.configure("1") do
|
15
|
+
receiver.one
|
16
|
+
end
|
17
|
+
|
18
|
+
Vagrant.configure("2") do
|
19
|
+
receiver.two
|
20
|
+
end
|
21
|
+
end
|
22
|
+
|
23
|
+
procs.should be_kind_of(Array)
|
24
|
+
procs.length.should == 2
|
25
|
+
procs[0][0].should == "1"
|
26
|
+
procs[1][0].should == "2"
|
27
|
+
|
28
|
+
# Verify the proper procs were captured
|
29
|
+
receiver.should_receive(:one).once.ordered
|
30
|
+
receiver.should_receive(:two).once.ordered
|
31
|
+
procs[0][1].call
|
32
|
+
procs[1][1].call
|
33
|
+
end
|
34
|
+
|
35
|
+
it "should capture configuration procs" do
|
36
|
+
receiver = double()
|
37
|
+
|
38
|
+
procs = described_class.capture_configures do
|
39
|
+
described_class.run do
|
40
|
+
receiver.hello!
|
41
|
+
end
|
42
|
+
end
|
43
|
+
|
44
|
+
# Verify the structure of the result
|
45
|
+
procs.should be_kind_of(Array)
|
46
|
+
procs.length.should == 1
|
47
|
+
|
48
|
+
# Verify that the proper proc was captured
|
49
|
+
receiver.should_receive(:hello!).once
|
50
|
+
procs[0][0].should == "1"
|
51
|
+
procs[0][1].call
|
52
|
+
end
|
53
|
+
|
54
|
+
it "should capture the proper version" do
|
55
|
+
procs = described_class.capture_configures do
|
56
|
+
described_class.run("1") {}
|
57
|
+
described_class.run("2") {}
|
58
|
+
end
|
59
|
+
|
60
|
+
# Verify the structure of the result
|
61
|
+
procs.should be_kind_of(Array)
|
62
|
+
procs.length.should == 2
|
63
|
+
procs[0][0].should == "1"
|
64
|
+
procs[1][0].should == "2"
|
65
|
+
end
|
66
|
+
end
|
@@ -0,0 +1,746 @@
|
|
1
|
+
require File.expand_path("../../base", __FILE__)
|
2
|
+
require "json"
|
3
|
+
require "pathname"
|
4
|
+
require "tempfile"
|
5
|
+
require "tmpdir"
|
6
|
+
|
7
|
+
require "vagrant/util/file_mode"
|
8
|
+
|
9
|
+
describe Vagrant::Environment do
|
10
|
+
include_context "unit"
|
11
|
+
|
12
|
+
let(:env) do
|
13
|
+
isolated_environment.tap do |e|
|
14
|
+
e.box2("base", :virtualbox)
|
15
|
+
e.vagrantfile <<-VF
|
16
|
+
Vagrant.configure("2") do |config|
|
17
|
+
config.vm.box = "base"
|
18
|
+
end
|
19
|
+
VF
|
20
|
+
end
|
21
|
+
end
|
22
|
+
|
23
|
+
let(:instance) { env.create_vagrant_env }
|
24
|
+
|
25
|
+
subject { instance }
|
26
|
+
|
27
|
+
describe "active machines" do
|
28
|
+
it "should be empty if the machines folder doesn't exist" do
|
29
|
+
folder = instance.local_data_path.join("machines")
|
30
|
+
folder.should_not be_exist
|
31
|
+
|
32
|
+
instance.active_machines.should be_empty
|
33
|
+
end
|
34
|
+
|
35
|
+
it "should return the name and provider of active machines" do
|
36
|
+
machines = instance.local_data_path.join("machines")
|
37
|
+
|
38
|
+
# Valid machine, with "foo" and virtualbox
|
39
|
+
machine_foo = machines.join("foo/virtualbox")
|
40
|
+
machine_foo.mkpath
|
41
|
+
machine_foo.join("id").open("w+") { |f| f.write("") }
|
42
|
+
|
43
|
+
# Invalid machine (no ID)
|
44
|
+
machine_bar = machines.join("bar/virtualbox")
|
45
|
+
machine_bar.mkpath
|
46
|
+
|
47
|
+
instance.active_machines.should == [[:foo, :virtualbox]]
|
48
|
+
end
|
49
|
+
end
|
50
|
+
|
51
|
+
describe "batching" do
|
52
|
+
let(:batch) do
|
53
|
+
double("batch") do |b|
|
54
|
+
b.stub(:run)
|
55
|
+
end
|
56
|
+
end
|
57
|
+
|
58
|
+
context "without the disabling env var" do
|
59
|
+
it "should run without disabling parallelization" do
|
60
|
+
with_temp_env("VAGRANT_NO_PARALLEL" => nil) do
|
61
|
+
Vagrant::BatchAction.should_receive(:new).with(true).and_return(batch)
|
62
|
+
batch.should_receive(:run)
|
63
|
+
|
64
|
+
instance.batch {}
|
65
|
+
end
|
66
|
+
end
|
67
|
+
|
68
|
+
it "should run with disabling parallelization if explicit" do
|
69
|
+
with_temp_env("VAGRANT_NO_PARALLEL" => nil) do
|
70
|
+
Vagrant::BatchAction.should_receive(:new).with(false).and_return(batch)
|
71
|
+
batch.should_receive(:run)
|
72
|
+
|
73
|
+
instance.batch(false) {}
|
74
|
+
end
|
75
|
+
end
|
76
|
+
end
|
77
|
+
|
78
|
+
context "with the disabling env var" do
|
79
|
+
it "should run with disabling parallelization" do
|
80
|
+
with_temp_env("VAGRANT_NO_PARALLEL" => "yes") do
|
81
|
+
Vagrant::BatchAction.should_receive(:new).with(false).and_return(batch)
|
82
|
+
batch.should_receive(:run)
|
83
|
+
|
84
|
+
instance.batch {}
|
85
|
+
end
|
86
|
+
end
|
87
|
+
end
|
88
|
+
end
|
89
|
+
|
90
|
+
describe "current working directory" do
|
91
|
+
it "is the cwd by default" do
|
92
|
+
Dir.mktmpdir do |temp_dir|
|
93
|
+
Dir.chdir(temp_dir) do
|
94
|
+
with_temp_env("VAGRANT_CWD" => nil) do
|
95
|
+
described_class.new.cwd.should == Pathname.new(Dir.pwd)
|
96
|
+
end
|
97
|
+
end
|
98
|
+
end
|
99
|
+
end
|
100
|
+
|
101
|
+
it "is set to the cwd given" do
|
102
|
+
Dir.mktmpdir do |directory|
|
103
|
+
instance = described_class.new(:cwd => directory)
|
104
|
+
instance.cwd.should == Pathname.new(directory)
|
105
|
+
end
|
106
|
+
end
|
107
|
+
|
108
|
+
it "is set to the environmental variable VAGRANT_CWD" do
|
109
|
+
Dir.mktmpdir do |directory|
|
110
|
+
instance = with_temp_env("VAGRANT_CWD" => directory) do
|
111
|
+
described_class.new
|
112
|
+
end
|
113
|
+
|
114
|
+
instance.cwd.should == Pathname.new(directory)
|
115
|
+
end
|
116
|
+
end
|
117
|
+
|
118
|
+
it "raises an exception if the CWD doesn't exist" do
|
119
|
+
expect { described_class.new(:cwd => "doesntexist") }.
|
120
|
+
to raise_error(Vagrant::Errors::EnvironmentNonExistentCWD)
|
121
|
+
end
|
122
|
+
end
|
123
|
+
|
124
|
+
describe "default provider" do
|
125
|
+
it "is virtualbox without any environmental variable" do
|
126
|
+
with_temp_env("VAGRANT_DEFAULT_PROVIDER" => nil) do
|
127
|
+
subject.default_provider.should == :virtualbox
|
128
|
+
end
|
129
|
+
end
|
130
|
+
|
131
|
+
it "is whatever the environmental variable is if set" do
|
132
|
+
with_temp_env("VAGRANT_DEFAULT_PROVIDER" => "foo") do
|
133
|
+
subject.default_provider.should == :foo
|
134
|
+
end
|
135
|
+
end
|
136
|
+
end
|
137
|
+
|
138
|
+
describe "home path" do
|
139
|
+
it "is set to the home path given" do
|
140
|
+
Dir.mktmpdir do |dir|
|
141
|
+
instance = described_class.new(:home_path => dir)
|
142
|
+
instance.home_path.should == Pathname.new(dir)
|
143
|
+
end
|
144
|
+
end
|
145
|
+
|
146
|
+
it "is set to the environmental variable VAGRANT_HOME" do
|
147
|
+
Dir.mktmpdir do |dir|
|
148
|
+
instance = with_temp_env("VAGRANT_HOME" => dir) do
|
149
|
+
described_class.new
|
150
|
+
end
|
151
|
+
|
152
|
+
instance.home_path.should == Pathname.new(dir)
|
153
|
+
end
|
154
|
+
end
|
155
|
+
|
156
|
+
context "default home path" do
|
157
|
+
before :each do
|
158
|
+
Vagrant::Util::Platform.stub(:windows? => false)
|
159
|
+
end
|
160
|
+
|
161
|
+
it "is set to '~/.vagrant.d' by default" do
|
162
|
+
expected = Pathname.new(File.expand_path("~/.vagrant.d"))
|
163
|
+
described_class.new.home_path.should == expected
|
164
|
+
end
|
165
|
+
|
166
|
+
it "is set to '~/.vagrant.d' if on Windows but no USERPROFILE" do
|
167
|
+
Vagrant::Util::Platform.stub(:windows? => true)
|
168
|
+
|
169
|
+
expected = Pathname.new(File.expand_path("~/.vagrant.d"))
|
170
|
+
|
171
|
+
with_temp_env("USERPROFILE" => nil) do
|
172
|
+
described_class.new.home_path.should == expected
|
173
|
+
end
|
174
|
+
end
|
175
|
+
|
176
|
+
it "is set to '%USERPROFILE%/.vagrant.d' if on Windows and USERPROFILE is set" do
|
177
|
+
Vagrant::Util::Platform.stub(:windows? => true)
|
178
|
+
|
179
|
+
Dir.mktmpdir do |dir|
|
180
|
+
expected = Pathname.new(File.expand_path("#{dir}/.vagrant.d"))
|
181
|
+
|
182
|
+
with_temp_env("USERPROFILE" => dir) do
|
183
|
+
described_class.new.home_path.should == expected
|
184
|
+
end
|
185
|
+
end
|
186
|
+
end
|
187
|
+
end
|
188
|
+
|
189
|
+
it "throws an exception if inaccessible" do
|
190
|
+
expect {
|
191
|
+
described_class.new(:home_path => "/")
|
192
|
+
}.to raise_error(Vagrant::Errors::HomeDirectoryNotAccessible)
|
193
|
+
end
|
194
|
+
end
|
195
|
+
|
196
|
+
describe "local data path" do
|
197
|
+
it "is set to the proper default" do
|
198
|
+
default = instance.root_path.join(described_class::DEFAULT_LOCAL_DATA)
|
199
|
+
instance.local_data_path.should == default
|
200
|
+
end
|
201
|
+
|
202
|
+
it "is expanded relative to the cwd" do
|
203
|
+
instance = described_class.new(:local_data_path => "foo")
|
204
|
+
instance.local_data_path.should == instance.cwd.join("foo")
|
205
|
+
end
|
206
|
+
|
207
|
+
it "is set to the given value" do
|
208
|
+
Dir.mktmpdir do |dir|
|
209
|
+
instance = described_class.new(:local_data_path => dir)
|
210
|
+
instance.local_data_path.to_s.should == dir
|
211
|
+
end
|
212
|
+
end
|
213
|
+
|
214
|
+
describe "upgrading V1 dotfiles" do
|
215
|
+
let(:v1_dotfile_tempfile) { Tempfile.new("vagrant") }
|
216
|
+
let(:v1_dotfile) { Pathname.new(v1_dotfile_tempfile.path) }
|
217
|
+
let(:local_data_path) { v1_dotfile_tempfile.path }
|
218
|
+
let(:instance) { described_class.new(:local_data_path => local_data_path) }
|
219
|
+
|
220
|
+
it "should be fine if dotfile is empty" do
|
221
|
+
v1_dotfile.open("w+") do |f|
|
222
|
+
f.write("")
|
223
|
+
end
|
224
|
+
|
225
|
+
expect { instance }.to_not raise_error
|
226
|
+
Pathname.new(local_data_path).should be_directory
|
227
|
+
end
|
228
|
+
|
229
|
+
it "should upgrade all active VMs" do
|
230
|
+
active_vms = {
|
231
|
+
"foo" => "foo_id",
|
232
|
+
"bar" => "bar_id"
|
233
|
+
}
|
234
|
+
|
235
|
+
v1_dotfile.open("w+") do |f|
|
236
|
+
f.write(JSON.dump({
|
237
|
+
"active" => active_vms
|
238
|
+
}))
|
239
|
+
end
|
240
|
+
|
241
|
+
expect { instance }.to_not raise_error
|
242
|
+
|
243
|
+
local_data_pathname = Pathname.new(local_data_path)
|
244
|
+
foo_id_file = local_data_pathname.join("machines/foo/virtualbox/id")
|
245
|
+
foo_id_file.should be_file
|
246
|
+
foo_id_file.read.should == "foo_id"
|
247
|
+
|
248
|
+
bar_id_file = local_data_pathname.join("machines/bar/virtualbox/id")
|
249
|
+
bar_id_file.should be_file
|
250
|
+
bar_id_file.read.should == "bar_id"
|
251
|
+
end
|
252
|
+
|
253
|
+
it "should raise an error if invalid JSON" do
|
254
|
+
v1_dotfile.open("w+") do |f|
|
255
|
+
f.write("bad")
|
256
|
+
end
|
257
|
+
|
258
|
+
expect { instance }.
|
259
|
+
to raise_error(Vagrant::Errors::DotfileUpgradeJSONError)
|
260
|
+
end
|
261
|
+
end
|
262
|
+
end
|
263
|
+
|
264
|
+
describe "copying the private SSH key" do
|
265
|
+
it "copies the SSH key into the home directory" do
|
266
|
+
env = isolated_environment
|
267
|
+
instance = described_class.new(:home_path => env.homedir)
|
268
|
+
|
269
|
+
pk = env.homedir.join("insecure_private_key")
|
270
|
+
pk.should be_exist
|
271
|
+
Vagrant::Util::FileMode.from_octal(pk.stat.mode).should == "600"
|
272
|
+
end
|
273
|
+
end
|
274
|
+
|
275
|
+
it "has a box collection pointed to the proper directory" do
|
276
|
+
collection = instance.boxes
|
277
|
+
collection.should be_kind_of(Vagrant::BoxCollection)
|
278
|
+
collection.directory.should == instance.boxes_path
|
279
|
+
end
|
280
|
+
|
281
|
+
describe "action runner" do
|
282
|
+
it "has an action runner" do
|
283
|
+
instance.action_runner.should be_kind_of(Vagrant::Action::Runner)
|
284
|
+
end
|
285
|
+
|
286
|
+
it "has a `ui` in the globals" do
|
287
|
+
result = nil
|
288
|
+
callable = lambda { |env| result = env[:ui] }
|
289
|
+
|
290
|
+
instance.action_runner.run(callable)
|
291
|
+
result.should eql(instance.ui)
|
292
|
+
end
|
293
|
+
end
|
294
|
+
|
295
|
+
describe "#hook" do
|
296
|
+
it "should call the action runner with the proper hook" do
|
297
|
+
hook_name = :foo
|
298
|
+
|
299
|
+
instance.action_runner.should_receive(:run).with do |callable, env|
|
300
|
+
env[:action_name].should == hook_name
|
301
|
+
end
|
302
|
+
|
303
|
+
instance.hook(hook_name)
|
304
|
+
end
|
305
|
+
|
306
|
+
it "should return the result of the action runner run" do
|
307
|
+
instance.action_runner.should_receive(:run).and_return(:foo)
|
308
|
+
|
309
|
+
instance.hook(:bar).should == :foo
|
310
|
+
end
|
311
|
+
end
|
312
|
+
|
313
|
+
describe "primary machine name" do
|
314
|
+
it "should be the only machine if not a multi-machine environment" do
|
315
|
+
instance.primary_machine_name.should == instance.machine_names.first
|
316
|
+
end
|
317
|
+
|
318
|
+
it "should be the machine marked as the primary" do
|
319
|
+
environment = isolated_environment do |env|
|
320
|
+
env.vagrantfile(<<-VF)
|
321
|
+
Vagrant.configure("2") do |config|
|
322
|
+
config.vm.box = "base"
|
323
|
+
config.vm.define :foo
|
324
|
+
config.vm.define :bar, :primary => true
|
325
|
+
end
|
326
|
+
VF
|
327
|
+
|
328
|
+
env.box2("base", :virtualbox)
|
329
|
+
end
|
330
|
+
|
331
|
+
env = environment.create_vagrant_env
|
332
|
+
env.primary_machine_name.should == :bar
|
333
|
+
end
|
334
|
+
|
335
|
+
it "should be nil if no primary is specified in a multi-machine environment" do
|
336
|
+
environment = isolated_environment do |env|
|
337
|
+
env.vagrantfile(<<-VF)
|
338
|
+
Vagrant.configure("2") do |config|
|
339
|
+
config.vm.box = "base"
|
340
|
+
config.vm.define :foo
|
341
|
+
config.vm.define :bar
|
342
|
+
end
|
343
|
+
VF
|
344
|
+
|
345
|
+
env.box2("base", :virtualbox)
|
346
|
+
end
|
347
|
+
|
348
|
+
env = environment.create_vagrant_env
|
349
|
+
env.primary_machine_name.should be_nil
|
350
|
+
end
|
351
|
+
end
|
352
|
+
|
353
|
+
describe "loading configuration" do
|
354
|
+
it "should load global configuration" do
|
355
|
+
environment = isolated_environment do |env|
|
356
|
+
env.vagrantfile(<<-VF)
|
357
|
+
Vagrant.configure("2") do |config|
|
358
|
+
config.ssh.port = 200
|
359
|
+
end
|
360
|
+
VF
|
361
|
+
end
|
362
|
+
|
363
|
+
env = environment.create_vagrant_env
|
364
|
+
env.config_global.ssh.port.should == 200
|
365
|
+
end
|
366
|
+
|
367
|
+
it "should load from a custom Vagrantfile" do
|
368
|
+
environment = isolated_environment do |env|
|
369
|
+
env.file("non_standard_name", <<-VF)
|
370
|
+
Vagrant.configure("2") do |config|
|
371
|
+
config.ssh.port = 200
|
372
|
+
end
|
373
|
+
VF
|
374
|
+
end
|
375
|
+
|
376
|
+
env = environment.create_vagrant_env(:vagrantfile_name => "non_standard_name")
|
377
|
+
env.config_global.ssh.port.should == 200
|
378
|
+
end
|
379
|
+
|
380
|
+
it "should load from a custom Vagrantfile specified by env var" do
|
381
|
+
environment = isolated_environment do |env|
|
382
|
+
env.file("some_other_name", <<-VF)
|
383
|
+
Vagrant.configure("2") do |config|
|
384
|
+
config.ssh.port = 400
|
385
|
+
end
|
386
|
+
VF
|
387
|
+
end
|
388
|
+
|
389
|
+
env = with_temp_env("VAGRANT_VAGRANTFILE" => "some_other_name") do
|
390
|
+
environment.create_vagrant_env
|
391
|
+
end
|
392
|
+
|
393
|
+
env.config_global.ssh.port.should == 400
|
394
|
+
end
|
395
|
+
end
|
396
|
+
|
397
|
+
describe "ui" do
|
398
|
+
it "should be a silent UI by default" do
|
399
|
+
described_class.new.ui.should be_kind_of(Vagrant::UI::Silent)
|
400
|
+
end
|
401
|
+
|
402
|
+
it "should be a UI given in the constructor" do
|
403
|
+
# Create a custom UI for our test
|
404
|
+
class CustomUI < Vagrant::UI::Interface; end
|
405
|
+
|
406
|
+
instance = described_class.new(:ui_class => CustomUI)
|
407
|
+
instance.ui.should be_kind_of(CustomUI)
|
408
|
+
end
|
409
|
+
end
|
410
|
+
|
411
|
+
describe "#unload" do
|
412
|
+
it "should run the unload hook" do
|
413
|
+
instance.should_receive(:hook).with(:environment_unload).once
|
414
|
+
instance.unload
|
415
|
+
end
|
416
|
+
end
|
417
|
+
|
418
|
+
describe "getting a machine" do
|
419
|
+
# A helper to register a provider for use in tests.
|
420
|
+
def register_provider(name, config_class=nil, options=nil)
|
421
|
+
provider_cls = Class.new(Vagrant.plugin("2", :provider))
|
422
|
+
|
423
|
+
register_plugin("2") do |p|
|
424
|
+
p.provider(name, options) { provider_cls }
|
425
|
+
|
426
|
+
if config_class
|
427
|
+
p.config(name, :provider) { config_class }
|
428
|
+
end
|
429
|
+
end
|
430
|
+
|
431
|
+
provider_cls
|
432
|
+
end
|
433
|
+
|
434
|
+
it "should return a machine object with the correct provider" do
|
435
|
+
# Create a provider
|
436
|
+
foo_provider = register_provider("foo")
|
437
|
+
|
438
|
+
# Create the configuration
|
439
|
+
isolated_env = isolated_environment do |e|
|
440
|
+
e.vagrantfile(<<-VF)
|
441
|
+
Vagrant.configure("2") do |config|
|
442
|
+
config.vm.box = "base"
|
443
|
+
config.vm.define "foo"
|
444
|
+
end
|
445
|
+
VF
|
446
|
+
|
447
|
+
e.box2("base", :foo)
|
448
|
+
end
|
449
|
+
|
450
|
+
# Verify that we can get the machine
|
451
|
+
env = isolated_env.create_vagrant_env
|
452
|
+
machine = env.machine(:foo, :foo)
|
453
|
+
machine.should be_kind_of(Vagrant::Machine)
|
454
|
+
machine.name.should == :foo
|
455
|
+
machine.provider.should be_kind_of(foo_provider)
|
456
|
+
machine.provider_config.should be_nil
|
457
|
+
end
|
458
|
+
|
459
|
+
it "should return a machine object with the machine configuration" do
|
460
|
+
# Create a provider
|
461
|
+
foo_config = Class.new(Vagrant.plugin("2", :config)) do
|
462
|
+
attr_accessor :value
|
463
|
+
end
|
464
|
+
|
465
|
+
foo_provider = register_provider("foo", foo_config)
|
466
|
+
|
467
|
+
# Create the configuration
|
468
|
+
isolated_env = isolated_environment do |e|
|
469
|
+
e.vagrantfile(<<-VF)
|
470
|
+
Vagrant.configure("2") do |config|
|
471
|
+
config.vm.box = "base"
|
472
|
+
config.vm.define "foo"
|
473
|
+
|
474
|
+
config.vm.provider :foo do |fooconfig|
|
475
|
+
fooconfig.value = 100
|
476
|
+
end
|
477
|
+
end
|
478
|
+
VF
|
479
|
+
|
480
|
+
e.box2("base", :foo)
|
481
|
+
end
|
482
|
+
|
483
|
+
# Verify that we can get the machine
|
484
|
+
env = isolated_env.create_vagrant_env
|
485
|
+
machine = env.machine(:foo, :foo)
|
486
|
+
machine.should be_kind_of(Vagrant::Machine)
|
487
|
+
machine.name.should == :foo
|
488
|
+
machine.provider.should be_kind_of(foo_provider)
|
489
|
+
machine.provider_config.value.should == 100
|
490
|
+
end
|
491
|
+
|
492
|
+
it "should cache the machine objects by name and provider" do
|
493
|
+
# Create a provider
|
494
|
+
foo_provider = register_provider("foo")
|
495
|
+
bar_provider = register_provider("bar")
|
496
|
+
|
497
|
+
# Create the configuration
|
498
|
+
isolated_env = isolated_environment do |e|
|
499
|
+
e.vagrantfile(<<-VF)
|
500
|
+
Vagrant.configure("2") do |config|
|
501
|
+
config.vm.box = "base"
|
502
|
+
config.vm.define "vm1"
|
503
|
+
config.vm.define "vm2"
|
504
|
+
end
|
505
|
+
VF
|
506
|
+
|
507
|
+
e.box2("base", :foo)
|
508
|
+
e.box2("base", :bar)
|
509
|
+
end
|
510
|
+
|
511
|
+
env = isolated_env.create_vagrant_env
|
512
|
+
vm1_foo = env.machine(:vm1, :foo)
|
513
|
+
vm1_bar = env.machine(:vm1, :bar)
|
514
|
+
vm2_foo = env.machine(:vm2, :foo)
|
515
|
+
|
516
|
+
vm1_foo.should eql(env.machine(:vm1, :foo))
|
517
|
+
vm1_bar.should eql(env.machine(:vm1, :bar))
|
518
|
+
vm1_foo.should_not eql(vm1_bar)
|
519
|
+
vm2_foo.should eql(env.machine(:vm2, :foo))
|
520
|
+
end
|
521
|
+
|
522
|
+
it "should load a machine without a box" do
|
523
|
+
register_provider("foo")
|
524
|
+
|
525
|
+
environment = isolated_environment do |env|
|
526
|
+
env.vagrantfile(<<-VF)
|
527
|
+
Vagrant.configure("2") do |config|
|
528
|
+
config.vm.box = "i-dont-exist"
|
529
|
+
end
|
530
|
+
VF
|
531
|
+
end
|
532
|
+
|
533
|
+
env = environment.create_vagrant_env
|
534
|
+
machine = env.machine(:default, :foo)
|
535
|
+
machine.box.should be_nil
|
536
|
+
end
|
537
|
+
|
538
|
+
it "should load the machine configuration" do
|
539
|
+
register_provider("foo")
|
540
|
+
|
541
|
+
environment = isolated_environment do |env|
|
542
|
+
env.vagrantfile(<<-VF)
|
543
|
+
Vagrant.configure("2") do |config|
|
544
|
+
config.ssh.port = 1
|
545
|
+
config.vm.box = "base"
|
546
|
+
|
547
|
+
config.vm.define "vm1" do |inner|
|
548
|
+
inner.ssh.port = 100
|
549
|
+
end
|
550
|
+
end
|
551
|
+
VF
|
552
|
+
|
553
|
+
env.box2("base", :foo)
|
554
|
+
end
|
555
|
+
|
556
|
+
env = environment.create_vagrant_env
|
557
|
+
machine = env.machine(:vm1, :foo)
|
558
|
+
machine.config.ssh.port.should == 100
|
559
|
+
machine.config.vm.box.should == "base"
|
560
|
+
end
|
561
|
+
|
562
|
+
it "should load the box configuration for a V2 box" do
|
563
|
+
register_provider("foo")
|
564
|
+
|
565
|
+
environment = isolated_environment do |env|
|
566
|
+
env.vagrantfile(<<-VF)
|
567
|
+
Vagrant.configure("2") do |config|
|
568
|
+
config.vm.box = "base"
|
569
|
+
end
|
570
|
+
VF
|
571
|
+
|
572
|
+
env.box2("base", :foo, :vagrantfile => <<-VF)
|
573
|
+
Vagrant.configure("2") do |config|
|
574
|
+
config.ssh.port = 100
|
575
|
+
end
|
576
|
+
VF
|
577
|
+
end
|
578
|
+
|
579
|
+
env = environment.create_vagrant_env
|
580
|
+
machine = env.machine(:default, :foo)
|
581
|
+
machine.config.ssh.port.should == 100
|
582
|
+
end
|
583
|
+
|
584
|
+
it "should load the box configuration for a V2 box and custom Vagrantfile name" do
|
585
|
+
register_provider("foo")
|
586
|
+
|
587
|
+
environment = isolated_environment do |env|
|
588
|
+
env.file("some_other_name", <<-VF)
|
589
|
+
Vagrant.configure("2") do |config|
|
590
|
+
config.vm.box = "base"
|
591
|
+
end
|
592
|
+
VF
|
593
|
+
|
594
|
+
env.box2("base", :foo, :vagrantfile => <<-VF)
|
595
|
+
Vagrant.configure("2") do |config|
|
596
|
+
config.ssh.port = 100
|
597
|
+
end
|
598
|
+
VF
|
599
|
+
end
|
600
|
+
|
601
|
+
env = with_temp_env("VAGRANT_VAGRANTFILE" => "some_other_name") do
|
602
|
+
environment.create_vagrant_env
|
603
|
+
end
|
604
|
+
|
605
|
+
machine = env.machine(:default, :foo)
|
606
|
+
machine.config.ssh.port.should == 100
|
607
|
+
end
|
608
|
+
|
609
|
+
it "should load the box configuration for other formats for a V2 box" do
|
610
|
+
register_provider("foo", nil, box_format: "bar")
|
611
|
+
|
612
|
+
environment = isolated_environment do |env|
|
613
|
+
env.vagrantfile(<<-VF)
|
614
|
+
Vagrant.configure("2") do |config|
|
615
|
+
config.vm.box = "base"
|
616
|
+
end
|
617
|
+
VF
|
618
|
+
|
619
|
+
env.box2("base", :bar, :vagrantfile => <<-VF)
|
620
|
+
Vagrant.configure("2") do |config|
|
621
|
+
config.ssh.port = 100
|
622
|
+
end
|
623
|
+
VF
|
624
|
+
end
|
625
|
+
|
626
|
+
env = environment.create_vagrant_env
|
627
|
+
machine = env.machine(:default, :foo)
|
628
|
+
machine.config.ssh.port.should == 100
|
629
|
+
end
|
630
|
+
|
631
|
+
it "prefer sooner formats when multiple box formats are available" do
|
632
|
+
register_provider("foo", nil, box_format: ["fA", "fB"])
|
633
|
+
|
634
|
+
environment = isolated_environment do |env|
|
635
|
+
env.vagrantfile(<<-VF)
|
636
|
+
Vagrant.configure("2") do |config|
|
637
|
+
config.vm.box = "base"
|
638
|
+
end
|
639
|
+
VF
|
640
|
+
|
641
|
+
env.box2("base", :fA, :vagrantfile => <<-VF)
|
642
|
+
Vagrant.configure("2") do |config|
|
643
|
+
config.ssh.port = 100
|
644
|
+
end
|
645
|
+
VF
|
646
|
+
|
647
|
+
env.box2("base", :fB, :vagrantfile => <<-VF)
|
648
|
+
Vagrant.configure("2") do |config|
|
649
|
+
config.ssh.port = 200
|
650
|
+
end
|
651
|
+
VF
|
652
|
+
end
|
653
|
+
|
654
|
+
env = environment.create_vagrant_env
|
655
|
+
machine = env.machine(:default, :foo)
|
656
|
+
machine.config.ssh.port.should == 100
|
657
|
+
end
|
658
|
+
|
659
|
+
it "should load the provider override if set" do
|
660
|
+
register_provider("bar")
|
661
|
+
register_provider("foo")
|
662
|
+
|
663
|
+
isolated_env = isolated_environment do |e|
|
664
|
+
e.vagrantfile(<<-VF)
|
665
|
+
Vagrant.configure("2") do |config|
|
666
|
+
config.vm.box = "foo"
|
667
|
+
|
668
|
+
config.vm.provider :foo do |_, c|
|
669
|
+
c.vm.box = "bar"
|
670
|
+
end
|
671
|
+
end
|
672
|
+
VF
|
673
|
+
end
|
674
|
+
|
675
|
+
env = isolated_env.create_vagrant_env
|
676
|
+
foo_vm = env.machine(:default, :foo)
|
677
|
+
bar_vm = env.machine(:default, :bar)
|
678
|
+
foo_vm.config.vm.box.should == "bar"
|
679
|
+
bar_vm.config.vm.box.should == "foo"
|
680
|
+
end
|
681
|
+
|
682
|
+
it "should reload the cache if refresh is set" do
|
683
|
+
# Create a provider
|
684
|
+
foo_provider = register_provider("foo")
|
685
|
+
|
686
|
+
# Create the configuration
|
687
|
+
isolated_env = isolated_environment do |e|
|
688
|
+
e.vagrantfile(<<-VF)
|
689
|
+
Vagrant.configure("2") do |config|
|
690
|
+
config.vm.box = "base"
|
691
|
+
end
|
692
|
+
VF
|
693
|
+
|
694
|
+
e.box2("base", :foo)
|
695
|
+
end
|
696
|
+
|
697
|
+
env = isolated_env.create_vagrant_env
|
698
|
+
vm1 = env.machine(:default, :foo)
|
699
|
+
vm2 = env.machine(:default, :foo, true)
|
700
|
+
vm3 = env.machine(:default, :foo)
|
701
|
+
|
702
|
+
vm1.should_not eql(vm2)
|
703
|
+
vm2.should eql(vm3)
|
704
|
+
end
|
705
|
+
|
706
|
+
it "should raise an error if the VM is not found" do
|
707
|
+
expect { instance.machine("i-definitely-dont-exist", :virtualbox) }.
|
708
|
+
to raise_error(Vagrant::Errors::MachineNotFound)
|
709
|
+
end
|
710
|
+
|
711
|
+
it "should raise an error if the provider is not found" do
|
712
|
+
expect { instance.machine(:default, :lol_no) }.
|
713
|
+
to raise_error(Vagrant::Errors::ProviderNotFound)
|
714
|
+
end
|
715
|
+
end
|
716
|
+
|
717
|
+
describe "getting machine names" do
|
718
|
+
it "should return the default machine if no multi-VM is used" do
|
719
|
+
# Create the config
|
720
|
+
isolated_env = isolated_environment do |e|
|
721
|
+
e.vagrantfile(<<-VF)
|
722
|
+
Vagrant.configure("2") do |config|
|
723
|
+
end
|
724
|
+
VF
|
725
|
+
end
|
726
|
+
|
727
|
+
env = isolated_env.create_vagrant_env
|
728
|
+
env.machine_names.should == [:default]
|
729
|
+
end
|
730
|
+
|
731
|
+
it "should return the machine names in order" do
|
732
|
+
# Create the config
|
733
|
+
isolated_env = isolated_environment do |e|
|
734
|
+
e.vagrantfile(<<-VF)
|
735
|
+
Vagrant.configure("2") do |config|
|
736
|
+
config.vm.define "foo"
|
737
|
+
config.vm.define "bar"
|
738
|
+
end
|
739
|
+
VF
|
740
|
+
end
|
741
|
+
|
742
|
+
env = isolated_env.create_vagrant_env
|
743
|
+
env.machine_names.should == [:foo, :bar]
|
744
|
+
end
|
745
|
+
end
|
746
|
+
end
|