tnargav 1.3.5 → 1.3.6

Sign up to get free protection for your applications and to get access to all the features.
Files changed (478) hide show
  1. data/lib/vagrant/action.rb +45 -0
  2. data/lib/vagrant/action/builder.rb +174 -0
  3. data/lib/vagrant/action/builtin/box_add.rb +92 -0
  4. data/lib/vagrant/action/builtin/call.rb +67 -0
  5. data/lib/vagrant/action/builtin/config_validate.rb +30 -0
  6. data/lib/vagrant/action/builtin/confirm.rb +39 -0
  7. data/lib/vagrant/action/builtin/destroy_confirm.rb +21 -0
  8. data/lib/vagrant/action/builtin/env_set.rb +24 -0
  9. data/lib/vagrant/action/builtin/graceful_halt.rb +82 -0
  10. data/lib/vagrant/action/builtin/handle_box_url.rb +86 -0
  11. data/lib/vagrant/action/builtin/handle_forwarded_port_collisions.rb +134 -0
  12. data/lib/vagrant/action/builtin/lock.rb +57 -0
  13. data/lib/vagrant/action/builtin/mixin_provisioners.rb +43 -0
  14. data/lib/vagrant/action/builtin/nfs.rb +128 -0
  15. data/lib/vagrant/action/builtin/provision.rb +79 -0
  16. data/lib/vagrant/action/builtin/provisioner_cleanup.rb +35 -0
  17. data/lib/vagrant/action/builtin/set_hostname.rb +27 -0
  18. data/lib/vagrant/action/builtin/ssh_exec.rb +42 -0
  19. data/lib/vagrant/action/builtin/ssh_run.rb +43 -0
  20. data/lib/vagrant/action/builtin/wait_for_communicator.rb +84 -0
  21. data/lib/vagrant/action/general/package.rb +103 -0
  22. data/lib/vagrant/action/hook.rb +107 -0
  23. data/lib/vagrant/action/runner.rb +69 -0
  24. data/lib/vagrant/action/warden.rb +104 -0
  25. data/lib/vagrant/batch_action.rb +113 -0
  26. data/lib/vagrant/box.rb +97 -0
  27. data/lib/vagrant/box_collection.rb +393 -0
  28. data/lib/vagrant/cli.rb +74 -0
  29. data/lib/vagrant/config.rb +61 -0
  30. data/lib/vagrant/config/loader.rb +222 -0
  31. data/lib/vagrant/config/v1.rb +9 -0
  32. data/lib/vagrant/config/v1/dummy_config.rb +13 -0
  33. data/lib/vagrant/config/v1/loader.rb +105 -0
  34. data/lib/vagrant/config/v1/root.rb +60 -0
  35. data/lib/vagrant/config/v2.rb +9 -0
  36. data/lib/vagrant/config/v2/dummy_config.rb +13 -0
  37. data/lib/vagrant/config/v2/loader.rb +141 -0
  38. data/lib/vagrant/config/v2/root.rb +111 -0
  39. data/lib/vagrant/config/v2/util.rb +21 -0
  40. data/lib/vagrant/config/version_base.rb +80 -0
  41. data/lib/vagrant/environment.rb +819 -0
  42. data/lib/vagrant/errors.rb +614 -0
  43. data/lib/vagrant/guest.rb +172 -0
  44. data/lib/vagrant/hosts.rb +28 -0
  45. data/lib/vagrant/machine.rb +319 -0
  46. data/lib/vagrant/machine_state.rb +45 -0
  47. data/lib/vagrant/plugin.rb +6 -0
  48. data/lib/vagrant/plugin/v1.rb +19 -0
  49. data/lib/vagrant/plugin/v1/command.rb +169 -0
  50. data/lib/vagrant/plugin/v1/communicator.rb +98 -0
  51. data/lib/vagrant/plugin/v1/config.rb +112 -0
  52. data/lib/vagrant/plugin/v1/errors.rb +15 -0
  53. data/lib/vagrant/plugin/v1/guest.rb +92 -0
  54. data/lib/vagrant/plugin/v1/host.rb +66 -0
  55. data/lib/vagrant/plugin/v1/manager.rb +131 -0
  56. data/lib/vagrant/plugin/v1/plugin.rb +229 -0
  57. data/lib/vagrant/plugin/v1/provider.rb +68 -0
  58. data/lib/vagrant/plugin/v1/provisioner.rb +50 -0
  59. data/lib/vagrant/plugin/v2.rb +22 -0
  60. data/lib/vagrant/plugin/v2/command.rb +237 -0
  61. data/lib/vagrant/plugin/v2/communicator.rb +119 -0
  62. data/lib/vagrant/plugin/v2/components.rb +47 -0
  63. data/lib/vagrant/plugin/v2/config.rb +136 -0
  64. data/lib/vagrant/plugin/v2/errors.rb +15 -0
  65. data/lib/vagrant/plugin/v2/guest.rb +23 -0
  66. data/lib/vagrant/plugin/v2/host.rb +66 -0
  67. data/lib/vagrant/plugin/v2/manager.rb +173 -0
  68. data/lib/vagrant/plugin/v2/plugin.rb +226 -0
  69. data/lib/vagrant/plugin/v2/provider.rb +69 -0
  70. data/lib/vagrant/plugin/v2/provisioner.rb +53 -0
  71. data/lib/vagrant/registry.rb +78 -0
  72. data/lib/vagrant/ui.rb +215 -0
  73. data/lib/vagrant/util.rb +12 -0
  74. data/lib/vagrant/util/ansi_escape_code_remover.rb +34 -0
  75. data/lib/vagrant/util/busy.rb +59 -0
  76. data/lib/vagrant/util/counter.rb +24 -0
  77. data/lib/vagrant/util/downloader.rb +151 -0
  78. data/lib/vagrant/util/file_checksum.rb +38 -0
  79. data/lib/vagrant/util/file_mode.rb +12 -0
  80. data/lib/vagrant/util/hash_with_indifferent_access.rb +63 -0
  81. data/lib/vagrant/util/is_port_open.rb +38 -0
  82. data/lib/vagrant/util/line_ending_helpers.rb +14 -0
  83. data/lib/vagrant/util/network_ip.rb +28 -0
  84. data/lib/vagrant/util/platform.rb +101 -0
  85. data/lib/vagrant/util/retryable.rb +31 -0
  86. data/lib/vagrant/util/safe_chdir.rb +33 -0
  87. data/lib/vagrant/util/safe_exec.rb +36 -0
  88. data/lib/vagrant/util/safe_puts.rb +31 -0
  89. data/lib/vagrant/util/scoped_hash_override.rb +45 -0
  90. data/lib/vagrant/util/ssh.rb +155 -0
  91. data/lib/vagrant/util/stacked_proc_runner.rb +35 -0
  92. data/lib/vagrant/util/string_block_editor.rb +77 -0
  93. data/lib/vagrant/util/subprocess.rb +294 -0
  94. data/lib/vagrant/util/template_renderer.rb +83 -0
  95. data/lib/vagrant/util/which.rb +43 -0
  96. data/lib/vagrant/version.rb +6 -0
  97. data/plugins/commands/box/command/add.rb +51 -0
  98. data/plugins/commands/box/command/list.rb +41 -0
  99. data/plugins/commands/box/command/remove.rb +57 -0
  100. data/plugins/commands/box/command/repackage.rb +43 -0
  101. data/plugins/commands/box/command/root.rb +75 -0
  102. data/plugins/commands/box/plugin.rb +15 -0
  103. data/plugins/commands/destroy/command.rb +36 -0
  104. data/plugins/commands/destroy/plugin.rb +18 -0
  105. data/plugins/commands/halt/command.rb +33 -0
  106. data/plugins/commands/halt/plugin.rb +18 -0
  107. data/plugins/commands/help/command.rb +12 -0
  108. data/plugins/commands/help/plugin.rb +17 -0
  109. data/plugins/commands/init/command.rb +40 -0
  110. data/plugins/commands/init/plugin.rb +18 -0
  111. data/plugins/commands/package/command.rb +83 -0
  112. data/plugins/commands/package/plugin.rb +18 -0
  113. data/plugins/commands/plugin/action.rb +63 -0
  114. data/plugins/commands/plugin/action/bundler_check.rb +25 -0
  115. data/plugins/commands/plugin/action/install_gem.rb +106 -0
  116. data/plugins/commands/plugin/action/license_plugin.rb +54 -0
  117. data/plugins/commands/plugin/action/list_plugins.rb +54 -0
  118. data/plugins/commands/plugin/action/plugin_exists_check.rb +26 -0
  119. data/plugins/commands/plugin/action/prune_gems.rb +149 -0
  120. data/plugins/commands/plugin/action/uninstall_plugin.rb +23 -0
  121. data/plugins/commands/plugin/command/base.rb +22 -0
  122. data/plugins/commands/plugin/command/install.rb +41 -0
  123. data/plugins/commands/plugin/command/license.rb +31 -0
  124. data/plugins/commands/plugin/command/list.rb +28 -0
  125. data/plugins/commands/plugin/command/mixin_install_opts.rb +30 -0
  126. data/plugins/commands/plugin/command/root.rb +80 -0
  127. data/plugins/commands/plugin/command/uninstall.rb +28 -0
  128. data/plugins/commands/plugin/command/update.rb +41 -0
  129. data/plugins/commands/plugin/gem_helper.rb +74 -0
  130. data/plugins/commands/plugin/plugin.rb +22 -0
  131. data/plugins/commands/plugin/state_file.rb +57 -0
  132. data/plugins/commands/provision/command.rb +34 -0
  133. data/plugins/commands/provision/plugin.rb +18 -0
  134. data/plugins/commands/reload/command.rb +41 -0
  135. data/plugins/commands/reload/plugin.rb +18 -0
  136. data/plugins/commands/resume/command.rb +25 -0
  137. data/plugins/commands/resume/plugin.rb +17 -0
  138. data/plugins/commands/ssh/command.rb +63 -0
  139. data/plugins/commands/ssh/plugin.rb +17 -0
  140. data/plugins/commands/ssh_config/command.rb +49 -0
  141. data/plugins/commands/ssh_config/plugin.rb +18 -0
  142. data/plugins/commands/status/command.rb +44 -0
  143. data/plugins/commands/status/plugin.rb +18 -0
  144. data/plugins/commands/suspend/command.rb +25 -0
  145. data/plugins/commands/suspend/plugin.rb +18 -0
  146. data/plugins/commands/up/command.rb +67 -0
  147. data/plugins/commands/up/plugin.rb +17 -0
  148. data/plugins/commands/up/start_mixins.rb +37 -0
  149. data/plugins/communicators/ssh/communicator.rb +400 -0
  150. data/plugins/communicators/ssh/plugin.rb +19 -0
  151. data/plugins/guests/arch/cap/change_host_name.rb +17 -0
  152. data/plugins/guests/arch/cap/configure_networks.rb +30 -0
  153. data/plugins/guests/arch/guest.rb +11 -0
  154. data/plugins/guests/arch/plugin.rb +25 -0
  155. data/plugins/guests/coreos/cap/change_host_name.rb +15 -0
  156. data/plugins/guests/coreos/cap/configure_networks.rb +72 -0
  157. data/plugins/guests/coreos/guest.rb +9 -0
  158. data/plugins/guests/coreos/plugin.rb +25 -0
  159. data/plugins/guests/darwin/cap/change_host_name.rb +14 -0
  160. data/plugins/guests/darwin/cap/configure_networks.rb +52 -0
  161. data/plugins/guests/darwin/cap/halt.rb +16 -0
  162. data/plugins/guests/darwin/cap/mount_nfs_folder.rb +25 -0
  163. data/plugins/guests/darwin/cap/mount_vmware_shared_folder.rb +36 -0
  164. data/plugins/guests/darwin/cap/shell_expand_guest_path.rb +26 -0
  165. data/plugins/guests/darwin/cap/verify_vmware_hgfs.rb +12 -0
  166. data/plugins/guests/darwin/guest.rb +15 -0
  167. data/plugins/guests/darwin/plugin.rb +50 -0
  168. data/plugins/guests/debian/cap/change_host_name.rb +19 -0
  169. data/plugins/guests/debian/cap/configure_networks.rb +61 -0
  170. data/plugins/guests/debian/guest.rb +9 -0
  171. data/plugins/guests/debian/plugin.rb +25 -0
  172. data/plugins/guests/fedora/cap/configure_networks.rb +59 -0
  173. data/plugins/guests/fedora/cap/network_scripts_dir.rb +15 -0
  174. data/plugins/guests/fedora/guest.rb +11 -0
  175. data/plugins/guests/fedora/plugin.rb +25 -0
  176. data/plugins/guests/freebsd/cap/change_host_name.rb +14 -0
  177. data/plugins/guests/freebsd/cap/configure_networks.rb +39 -0
  178. data/plugins/guests/freebsd/cap/halt.rb +16 -0
  179. data/plugins/guests/freebsd/cap/mount_nfs_folder.rb +14 -0
  180. data/plugins/guests/freebsd/guest.rb +14 -0
  181. data/plugins/guests/freebsd/plugin.rb +35 -0
  182. data/plugins/guests/gentoo/cap/change_host_name.rb +17 -0
  183. data/plugins/guests/gentoo/cap/configure_networks.rb +43 -0
  184. data/plugins/guests/gentoo/guest.rb +9 -0
  185. data/plugins/guests/gentoo/plugin.rb +25 -0
  186. data/plugins/guests/linux/cap/halt.rb +16 -0
  187. data/plugins/guests/linux/cap/mount_nfs.rb +38 -0
  188. data/plugins/guests/linux/cap/mount_virtualbox_shared_folder.rb +59 -0
  189. data/plugins/guests/linux/cap/read_ip_address.rb +17 -0
  190. data/plugins/guests/linux/cap/shell_expand_guest_path.rb +29 -0
  191. data/plugins/guests/linux/guest.rb +11 -0
  192. data/plugins/guests/linux/plugin.rb +40 -0
  193. data/plugins/guests/omnios/cap/change_host_name.rb +17 -0
  194. data/plugins/guests/omnios/guest.rb +11 -0
  195. data/plugins/guests/omnios/plugin.rb +20 -0
  196. data/plugins/guests/openbsd/cap/change_host_name.rb +14 -0
  197. data/plugins/guests/openbsd/cap/configure_networks.rb +40 -0
  198. data/plugins/guests/openbsd/cap/halt.rb +16 -0
  199. data/plugins/guests/openbsd/cap/mount_nfs_folder.rb +14 -0
  200. data/plugins/guests/openbsd/guest.rb +11 -0
  201. data/plugins/guests/openbsd/plugin.rb +35 -0
  202. data/plugins/guests/pld/cap/network_scripts_dir.rb +11 -0
  203. data/plugins/guests/pld/guest.rb +11 -0
  204. data/plugins/guests/pld/plugin.rb +20 -0
  205. data/plugins/guests/redhat/cap/change_host_name.rb +18 -0
  206. data/plugins/guests/redhat/cap/configure_networks.rb +60 -0
  207. data/plugins/guests/redhat/cap/network_scripts_dir.rb +11 -0
  208. data/plugins/guests/redhat/guest.rb +11 -0
  209. data/plugins/guests/redhat/plugin.rb +30 -0
  210. data/plugins/guests/solaris/cap/change_host_name.rb +17 -0
  211. data/plugins/guests/solaris/cap/configure_networks.rb +25 -0
  212. data/plugins/guests/solaris/cap/halt.rb +22 -0
  213. data/plugins/guests/solaris/cap/mount_virtualbox_shared_folder.rb +31 -0
  214. data/plugins/guests/solaris/config.rb +18 -0
  215. data/plugins/guests/solaris/guest.rb +14 -0
  216. data/plugins/guests/solaris/plugin.rb +40 -0
  217. data/plugins/guests/solaris11/cap/change_host_name.rb +25 -0
  218. data/plugins/guests/solaris11/cap/configure_networks.rb +32 -0
  219. data/plugins/guests/solaris11/cap/halt.rb +26 -0
  220. data/plugins/guests/solaris11/cap/mount_virtualbox_shared_folder.rb +35 -0
  221. data/plugins/guests/solaris11/config.rb +22 -0
  222. data/plugins/guests/solaris11/guest.rb +15 -0
  223. data/plugins/guests/solaris11/plugin.rb +44 -0
  224. data/plugins/guests/suse/cap/change_host_name.rb +18 -0
  225. data/plugins/guests/suse/cap/configure_networks.rb +60 -0
  226. data/plugins/guests/suse/cap/network_scripts_dir.rb +11 -0
  227. data/plugins/guests/suse/guest.rb +11 -0
  228. data/plugins/guests/suse/plugin.rb +30 -0
  229. data/plugins/guests/ubuntu/cap/change_host_name.rb +24 -0
  230. data/plugins/guests/ubuntu/cap/mount_nfs.rb +19 -0
  231. data/plugins/guests/ubuntu/cap/mount_virtualbox_shared_folder.rb +14 -0
  232. data/plugins/guests/ubuntu/guest.rb +13 -0
  233. data/plugins/guests/ubuntu/plugin.rb +30 -0
  234. data/plugins/hosts/arch/host.rb +45 -0
  235. data/plugins/hosts/arch/plugin.rb +15 -0
  236. data/plugins/hosts/bsd/host.rb +178 -0
  237. data/plugins/hosts/bsd/plugin.rb +15 -0
  238. data/plugins/hosts/fedora/host.rb +57 -0
  239. data/plugins/hosts/fedora/plugin.rb +15 -0
  240. data/plugins/hosts/freebsd/host.rb +43 -0
  241. data/plugins/hosts/freebsd/plugin.rb +15 -0
  242. data/plugins/hosts/gentoo/host.rb +26 -0
  243. data/plugins/hosts/gentoo/plugin.rb +15 -0
  244. data/plugins/hosts/linux/host.rb +128 -0
  245. data/plugins/hosts/linux/plugin.rb +15 -0
  246. data/plugins/hosts/opensuse/host.rb +36 -0
  247. data/plugins/hosts/opensuse/plugin.rb +15 -0
  248. data/plugins/hosts/slackware/host.rb +26 -0
  249. data/plugins/hosts/slackware/plugin.rb +15 -0
  250. data/plugins/hosts/windows/host.rb +17 -0
  251. data/plugins/hosts/windows/plugin.rb +15 -0
  252. data/plugins/kernel_v1/config/nfs.rb +20 -0
  253. data/plugins/kernel_v1/config/package.rb +17 -0
  254. data/plugins/kernel_v1/config/ssh.rb +46 -0
  255. data/plugins/kernel_v1/config/vagrant.rb +31 -0
  256. data/plugins/kernel_v1/config/vm.rb +187 -0
  257. data/plugins/kernel_v1/plugin.rb +44 -0
  258. data/plugins/kernel_v2/config/nfs.rb +14 -0
  259. data/plugins/kernel_v2/config/package.rb +13 -0
  260. data/plugins/kernel_v2/config/ssh.rb +68 -0
  261. data/plugins/kernel_v2/config/ssh_connect.rb +40 -0
  262. data/plugins/kernel_v2/config/vagrant.rb +13 -0
  263. data/plugins/kernel_v2/config/vm.rb +486 -0
  264. data/plugins/kernel_v2/config/vm_provisioner.rb +55 -0
  265. data/plugins/kernel_v2/config/vm_subvm.rb +30 -0
  266. data/plugins/kernel_v2/plugin.rb +44 -0
  267. data/plugins/providers/virtualbox/action.rb +324 -0
  268. data/plugins/providers/virtualbox/action/boot.rb +23 -0
  269. data/plugins/providers/virtualbox/action/check_accessible.rb +23 -0
  270. data/plugins/providers/virtualbox/action/check_created.rb +21 -0
  271. data/plugins/providers/virtualbox/action/check_guest_additions.rb +45 -0
  272. data/plugins/providers/virtualbox/action/check_running.rb +21 -0
  273. data/plugins/providers/virtualbox/action/check_virtualbox.rb +22 -0
  274. data/plugins/providers/virtualbox/action/clean_machine_folder.rb +43 -0
  275. data/plugins/providers/virtualbox/action/clear_forwarded_ports.rb +18 -0
  276. data/plugins/providers/virtualbox/action/clear_network_interfaces.rb +31 -0
  277. data/plugins/providers/virtualbox/action/clear_shared_folders.rb +17 -0
  278. data/plugins/providers/virtualbox/action/created.rb +20 -0
  279. data/plugins/providers/virtualbox/action/customize.rb +43 -0
  280. data/plugins/providers/virtualbox/action/destroy.rb +19 -0
  281. data/plugins/providers/virtualbox/action/destroy_unused_network_interfaces.rb +23 -0
  282. data/plugins/providers/virtualbox/action/discard_state.rb +20 -0
  283. data/plugins/providers/virtualbox/action/export.rb +57 -0
  284. data/plugins/providers/virtualbox/action/forced_halt.rb +25 -0
  285. data/plugins/providers/virtualbox/action/forward_ports.rb +89 -0
  286. data/plugins/providers/virtualbox/action/import.rb +54 -0
  287. data/plugins/providers/virtualbox/action/is_paused.rb +20 -0
  288. data/plugins/providers/virtualbox/action/is_running.rb +20 -0
  289. data/plugins/providers/virtualbox/action/is_saved.rb +20 -0
  290. data/plugins/providers/virtualbox/action/match_mac_address.rb +21 -0
  291. data/plugins/providers/virtualbox/action/message_already_running.rb +16 -0
  292. data/plugins/providers/virtualbox/action/message_not_created.rb +16 -0
  293. data/plugins/providers/virtualbox/action/message_not_running.rb +16 -0
  294. data/plugins/providers/virtualbox/action/message_will_not_destroy.rb +17 -0
  295. data/plugins/providers/virtualbox/action/network.rb +424 -0
  296. data/plugins/providers/virtualbox/action/package.rb +20 -0
  297. data/plugins/providers/virtualbox/action/package_vagrantfile.rb +33 -0
  298. data/plugins/providers/virtualbox/action/prepare_forwarded_port_collision_params.rb +35 -0
  299. data/plugins/providers/virtualbox/action/prepare_nfs_settings.rb +69 -0
  300. data/plugins/providers/virtualbox/action/prune_nfs_exports.rb +20 -0
  301. data/plugins/providers/virtualbox/action/resume.rb +25 -0
  302. data/plugins/providers/virtualbox/action/sane_defaults.rb +91 -0
  303. data/plugins/providers/virtualbox/action/set_name.rb +52 -0
  304. data/plugins/providers/virtualbox/action/setup_package_files.rb +51 -0
  305. data/plugins/providers/virtualbox/action/share_folders.rb +128 -0
  306. data/plugins/providers/virtualbox/action/suspend.rb +20 -0
  307. data/plugins/providers/virtualbox/config.rb +123 -0
  308. data/plugins/providers/virtualbox/driver/base.rb +374 -0
  309. data/plugins/providers/virtualbox/driver/meta.rb +148 -0
  310. data/plugins/providers/virtualbox/driver/version_4_0.rb +485 -0
  311. data/plugins/providers/virtualbox/driver/version_4_1.rb +485 -0
  312. data/plugins/providers/virtualbox/driver/version_4_2.rb +499 -0
  313. data/plugins/providers/virtualbox/model/forwarded_port.rb +70 -0
  314. data/plugins/providers/virtualbox/plugin.rb +42 -0
  315. data/plugins/providers/virtualbox/provider.rb +92 -0
  316. data/plugins/providers/virtualbox/util/compile_forwarded_ports.rb +35 -0
  317. data/plugins/provisioners/ansible/config.rb +89 -0
  318. data/plugins/provisioners/ansible/plugin.rb +23 -0
  319. data/plugins/provisioners/ansible/provisioner.rb +100 -0
  320. data/plugins/provisioners/cfengine/cap/debian/cfengine_install.rb +19 -0
  321. data/plugins/provisioners/cfengine/cap/linux/cfengine_installed.rb +14 -0
  322. data/plugins/provisioners/cfengine/cap/linux/cfengine_needs_bootstrap.rb +34 -0
  323. data/plugins/provisioners/cfengine/cap/redhat/cfengine_install.rb +24 -0
  324. data/plugins/provisioners/cfengine/config.rb +126 -0
  325. data/plugins/provisioners/cfengine/plugin.rb +42 -0
  326. data/plugins/provisioners/cfengine/provisioner.rb +135 -0
  327. data/plugins/provisioners/chef/config/base.rb +116 -0
  328. data/plugins/provisioners/chef/config/chef_client.rb +66 -0
  329. data/plugins/provisioners/chef/config/chef_solo.rb +94 -0
  330. data/plugins/provisioners/chef/plugin.rb +33 -0
  331. data/plugins/provisioners/chef/provisioner/base.rb +113 -0
  332. data/plugins/provisioners/chef/provisioner/chef_client.rb +126 -0
  333. data/plugins/provisioners/chef/provisioner/chef_solo.rb +195 -0
  334. data/plugins/provisioners/file/config.rb +29 -0
  335. data/plugins/provisioners/file/plugin.rb +23 -0
  336. data/plugins/provisioners/file/provisioner.rb +16 -0
  337. data/plugins/provisioners/puppet/config/puppet.rb +93 -0
  338. data/plugins/provisioners/puppet/config/puppet_server.rb +16 -0
  339. data/plugins/provisioners/puppet/plugin.rb +33 -0
  340. data/plugins/provisioners/puppet/provisioner/puppet.rb +146 -0
  341. data/plugins/provisioners/puppet/provisioner/puppet_server.rb +74 -0
  342. data/plugins/provisioners/salt/bootstrap-salt.sh +6 -0
  343. data/plugins/provisioners/salt/config.rb +105 -0
  344. data/plugins/provisioners/salt/errors.rb +11 -0
  345. data/plugins/provisioners/salt/plugin.rb +22 -0
  346. data/plugins/provisioners/salt/provisioner.rb +249 -0
  347. data/plugins/provisioners/shell/config.rb +65 -0
  348. data/plugins/provisioners/shell/plugin.rb +23 -0
  349. data/plugins/provisioners/shell/provisioner.rb +98 -0
  350. data/templates/commands/init/Vagrantfile.erb +118 -0
  351. data/templates/commands/ssh_config/config.erb +20 -0
  352. data/templates/config/messages.erb +14 -0
  353. data/templates/config/validation_failed.erb +7 -0
  354. data/templates/guests/arch/network_dhcp.erb +4 -0
  355. data/templates/guests/arch/network_static.erb +5 -0
  356. data/templates/guests/coreos/etcd.service.erb +10 -0
  357. data/templates/guests/debian/network_dhcp.erb +11 -0
  358. data/templates/guests/debian/network_static.erb +7 -0
  359. data/templates/guests/fedora/network_dhcp.erb +6 -0
  360. data/templates/guests/fedora/network_static.erb +12 -0
  361. data/templates/guests/freebsd/network_dhcp.erb +3 -0
  362. data/templates/guests/freebsd/network_static.erb +3 -0
  363. data/templates/guests/gentoo/network_dhcp.erb +4 -0
  364. data/templates/guests/gentoo/network_static.erb +4 -0
  365. data/templates/guests/openbsd/network_dhcp.erb +1 -0
  366. data/templates/guests/openbsd/network_static.erb +1 -0
  367. data/templates/guests/redhat/network_dhcp.erb +6 -0
  368. data/templates/guests/redhat/network_static.erb +8 -0
  369. data/templates/guests/suse/network_dhcp.erb +6 -0
  370. data/templates/guests/suse/network_static.erb +10 -0
  371. data/templates/locales/en.yml +1248 -0
  372. data/templates/nfs/exports.erb +5 -0
  373. data/templates/nfs/exports_freebsd.erb +5 -0
  374. data/templates/nfs/exports_linux.erb +7 -0
  375. data/templates/provisioners/chef_client/client.erb +41 -0
  376. data/templates/provisioners/chef_solo/solo.erb +45 -0
  377. data/test/acceptance/base.rb +48 -0
  378. data/test/acceptance/box_test.rb +99 -0
  379. data/test/acceptance/destroy_test.rb +37 -0
  380. data/test/acceptance/halt_test.rb +72 -0
  381. data/test/acceptance/init_test.rb +33 -0
  382. data/test/acceptance/networking/host_only_test.rb +37 -0
  383. data/test/acceptance/networking/port_forward_test.rb +125 -0
  384. data/test/acceptance/package_test.rb +46 -0
  385. data/test/acceptance/provisioning/basic_test.rb +61 -0
  386. data/test/acceptance/provisioning/chef_solo_test.rb +37 -0
  387. data/test/acceptance/provisioning/shell_test.rb +53 -0
  388. data/test/acceptance/resume_test.rb +17 -0
  389. data/test/acceptance/shared_folders_test.rb +84 -0
  390. data/test/acceptance/skeletons/chef_solo_basic/README.md +3 -0
  391. data/test/acceptance/skeletons/chef_solo_basic/cookbooks/basic/recipes/default.rb +5 -0
  392. data/test/acceptance/skeletons/chef_solo_json/README.md +3 -0
  393. data/test/acceptance/skeletons/chef_solo_json/cookbooks/basic/recipes/default.rb +6 -0
  394. data/test/acceptance/skeletons/provisioner_multi/README.md +3 -0
  395. data/test/acceptance/skeletons/provisioner_multi/cookbooks/basic/recipes/default.rb +5 -0
  396. data/test/acceptance/ssh_test.rb +46 -0
  397. data/test/acceptance/support/config.rb +42 -0
  398. data/test/acceptance/support/isolated_environment.rb +118 -0
  399. data/test/acceptance/support/matchers/have_color.rb +9 -0
  400. data/test/acceptance/support/matchers/match_output.rb +14 -0
  401. data/test/acceptance/support/matchers/succeed.rb +14 -0
  402. data/test/acceptance/support/network_tests.rb +29 -0
  403. data/test/acceptance/support/output.rb +95 -0
  404. data/test/acceptance/support/shared/base_context.rb +72 -0
  405. data/test/acceptance/support/shared/command_examples.rb +33 -0
  406. data/test/acceptance/support/virtualbox.rb +36 -0
  407. data/test/acceptance/suspend_test.rb +56 -0
  408. data/test/acceptance/up_basic_test.rb +33 -0
  409. data/test/acceptance/up_with_box_url.rb +40 -0
  410. data/test/acceptance/vagrant_test.rb +47 -0
  411. data/test/acceptance/version_test.rb +15 -0
  412. data/test/config/acceptance_boxes.yml +7 -0
  413. data/test/support/isolated_environment.rb +46 -0
  414. data/test/support/tempdir.rb +43 -0
  415. data/test/unit/base.rb +27 -0
  416. data/test/unit/support/dummy_provider.rb +16 -0
  417. data/test/unit/support/isolated_environment.rb +179 -0
  418. data/test/unit/support/shared/base_context.rb +104 -0
  419. data/test/unit/vagrant/action/builder_test.rb +242 -0
  420. data/test/unit/vagrant/action/builtin/call_test.rb +145 -0
  421. data/test/unit/vagrant/action/builtin/confirm_test.rb +36 -0
  422. data/test/unit/vagrant/action/builtin/env_set_test.rb +20 -0
  423. data/test/unit/vagrant/action/builtin/graceful_halt_test.rb +60 -0
  424. data/test/unit/vagrant/action/builtin/lock_test.rb +98 -0
  425. data/test/unit/vagrant/action/builtin/ssh_exec_test.rb +57 -0
  426. data/test/unit/vagrant/action/hook_test.rb +120 -0
  427. data/test/unit/vagrant/action/runner_test.rb +71 -0
  428. data/test/unit/vagrant/action/warden_test.rb +92 -0
  429. data/test/unit/vagrant/batch_action_test.rb +36 -0
  430. data/test/unit/vagrant/box_collection_test.rb +237 -0
  431. data/test/unit/vagrant/box_test.rb +122 -0
  432. data/test/unit/vagrant/cli_test.rb +28 -0
  433. data/test/unit/vagrant/config/loader_test.rb +184 -0
  434. data/test/unit/vagrant/config/v1/dummy_config_test.rb +24 -0
  435. data/test/unit/vagrant/config/v1/loader_test.rb +145 -0
  436. data/test/unit/vagrant/config/v1/root_test.rb +40 -0
  437. data/test/unit/vagrant/config/v2/dummy_config_test.rb +24 -0
  438. data/test/unit/vagrant/config/v2/loader_test.rb +151 -0
  439. data/test/unit/vagrant/config/v2/root_test.rb +115 -0
  440. data/test/unit/vagrant/config/v2/util_test.rb +21 -0
  441. data/test/unit/vagrant/config_test.rb +66 -0
  442. data/test/unit/vagrant/environment_test.rb +746 -0
  443. data/test/unit/vagrant/guest_test.rb +179 -0
  444. data/test/unit/vagrant/hosts_test.rb +37 -0
  445. data/test/unit/vagrant/machine_state_test.rb +26 -0
  446. data/test/unit/vagrant/machine_test.rb +384 -0
  447. data/test/unit/vagrant/plugin/v1/command_test.rb +143 -0
  448. data/test/unit/vagrant/plugin/v1/communicator_test.rb +9 -0
  449. data/test/unit/vagrant/plugin/v1/config_test.rb +50 -0
  450. data/test/unit/vagrant/plugin/v1/host_test.rb +5 -0
  451. data/test/unit/vagrant/plugin/v1/manager_test.rb +114 -0
  452. data/test/unit/vagrant/plugin/v1/plugin_test.rb +267 -0
  453. data/test/unit/vagrant/plugin/v1/provider_test.rb +18 -0
  454. data/test/unit/vagrant/plugin/v2/command_test.rb +238 -0
  455. data/test/unit/vagrant/plugin/v2/communicator_test.rb +9 -0
  456. data/test/unit/vagrant/plugin/v2/components_test.rb +17 -0
  457. data/test/unit/vagrant/plugin/v2/config_test.rb +60 -0
  458. data/test/unit/vagrant/plugin/v2/host_test.rb +5 -0
  459. data/test/unit/vagrant/plugin/v2/manager_test.rb +174 -0
  460. data/test/unit/vagrant/plugin/v2/plugin_test.rb +305 -0
  461. data/test/unit/vagrant/plugin/v2/provider_test.rb +18 -0
  462. data/test/unit/vagrant/registry_test.rb +128 -0
  463. data/test/unit/vagrant/util/ansi_escape_code_remover_test.rb +16 -0
  464. data/test/unit/vagrant/util/downloader_test.rb +57 -0
  465. data/test/unit/vagrant/util/file_checksum_test.rb +23 -0
  466. data/test/unit/vagrant/util/hash_with_indifferent_access_test.rb +38 -0
  467. data/test/unit/vagrant/util/is_port_open_test.rb +53 -0
  468. data/test/unit/vagrant/util/line_endings_helper_test.rb +16 -0
  469. data/test/unit/vagrant/util/network_ip_test.rb +17 -0
  470. data/test/unit/vagrant/util/retryable_test.rb +106 -0
  471. data/test/unit/vagrant/util/safe_chdir_test.rb +43 -0
  472. data/test/unit/vagrant/util/scoped_hash_override_test.rb +48 -0
  473. data/test/unit/vagrant/util/ssh_test.rb +30 -0
  474. data/test/unit/vagrant/util/string_block_editor_test.rb +106 -0
  475. data/test/unit/vagrant/util/which_test.rb +43 -0
  476. data/test/unit/vagrant_test.rb +74 -0
  477. data/tnargav.gemspec +1 -1
  478. metadata +477 -1
@@ -0,0 +1,68 @@
1
+ module Vagrant
2
+ module Plugin
3
+ module V1
4
+ # This is the base class for a provider for the V1 API. A provider
5
+ # is responsible for creating compute resources to match the needs
6
+ # of a Vagrant-configured system.
7
+ class Provider
8
+ # Initialize the provider to represent the given machine.
9
+ #
10
+ # @param [Vagrant::Machine] machine The machine that this provider
11
+ # is responsible for.
12
+ def initialize(machine)
13
+ end
14
+
15
+ # This should return an action callable for the given name.
16
+ #
17
+ # @param [Symbol] name Name of the action.
18
+ # @return [Object] A callable action sequence object, whether it
19
+ # is a proc, object, etc.
20
+ def action(name)
21
+ nil
22
+ end
23
+
24
+ # This method is called if the underying machine ID changes. Providers
25
+ # can use this method to load in new data for the actual backing
26
+ # machine or to realize that the machine is now gone (the ID can
27
+ # become `nil`). No parameters are given, since the underlying machine
28
+ # is simply the machine instance given to this object. And no
29
+ # return value is necessary.
30
+ def machine_id_changed
31
+ end
32
+
33
+ # This should return a hash of information that explains how to
34
+ # SSH into the machine. If the machine is not at a point where
35
+ # SSH is even possible, then `nil` should be returned.
36
+ #
37
+ # The general structure of this returned hash should be the
38
+ # following:
39
+ #
40
+ # {
41
+ # :host => "1.2.3.4",
42
+ # :port => "22",
43
+ # :username => "mitchellh",
44
+ # :private_key_path => "/path/to/my/key"
45
+ # }
46
+ #
47
+ # **Note:** Vagrant only supports private key based authentication,
48
+ # mainly for the reason that there is no easy way to exec into an
49
+ # `ssh` prompt with a password, whereas we can pass a private key
50
+ # via commandline.
51
+ #
52
+ # @return [Hash] SSH information. For the structure of this hash
53
+ # read the accompanying documentation for this method.
54
+ def ssh_info
55
+ nil
56
+ end
57
+
58
+ # This should return the state of the machine within this provider.
59
+ # The state can be any symbol.
60
+ #
61
+ # @return [Symbol]
62
+ def state
63
+ nil
64
+ end
65
+ end
66
+ end
67
+ end
68
+ end
@@ -0,0 +1,50 @@
1
+ module Vagrant
2
+ module Plugin
3
+ module V1
4
+ # This is the base class for a provisioner for the V1 API. A provisioner
5
+ # is primarily responsible for installing software on a Vagrant guest.
6
+ class Provisioner
7
+ # The environment which provisioner is running in. This is the
8
+ # action environment, not a Vagrant::Environment.
9
+ attr_reader :env
10
+
11
+ # The configuration for this provisioner. This will be an instance of
12
+ # the `Config` class which is part of the provisioner.
13
+ attr_reader :config
14
+
15
+ def initialize(env, config)
16
+ @env = env
17
+ @config = config
18
+ end
19
+
20
+ # This method is expected to return a class that is used for
21
+ # configuring the provisioner. This return value is expected to be
22
+ # a subclass of {Config}.
23
+ #
24
+ # @return [Config]
25
+ def self.config_class
26
+ end
27
+
28
+ # This is the method called to "prepare" the provisioner. This is called
29
+ # before any actions are run by the action runner (see {Vagrant::Actions::Runner}).
30
+ # This can be used to setup shared folders, forward ports, etc. Whatever is
31
+ # necessary on a "meta" level.
32
+ #
33
+ # No return value is expected.
34
+ def prepare
35
+ end
36
+
37
+ # This is the method called to provision the system. This method
38
+ # is expected to do whatever necessary to provision the system (create files,
39
+ # SSH, etc.)
40
+ def provision!
41
+ end
42
+
43
+ # This is the method called to when the system is being destroyed
44
+ # and allows the provisioners to engage in any cleanup tasks necessary.
45
+ def cleanup
46
+ end
47
+ end
48
+ end
49
+ end
50
+ end
@@ -0,0 +1,22 @@
1
+ require "log4r"
2
+
3
+ # We don't autoload components because if we're loading anything in the
4
+ # V2 namespace anyways, then we're going to need the Components class.
5
+ require "vagrant/plugin/v2/components"
6
+ require "vagrant/plugin/v2/errors"
7
+
8
+ module Vagrant
9
+ module Plugin
10
+ module V2
11
+ autoload :Command, "vagrant/plugin/v2/command"
12
+ autoload :Communicator, "vagrant/plugin/v2/communicator"
13
+ autoload :Config, "vagrant/plugin/v2/config"
14
+ autoload :Guest, "vagrant/plugin/v2/guest"
15
+ autoload :Host, "vagrant/plugin/v2/host"
16
+ autoload :Manager, "vagrant/plugin/v2/manager"
17
+ autoload :Plugin, "vagrant/plugin/v2/plugin"
18
+ autoload :Provider, "vagrant/plugin/v2/provider"
19
+ autoload :Provisioner, "vagrant/plugin/v2/provisioner"
20
+ end
21
+ end
22
+ end
@@ -0,0 +1,237 @@
1
+ require 'log4r'
2
+
3
+ require "vagrant/util/safe_puts"
4
+
5
+ module Vagrant
6
+ module Plugin
7
+ module V2
8
+ # This is the base class for a CLI command.
9
+ class Command
10
+ include Util::SafePuts
11
+
12
+ def initialize(argv, env)
13
+ @argv = argv
14
+ @env = env
15
+ @logger = Log4r::Logger.new("vagrant::command::#{self.class.to_s.downcase}")
16
+ end
17
+
18
+ # This is what is called on the class to actually execute it. Any
19
+ # subclasses should implement this method and do any option parsing
20
+ # and validation here.
21
+ def execute
22
+ end
23
+
24
+ protected
25
+
26
+ # Parses the options given an OptionParser instance.
27
+ #
28
+ # This is a convenience method that properly handles duping the
29
+ # originally argv array so that it is not destroyed.
30
+ #
31
+ # This method will also automatically detect "-h" and "--help"
32
+ # and print help. And if any invalid options are detected, the help
33
+ # will be printed, as well.
34
+ #
35
+ # If this method returns `nil`, then you should assume that help
36
+ # was printed and parsing failed.
37
+ def parse_options(opts=nil)
38
+ # Creating a shallow copy of the arguments so the OptionParser
39
+ # doesn't destroy the originals.
40
+ argv = @argv.dup
41
+
42
+ # Default opts to a blank optionparser if none is given
43
+ opts ||= OptionParser.new
44
+
45
+ # Add the help option, which must be on every command.
46
+ opts.on_tail("-h", "--help", "Print this help") do
47
+ safe_puts(opts.help)
48
+ return nil
49
+ end
50
+
51
+ opts.parse!(argv)
52
+ return argv
53
+ rescue OptionParser::InvalidOption
54
+ raise Errors::CLIInvalidOptions, :help => opts.help.chomp
55
+ end
56
+
57
+ # Yields a VM for each target VM for the command.
58
+ #
59
+ # This is a convenience method for easily implementing methods that
60
+ # take a target VM (in the case of multi-VM) or every VM if no
61
+ # specific VM name is specified.
62
+ #
63
+ # @param [String] name The name of the VM. Nil if every VM.
64
+ # @param [Hash] options Additional tweakable settings.
65
+ # @option options [Symbol] :provider The provider to back the
66
+ # machines with. All machines will be backed with this
67
+ # provider. If none is given, a sensible default is chosen.
68
+ # @option options [Boolean] :reverse If true, the resulting order
69
+ # of machines is reversed.
70
+ # @option options [Boolean] :single_target If true, then an
71
+ # exception will be raised if more than one target is found.
72
+ def with_target_vms(names=nil, options=nil)
73
+ @logger.debug("Getting target VMs for command. Arguments:")
74
+ @logger.debug(" -- names: #{names.inspect}")
75
+ @logger.debug(" -- options: #{options.inspect}")
76
+
77
+ # Using VMs requires a Vagrant environment to be properly setup
78
+ raise Errors::NoEnvironmentError if !@env.root_path
79
+
80
+ # Setup the options hash
81
+ options ||= {}
82
+
83
+ # Require that names be an array
84
+ names ||= []
85
+ names = [names] if !names.is_a?(Array)
86
+
87
+ # Cache the active machines outside the loop
88
+ active_machines = @env.active_machines
89
+
90
+ # This is a helper that gets a single machine with the proper
91
+ # provider. The "proper provider" in this case depends on what was
92
+ # given:
93
+ #
94
+ # * If a provider was explicitly specified, then use that provider.
95
+ # But if an active machine exists with a DIFFERENT provider,
96
+ # then throw an error (for now), since we don't yet support
97
+ # bringing up machines with different providers.
98
+ #
99
+ # * If no provider was specified, then use the active machine's
100
+ # provider if it exists, otherwise use the default provider.
101
+ #
102
+ get_machine = lambda do |name|
103
+ # Check for an active machine with the same name
104
+ provider_to_use = options[:provider]
105
+ provider_to_use = provider_to_use.to_sym if provider_to_use
106
+
107
+ active_machines.each do |active_name, active_provider|
108
+ if name == active_name
109
+ # We found an active machine with the same name
110
+
111
+ if provider_to_use && provider_to_use != active_provider
112
+ # We found an active machine with a provider that doesn't
113
+ # match the requested provider. Show an error.
114
+ raise Errors::ActiveMachineWithDifferentProvider,
115
+ :name => active_name.to_s,
116
+ :active_provider => active_provider.to_s,
117
+ :requested_provider => provider_to_use.to_s
118
+ else
119
+ # Use this provider and exit out of the loop. One of the
120
+ # invariants [for now] is that there shouldn't be machines
121
+ # with multiple providers.
122
+ @logger.info("Active machine found with name #{active_name}. " +
123
+ "Using provider: #{active_provider}")
124
+ provider_to_use = active_provider
125
+ break
126
+ end
127
+ end
128
+ end
129
+
130
+ # Use the default provider if nothing else
131
+ provider_to_use ||= @env.default_provider
132
+
133
+ # Get the right machine with the right provider
134
+ @env.machine(name, provider_to_use)
135
+ end
136
+
137
+ # First determine the proper array of VMs.
138
+ machines = []
139
+ if names.length > 0
140
+ names.each do |name|
141
+ if pattern = name[/^\/(.+?)\/$/, 1]
142
+ @logger.debug("Finding machines that match regex: #{pattern}")
143
+
144
+ # This is a regular expression name, so we convert to a regular
145
+ # expression and allow that sort of matching.
146
+ regex = Regexp.new(pattern)
147
+
148
+ @env.machine_names.each do |machine_name|
149
+ if machine_name =~ regex
150
+ machines << get_machine.call(machine_name)
151
+ end
152
+ end
153
+
154
+ raise Errors::VMNoMatchError if machines.empty?
155
+ else
156
+ # String name, just look for a specific VM
157
+ @logger.debug("Finding machine that match name: #{name}")
158
+ machines << get_machine.call(name.to_sym)
159
+ raise Errors::VMNotFoundError, :name => name if !machines[0]
160
+ end
161
+ end
162
+ else
163
+ # No name was given, so we return every VM in the order
164
+ # configured.
165
+ @logger.debug("Loading all machines...")
166
+ machines = @env.machine_names.map do |machine_name|
167
+ get_machine.call(machine_name)
168
+ end
169
+ end
170
+
171
+ # Make sure we're only working with one VM if single target
172
+ if options[:single_target] && machines.length != 1
173
+ @logger.debug("Using primary machine since single target")
174
+ primary_name = @env.primary_machine_name
175
+ raise Errors::MultiVMTargetRequired if !primary_name
176
+ machines = [get_machine.call(primary_name)]
177
+ end
178
+
179
+ # If we asked for reversed ordering, then reverse it
180
+ machines.reverse! if options[:reverse]
181
+
182
+ # Go through each VM and yield it!
183
+ machines.each do |machine|
184
+ @logger.info("With machine: #{machine.name} (#{machine.provider.inspect})")
185
+ yield machine
186
+ end
187
+ end
188
+
189
+ # This method will split the argv given into three parts: the
190
+ # flags to this command, the subcommand, and the flags to the
191
+ # subcommand. For example:
192
+ #
193
+ # -v status -h -v
194
+ #
195
+ # The above would yield 3 parts:
196
+ #
197
+ # ["-v"]
198
+ # "status"
199
+ # ["-h", "-v"]
200
+ #
201
+ # These parts are useful because the first is a list of arguments
202
+ # given to the current command, the second is a subcommand, and the
203
+ # third are the commands given to the subcommand.
204
+ #
205
+ # @return [Array] The three parts.
206
+ def split_main_and_subcommand(argv)
207
+ # Initialize return variables
208
+ main_args = nil
209
+ sub_command = nil
210
+ sub_args = []
211
+
212
+ # We split the arguments into two: One set containing any
213
+ # flags before a word, and then the rest. The rest are what
214
+ # get actually sent on to the subcommand.
215
+ argv.each_index do |i|
216
+ if !argv[i].start_with?("-")
217
+ # We found the beginning of the sub command. Split the
218
+ # args up.
219
+ main_args = argv[0, i]
220
+ sub_command = argv[i]
221
+ sub_args = argv[i + 1, argv.length - i + 1]
222
+
223
+ # Break so we don't find the next non flag and shift our
224
+ # main args.
225
+ break
226
+ end
227
+ end
228
+
229
+ # Handle the case that argv was empty or didn't contain any subcommand
230
+ main_args = argv.dup if main_args.nil?
231
+
232
+ return [main_args, sub_command, sub_args]
233
+ end
234
+ end
235
+ end
236
+ end
237
+ end
@@ -0,0 +1,119 @@
1
+ require "timeout"
2
+
3
+ module Vagrant
4
+ module Plugin
5
+ module V2
6
+ # Base class for a communicator in Vagrant. A communicator is
7
+ # responsible for communicating with a machine in some way. There
8
+ # are various stages of Vagrant that require things such as uploading
9
+ # files to the machine, executing shell commands, etc. Implementors
10
+ # of this class are expected to provide this functionality in some
11
+ # way.
12
+ #
13
+ # Note that a communicator must provide **all** of the methods
14
+ # in this base class. There is currently no way for one communicator
15
+ # to provide say a more efficient way of uploading a file, but not
16
+ # provide shell execution. This sort of thing will come in a future
17
+ # version.
18
+ class Communicator
19
+ # This returns true/false depending on if the given machine
20
+ # can be communicated with using this communicator. If this returns
21
+ # `true`, then this class will be used as the primary communication
22
+ # method for the machine.
23
+ #
24
+ # @return [Boolean]
25
+ def self.match?(machine)
26
+ false
27
+ end
28
+
29
+ # Initializes the communicator with the machine that we will be
30
+ # communicating with. This base method does nothing (it doesn't
31
+ # even store the machine in an instance variable for you), so you're
32
+ # expected to override this and do something with the machine if
33
+ # you care about it.
34
+ #
35
+ # @param [Machine] machine The machine this instance is expected to
36
+ # communicate with.
37
+ def initialize(machine)
38
+ end
39
+
40
+ # Checks if the target machine is ready for communication. If this
41
+ # returns true, then all the other methods for communicating with
42
+ # the machine are expected to be functional.
43
+ #
44
+ # @return [Boolean]
45
+ def ready?
46
+ false
47
+ end
48
+
49
+ # wait_for_ready waits until the communicator is ready, blocking
50
+ # until then. It will wait up to the given duration or raise an
51
+ # exception if something goes wrong.
52
+ def wait_for_ready(duration)
53
+ # By default, we implement a naive solution.
54
+ begin
55
+ Timeout.timeout(duration) do
56
+ while true
57
+ return true if ready?
58
+ sleep 0.5
59
+ end
60
+ end
61
+ rescue Timeout::Error
62
+ # We timed out, we failed.
63
+ end
64
+
65
+ return false
66
+ end
67
+
68
+ # Download a file from the remote machine to the local machine.
69
+ #
70
+ # @param [String] from Path of the file on the remote machine.
71
+ # @param [String] to Path of where to save the file locally.
72
+ def download(from, to)
73
+ end
74
+
75
+ # Upload a file to the remote machine.
76
+ #
77
+ # @param [String] from Path of the file locally to upload.
78
+ # @param [String] to Path of where to save the file on the remote
79
+ # machine.
80
+ def upload(from, to)
81
+ end
82
+
83
+ # Execute a command on the remote machine. The exact semantics
84
+ # of this method are up to the implementor, but in general the
85
+ # users of this class will expect this to be a shell.
86
+ #
87
+ # This method gives you no way to write data back to the remote
88
+ # machine, so only execute commands that don't expect input.
89
+ #
90
+ # @param [String] command Command to execute.
91
+ # @yield [type, data] Realtime output of the command being executed.
92
+ # @yieldparam [String] type Type of the output. This can be
93
+ # `:stdout`, `:stderr`, etc. The exact types are up to the
94
+ # implementor.
95
+ # @yieldparam [String] data Data for the given output.
96
+ # @return [Integer] Exit code of the command.
97
+ def execute(command, opts=nil)
98
+ end
99
+
100
+ # Executes a command on the remote machine with administrative
101
+ # privileges. See {#execute} for documentation, as the API is the
102
+ # same.
103
+ #
104
+ # @see #execute
105
+ def sudo(command, opts=nil)
106
+ end
107
+
108
+ # Executes a command and returns true if the command succeeded,
109
+ # and false otherwise. By default, this executes as a normal user,
110
+ # and it is up to the communicator implementation if they expose an
111
+ # option for running tests as an administrator.
112
+ #
113
+ # @see #execute
114
+ def test(command, opts=nil)
115
+ end
116
+ end
117
+ end
118
+ end
119
+ end