fairchild-poolparty 1.1.4 → 1.1.5

Sign up to get free protection for your applications and to get access to all the features.
Files changed (333) hide show
  1. data/README.txt +0 -12
  2. data/Rakefile +17 -1
  3. data/VERSION.yml +1 -1
  4. data/bin/cloud +20 -1
  5. data/bin/cloud-bootstrap +14 -4
  6. data/bin/cloud-configure +26 -9
  7. data/bin/cloud-contract +7 -7
  8. data/bin/cloud-describe +28 -0
  9. data/bin/cloud-expand +13 -6
  10. data/bin/cloud-list +3 -5
  11. data/bin/cloud-osxcopy +1 -1
  12. data/bin/cloud-provision +1 -1
  13. data/bin/cloud-show +6 -5
  14. data/bin/cloud-ssh +1 -3
  15. data/bin/cloud-start +8 -6
  16. data/bin/cloud-terminate +9 -7
  17. data/bin/server-cloud-elections +29 -18
  18. data/bin/server-ensure-provisioning +24 -29
  19. data/bin/server-list-active +10 -5
  20. data/bin/server-monitor.ru +18 -1
  21. data/bin/server-update-hosts +3 -3
  22. data/bin/server-write-new-nodes +1 -1
  23. data/config/jeweler.rb +12 -3
  24. data/lib/poolparty/aska/aska.rb +1 -12
  25. data/lib/poolparty/base_packages/haproxy.rb +26 -18
  26. data/lib/poolparty/base_packages/poolparty.rb +1 -1
  27. data/lib/poolparty/capistrano.rb +1 -1
  28. data/lib/poolparty/core/array.rb +12 -0
  29. data/lib/poolparty/core/hash.rb +12 -5
  30. data/lib/poolparty/core/nil.rb +8 -0
  31. data/lib/poolparty/core/object.rb +15 -5
  32. data/lib/poolparty/core/string.rb +28 -2
  33. data/lib/poolparty/dependency_resolver/chef_resolver.rb +106 -79
  34. data/lib/poolparty/dependency_resolver/dependency_resolver.rb +1 -1
  35. data/lib/poolparty/dependency_resolver/dependency_resolver_cloud_extensions.rb +5 -4
  36. data/lib/poolparty/dependency_resolver/puppet_resolver.rb +44 -17
  37. data/lib/poolparty/helpers/console.rb +1 -1
  38. data/lib/poolparty/helpers/optioner.rb +9 -2
  39. data/lib/poolparty/lite.rb +12 -2
  40. data/lib/poolparty/modules/callbacks.rb +44 -0
  41. data/lib/poolparty/modules/cloud_dsl.rb +17 -11
  42. data/lib/poolparty/modules/cloud_resourcer.rb +29 -21
  43. data/lib/poolparty/modules/definable_resource.rb +1 -1
  44. data/lib/poolparty/modules/pinger.rb +28 -0
  45. data/lib/poolparty/modules/resourcing_dsl.rb +7 -3
  46. data/lib/poolparty/modules/thread_pool.rb +107 -106
  47. data/lib/poolparty/modules/user_helpers.rb +20 -0
  48. data/lib/poolparty/monitors/base_monitor.rb +32 -81
  49. data/lib/poolparty/monitors/monitor_rack.rb +60 -69
  50. data/lib/poolparty/monitors/monitors/favicon_monitor.rb +12 -0
  51. data/lib/poolparty/monitors/monitors/load_monitor.rb +9 -15
  52. data/lib/poolparty/monitors/monitors/memory_monitor.rb +48 -48
  53. data/lib/poolparty/monitors/monitors/neighborhood_monitor.rb +77 -0
  54. data/lib/poolparty/monitors/{stats_monitor.rb → monitors/stats_monitor.rb} +29 -24
  55. data/lib/poolparty/monitors/monitors/time_monitor.rb +15 -0
  56. data/lib/poolparty/net/messenger.rb +2 -0
  57. data/lib/poolparty/net/remoter/cloud_control.rb +177 -227
  58. data/lib/poolparty/net/remoter/connections.rb +10 -18
  59. data/lib/poolparty/net/remoter/interactive.rb +24 -90
  60. data/lib/poolparty/net/remoter_base.rb +98 -25
  61. data/lib/poolparty/net/remoter_bases/ec2/ec2.rb +83 -66
  62. data/lib/poolparty/net/remoter_bases/vmrun/utilities/vm_disk.rb +12 -0
  63. data/lib/poolparty/net/remoter_bases/vmrun/utilities/vmx.rb +33 -0
  64. data/lib/poolparty/net/remoter_bases/vmrun/utilities/vmx_file.rb +117 -0
  65. data/lib/poolparty/net/remoter_bases/vmrun/vmrun.rb +165 -0
  66. data/lib/poolparty/net/remoter_bases/vmrun/vmrun_instance.rb +71 -0
  67. data/lib/poolparty/{base_packages → plugins}/bind.rb +1 -1
  68. data/lib/poolparty/plugins/chef.rb +71 -71
  69. data/lib/poolparty/plugins/chef_deploy.rb +58 -0
  70. data/lib/poolparty/plugins/{deploydirectory.rb → deploy_directory.rb} +12 -3
  71. data/lib/poolparty/plugins/dynomite.rb +14 -0
  72. data/lib/poolparty/plugins/gem_package.rb +37 -0
  73. data/lib/poolparty/plugins/line_in_file.rb +1 -0
  74. data/lib/poolparty/plugins/nanite.rb +41 -0
  75. data/lib/poolparty/{base_packages → plugins}/tokyo_tyrant.rb +1 -1
  76. data/lib/poolparty/poolparty/cloud.rb +36 -35
  77. data/lib/poolparty/poolparty/default.rb +2 -11
  78. data/lib/poolparty/poolparty/key.rb +15 -12
  79. data/lib/poolparty/poolparty/neighborhoods.rb +54 -21
  80. data/lib/poolparty/poolparty/plugin.rb +6 -9
  81. data/lib/poolparty/poolparty/plugin_model.rb +5 -5
  82. data/lib/poolparty/poolparty/pool.rb +8 -4
  83. data/lib/poolparty/poolparty/poolparty_base_class.rb +20 -11
  84. data/lib/poolparty/poolparty/resource.rb +9 -5
  85. data/lib/poolparty/poolparty/service.rb +3 -1
  86. data/lib/poolparty/provision/boot_strapper.rb +47 -24
  87. data/lib/poolparty/provision/configurations/chef.rb +7 -4
  88. data/lib/poolparty/provision/dr_configure.rb +80 -25
  89. data/lib/poolparty/resources/cron.rb +8 -0
  90. data/lib/poolparty/resources/directory.rb +1 -1
  91. data/lib/poolparty/resources/file.rb +16 -0
  92. data/lib/poolparty/resources/package.rb +7 -2
  93. data/lib/poolparty/resources/service.rb +4 -3
  94. data/lib/poolparty/resources/symlink.rb +0 -8
  95. data/lib/poolparty/schema.rb +35 -20
  96. data/lib/poolparty/templates/haproxy.conf +27 -25
  97. data/lib/poolparty/templates/monitor.ru +3 -3
  98. data/lib/poolparty/verification/verifier_base.rb +17 -0
  99. data/lib/poolparty/verification/verifiers/ping.rb +17 -0
  100. data/lib/poolparty/verification/verify.rb +74 -0
  101. data/lib/poolparty.rb +8 -9
  102. data/lib/poolpartycl.rb +14 -0
  103. data/spec/bin/server-list-active_spec.rb +2 -0
  104. data/spec/poolparty/base_packages/haproxy_spec.rb +1 -1
  105. data/spec/poolparty/core/array_spec.rb +3 -1
  106. data/spec/poolparty/core/ordered_hash_spec.rb +2 -2
  107. data/spec/poolparty/dependency_resolver/chef_resolver_spec.rb +9 -15
  108. data/spec/poolparty/dependency_resolver/dependency_resolver_cloud_extensions_spec.rb +6 -6
  109. data/spec/poolparty/dependency_resolver/puppet_resolver_spec.rb +121 -124
  110. data/spec/poolparty/net/remote_spec.rb +287 -286
  111. data/spec/poolparty/net/remoter_bases/ec2_mocks_and_stubs.rb +1 -1
  112. data/spec/poolparty/net/remoter_bases/ec2_remote_instance_spec.rb +7 -8
  113. data/spec/poolparty/net/remoter_bases/ec2_spec.rb +22 -7
  114. data/spec/poolparty/net/remoter_spec.rb +48 -45
  115. data/spec/poolparty/poolparty/cloud_spec.rb +15 -22
  116. data/spec/poolparty/poolparty/key_spec.rb +4 -4
  117. data/spec/poolparty/poolparty/neighborhoods_spec.rb +1 -2
  118. data/spec/poolparty/poolparty/plugin_spec.rb +2 -2
  119. data/spec/poolparty/poolparty/resource_spec.rb +4 -5
  120. data/spec/poolparty/poolparty_base_class_spec.rb +82 -78
  121. data/spec/poolparty/resources/package_spec.rb +0 -3
  122. data/spec/poolparty/spec_helper.rb +4 -4
  123. data/tasks/development.rake +9 -0
  124. data/test/poolparty/core/array_test.rb +21 -0
  125. data/test/poolparty/core/hash_test.rb +14 -1
  126. data/test/poolparty/core/string_test.rb +29 -0
  127. data/test/poolparty/dependency_resolver/puppet_resolver_test.rb +106 -0
  128. data/test/poolparty/modules/callbacks_test.rb +40 -0
  129. data/test/poolparty/modules/cloud_dsl_test.rb +25 -0
  130. data/test/poolparty/net/remoter_bases/vmrun/vmrun_test.rb +50 -0
  131. data/test/poolparty/net/remoter_test.rb +14 -0
  132. data/test/poolparty/poolparty/neighborhood_test.rb +23 -0
  133. data/test/poolparty/poolparty/poolparty_base_class_test.rb +84 -0
  134. data/test/poolparty/verification/verify_test.rb +49 -0
  135. data/test/test_helper.rb +4 -1
  136. data/test/test_poolparty.rb +6 -5
  137. data/vendor/chef/apache2/attributes/apache.rb +1 -1
  138. data/vendor/chef/apache2/templates/default/default-site.erb +1 -1
  139. data/vendor/chef/chef-deploy/LICENSE +201 -0
  140. data/vendor/chef/chef-deploy/README.rdoc +24 -0
  141. data/vendor/chef/chef-deploy/Rakefile +57 -0
  142. data/vendor/chef/chef-deploy/TODO +4 -0
  143. data/vendor/chef/chef-deploy/lib/chef-deploy/cached_deploy.rb +230 -0
  144. data/vendor/chef/chef-deploy/lib/chef-deploy/git.rb +132 -0
  145. data/vendor/chef/chef-deploy/lib/chef-deploy/subversion.rb +98 -0
  146. data/vendor/chef/chef-deploy/lib/chef-deploy.rb +183 -0
  147. metadata +57 -252
  148. data/bin/cloud-run +0 -18
  149. data/bin/cloud-stats +0 -17
  150. data/bin/ec2-list-active +0 -24
  151. data/bin/pool +0 -31
  152. data/bin/pool-describe +0 -8
  153. data/bin/pool-generate +0 -18
  154. data/bin/pool-init +0 -28
  155. data/bin/pool-list +0 -30
  156. data/bin/pool-start +0 -26
  157. data/bin/server-list-instances +0 -15
  158. data/lib/erlang/messenger/Emakefile +0 -1
  159. data/lib/erlang/messenger/Makefile +0 -15
  160. data/lib/erlang/messenger/README +0 -5
  161. data/lib/erlang/messenger/Rakefile +0 -72
  162. data/lib/erlang/messenger/control +0 -11
  163. data/lib/erlang/messenger/ebin/client.app +0 -19
  164. data/lib/erlang/messenger/ebin/master.app +0 -19
  165. data/lib/erlang/messenger/ebin/node.app +0 -19
  166. data/lib/erlang/messenger/ebin/packager.app +0 -19
  167. data/lib/erlang/messenger/ebin/pm_client_rel-0.1.rel +0 -1
  168. data/lib/erlang/messenger/ebin/pm_master_rel-0.1.rel +0 -1
  169. data/lib/erlang/messenger/ebin/pm_node_rel-0.1.rel +0 -1
  170. data/lib/erlang/messenger/include/defines.hrl +0 -27
  171. data/lib/erlang/messenger/lib/eunit/AUTHORS +0 -2
  172. data/lib/erlang/messenger/lib/eunit/CHANGELOG +0 -14
  173. data/lib/erlang/messenger/lib/eunit/COPYING +0 -504
  174. data/lib/erlang/messenger/lib/eunit/Makefile +0 -28
  175. data/lib/erlang/messenger/lib/eunit/NOTES +0 -276
  176. data/lib/erlang/messenger/lib/eunit/README +0 -3
  177. data/lib/erlang/messenger/lib/eunit/doc/edoc-info +0 -3
  178. data/lib/erlang/messenger/lib/eunit/doc/erlang.png +0 -0
  179. data/lib/erlang/messenger/lib/eunit/doc/eunit.html +0 -172
  180. data/lib/erlang/messenger/lib/eunit/doc/index.html +0 -17
  181. data/lib/erlang/messenger/lib/eunit/doc/modules-frame.html +0 -12
  182. data/lib/erlang/messenger/lib/eunit/doc/overview-summary.html +0 -984
  183. data/lib/erlang/messenger/lib/eunit/doc/overview.edoc +0 -980
  184. data/lib/erlang/messenger/lib/eunit/doc/packages-frame.html +0 -11
  185. data/lib/erlang/messenger/lib/eunit/doc/stylesheet.css +0 -55
  186. data/lib/erlang/messenger/lib/eunit/ebin/autoload.beam +0 -0
  187. data/lib/erlang/messenger/lib/eunit/ebin/code_monitor.beam +0 -0
  188. data/lib/erlang/messenger/lib/eunit/ebin/eunit.app +0 -21
  189. data/lib/erlang/messenger/lib/eunit/ebin/eunit.appup +0 -1
  190. data/lib/erlang/messenger/lib/eunit/ebin/eunit.beam +0 -0
  191. data/lib/erlang/messenger/lib/eunit/ebin/eunit_autoexport.beam +0 -0
  192. data/lib/erlang/messenger/lib/eunit/ebin/eunit_data.beam +0 -0
  193. data/lib/erlang/messenger/lib/eunit/ebin/eunit_lib.beam +0 -0
  194. data/lib/erlang/messenger/lib/eunit/ebin/eunit_proc.beam +0 -0
  195. data/lib/erlang/messenger/lib/eunit/ebin/eunit_serial.beam +0 -0
  196. data/lib/erlang/messenger/lib/eunit/ebin/eunit_server.beam +0 -0
  197. data/lib/erlang/messenger/lib/eunit/ebin/eunit_striptests.beam +0 -0
  198. data/lib/erlang/messenger/lib/eunit/ebin/eunit_test.beam +0 -0
  199. data/lib/erlang/messenger/lib/eunit/ebin/eunit_tests.beam +0 -0
  200. data/lib/erlang/messenger/lib/eunit/ebin/eunit_tty.beam +0 -0
  201. data/lib/erlang/messenger/lib/eunit/ebin/file_monitor.beam +0 -0
  202. data/lib/erlang/messenger/lib/eunit/examples/eunit_examples.erl +0 -339
  203. data/lib/erlang/messenger/lib/eunit/examples/fib.erl +0 -19
  204. data/lib/erlang/messenger/lib/eunit/examples/tests.txt +0 -1
  205. data/lib/erlang/messenger/lib/eunit/include/eunit.hrl +0 -313
  206. data/lib/erlang/messenger/lib/eunit/src/Makefile +0 -46
  207. data/lib/erlang/messenger/lib/eunit/src/autoload.erl +0 -388
  208. data/lib/erlang/messenger/lib/eunit/src/code_monitor.erl +0 -243
  209. data/lib/erlang/messenger/lib/eunit/src/eunit.app.src +0 -21
  210. data/lib/erlang/messenger/lib/eunit/src/eunit.appup.src +0 -1
  211. data/lib/erlang/messenger/lib/eunit/src/eunit.erl +0 -196
  212. data/lib/erlang/messenger/lib/eunit/src/eunit_autoexport.erl +0 -102
  213. data/lib/erlang/messenger/lib/eunit/src/eunit_data.erl +0 -798
  214. data/lib/erlang/messenger/lib/eunit/src/eunit_internal.hrl +0 -48
  215. data/lib/erlang/messenger/lib/eunit/src/eunit_lib.erl +0 -682
  216. data/lib/erlang/messenger/lib/eunit/src/eunit_proc.erl +0 -552
  217. data/lib/erlang/messenger/lib/eunit/src/eunit_serial.erl +0 -157
  218. data/lib/erlang/messenger/lib/eunit/src/eunit_server.erl +0 -340
  219. data/lib/erlang/messenger/lib/eunit/src/eunit_striptests.erl +0 -64
  220. data/lib/erlang/messenger/lib/eunit/src/eunit_test.erl +0 -334
  221. data/lib/erlang/messenger/lib/eunit/src/eunit_tests.erl +0 -45
  222. data/lib/erlang/messenger/lib/eunit/src/eunit_tty.erl +0 -272
  223. data/lib/erlang/messenger/lib/eunit/src/file_monitor.erl +0 -409
  224. data/lib/erlang/messenger/lib/eunit/sys.config +0 -9
  225. data/lib/erlang/messenger/lib/eunit/vsn.mk +0 -1
  226. data/lib/erlang/messenger/pm_client_rel-0.1.boot +0 -0
  227. data/lib/erlang/messenger/pm_client_rel-0.1.script +0 -238
  228. data/lib/erlang/messenger/pm_master_rel-0.1.boot +0 -0
  229. data/lib/erlang/messenger/pm_master_rel-0.1.script +0 -239
  230. data/lib/erlang/messenger/pm_node_rel-0.1.boot +0 -0
  231. data/lib/erlang/messenger/pm_node_rel-0.1.script +0 -237
  232. data/lib/erlang/messenger/src/client_app.erl +0 -39
  233. data/lib/erlang/messenger/src/client_server.erl +0 -60
  234. data/lib/erlang/messenger/src/master_app.erl +0 -39
  235. data/lib/erlang/messenger/src/node_app.erl +0 -39
  236. data/lib/erlang/messenger/src/pm_client.erl +0 -49
  237. data/lib/erlang/messenger/src/pm_client_supervisor.erl +0 -38
  238. data/lib/erlang/messenger/src/pm_cluster.erl +0 -61
  239. data/lib/erlang/messenger/src/pm_event_manager.erl +0 -27
  240. data/lib/erlang/messenger/src/pm_master.erl +0 -215
  241. data/lib/erlang/messenger/src/pm_master_event_handler.erl +0 -72
  242. data/lib/erlang/messenger/src/pm_master_supervisor.erl +0 -39
  243. data/lib/erlang/messenger/src/pm_node.erl +0 -200
  244. data/lib/erlang/messenger/src/pm_node_supervisor.erl +0 -38
  245. data/lib/erlang/messenger/src/pm_packager.erl +0 -76
  246. data/lib/erlang/messenger/src/pm_spawner.erl +0 -213
  247. data/lib/erlang/messenger/src/pm_strings.erl +0 -11
  248. data/lib/erlang/messenger/src/utils.erl +0 -72
  249. data/lib/erlang/messenger/useful_snippets +0 -17
  250. data/lib/poolparty/monitors/monitors/server_monitor.rb +0 -7
  251. data/lib/poolparty/monitors/monitors/web_monitor.rb +0 -18
  252. data/lib/poolparty/monitors/neighborhood_monitor.rb +0 -24
  253. data/lib/poolparty/monitors.rb +0 -6
  254. data/lib/poolparty/net/remoter/lists.rb +0 -12
  255. data/lib/poolparty/poolparty/custom_resource.rb +0 -45
  256. data/lib/poolparty/resources/custom_service.rb +0 -30
  257. data/lib/poolparty/services/gem_package.rb +0 -52
  258. data/lib/poolparty/version.rb +0 -15
  259. data/spec/poolparty/plugins/svn_spec.rb +0 -16
  260. data/spec/poolparty/poolparty/custom_resource_spec.rb +0 -79
  261. data/vendor/gems/butterfly/History.txt +0 -4
  262. data/vendor/gems/butterfly/PostInstall.txt +0 -2
  263. data/vendor/gems/butterfly/README.rdoc +0 -48
  264. data/vendor/gems/butterfly/Rakefile +0 -62
  265. data/vendor/gems/butterfly/VERSION.yml +0 -4
  266. data/vendor/gems/butterfly/bin/flutter +0 -4
  267. data/vendor/gems/butterfly/butterfly.gemspec +0 -37
  268. data/vendor/gems/butterfly/examples/config.ru +0 -15
  269. data/vendor/gems/butterfly/examples/my_app.rb +0 -12
  270. data/vendor/gems/butterfly/lib/butterfly.rb +0 -14
  271. data/vendor/gems/butterfly/lib/handler.rb +0 -48
  272. data/vendor/gems/butterfly/lib/request.rb +0 -29
  273. data/vendor/gems/butterfly/lib/response.rb +0 -49
  274. data/vendor/gems/butterfly/script/console +0 -10
  275. data/vendor/gems/butterfly/script/destroy +0 -14
  276. data/vendor/gems/butterfly/script/generate +0 -14
  277. data/vendor/gems/butterfly/test/test_adapter_base.rb +0 -23
  278. data/vendor/gems/butterfly/test/test_butterfly_request.rb +0 -46
  279. data/vendor/gems/butterfly/test/test_butterfly_response.rb +0 -43
  280. data/vendor/gems/butterfly/test/test_butterfly_server.rb +0 -16
  281. data/vendor/gems/butterfly/test/test_default.rb +0 -12
  282. data/vendor/gems/butterfly/test/test_helper.rb +0 -6
  283. data/vendor/gems/dslify/History.txt +0 -4
  284. data/vendor/gems/dslify/Manifest.txt +0 -25
  285. data/vendor/gems/dslify/PostInstall.txt +0 -5
  286. data/vendor/gems/dslify/README.txt +0 -60
  287. data/vendor/gems/dslify/Rakefile +0 -56
  288. data/vendor/gems/dslify/config/hoe.rb +0 -73
  289. data/vendor/gems/dslify/config/requirements.rb +0 -15
  290. data/vendor/gems/dslify/dslify.gemspec +0 -40
  291. data/vendor/gems/dslify/lib/dslify/dslify.rb +0 -69
  292. data/vendor/gems/dslify/lib/dslify/version.rb +0 -10
  293. data/vendor/gems/dslify/lib/dslify.rb +0 -7
  294. data/vendor/gems/dslify/script/console +0 -10
  295. data/vendor/gems/dslify/script/destroy +0 -14
  296. data/vendor/gems/dslify/script/generate +0 -14
  297. data/vendor/gems/dslify/script/txt2html +0 -82
  298. data/vendor/gems/dslify/setup.rb +0 -1585
  299. data/vendor/gems/dslify/tasks/deployment.rake +0 -34
  300. data/vendor/gems/dslify/tasks/environment.rake +0 -7
  301. data/vendor/gems/dslify/tasks/website.rake +0 -17
  302. data/vendor/gems/dslify/test/test_dslify.rb +0 -114
  303. data/vendor/gems/dslify/website/index.html +0 -86
  304. data/vendor/gems/dslify/website/index.txt +0 -83
  305. data/vendor/gems/dslify/website/javascripts/rounded_corners_lite.inc.js +0 -285
  306. data/vendor/gems/dslify/website/stylesheets/screen.css +0 -138
  307. data/vendor/gems/dslify/website/template.html.erb +0 -48
  308. data/vendor/gems/parenting/History.txt +0 -4
  309. data/vendor/gems/parenting/Manifest.txt +0 -13
  310. data/vendor/gems/parenting/PostInstall.txt +0 -2
  311. data/vendor/gems/parenting/README.rdoc +0 -47
  312. data/vendor/gems/parenting/Rakefile +0 -28
  313. data/vendor/gems/parenting/lib/parenting/base.rb +0 -65
  314. data/vendor/gems/parenting/lib/parenting.rb +0 -10
  315. data/vendor/gems/parenting/parenting.gemspec +0 -39
  316. data/vendor/gems/parenting/script/console +0 -10
  317. data/vendor/gems/parenting/script/destroy +0 -14
  318. data/vendor/gems/parenting/script/generate +0 -14
  319. data/vendor/gems/parenting/test/file_to_eval.rb +0 -9
  320. data/vendor/gems/parenting/test/test_helper.rb +0 -5
  321. data/vendor/gems/parenting/test/test_parenting.rb +0 -89
  322. data/vendor/gems/suitcase/LICENSE +0 -20
  323. data/vendor/gems/suitcase/README.rdoc +0 -31
  324. data/vendor/gems/suitcase/Rakefile +0 -57
  325. data/vendor/gems/suitcase/VERSION.yml +0 -4
  326. data/vendor/gems/suitcase/lib/suitcase/unzipper.rb +0 -15
  327. data/vendor/gems/suitcase/lib/suitcase/zipper.rb +0 -119
  328. data/vendor/gems/suitcase/lib/suitcase.rb +0 -5
  329. data/vendor/gems/suitcase/suitcase.gemspec +0 -32
  330. data/vendor/gems/suitcase/test/suitcase_test.rb +0 -102
  331. data/vendor/gems/suitcase/test/test_dir/box.rb +0 -1
  332. data/vendor/gems/suitcase/test/test_dir/test.txt +0 -1
  333. data/vendor/gems/suitcase/test/test_helper.rb +0 -12
@@ -1,18 +1,14 @@
1
1
  module PoolParty
2
2
  class Base
3
- plugin :poolparty_base_haproxy do
3
+ plugin :haproxy do
4
+
5
+ def before_configure
6
+ end
4
7
 
5
8
  def enable
6
- # We need the haproxy package
7
- ::Suitcase::Zipper.add("#{::File.dirname(__FILE__)}/../../../vendor/chef/apache2", "chef/recipes")
9
+ # has_chef_recipe "apache2"
10
+ include_chef_recipe "#{::File.dirname(__FILE__)}/../../../vendor/chef/apache2"
8
11
 
9
- has_chef_recipe 'apache2'
10
- has_service "apache2"
11
-
12
- has_package({:name => "haproxy"}) do
13
- stops get_service("apache2")
14
- end
15
-
16
12
  # Restart sysklogd after we update the haproxy.log
17
13
  has_service(:name => "sysklogd")
18
14
  # Template variables
@@ -27,24 +23,36 @@ module PoolParty
27
23
  has_line_in_file(:line => "ENABLED=1", :file => "/etc/default/haproxy")
28
24
  has_line_in_file({:line => "SYSLOGD=\"-r\"", :file => "/etc/default/syslogd"})
29
25
  has_line_in_file({:line => "local0.* /var/log/haproxy.log", :file => "/etc/syslog.conf"}, {:notify => get_service("sysklogd")})
26
+ has_file '/var/log/haproxy.log' do
27
+ content ''
28
+ end
29
+
30
+ has_directory "/var/run/haproxy"
31
+ has_package "apache2"
32
+ has_service "apache2"
33
+
34
+ has_package "haproxy" do
35
+ stops get_service("apache2"), :immediately
36
+ # starts get_service("apache2")
37
+ end
30
38
 
31
39
  has_exec "reloadhaproxy",
32
40
  :command => "/etc/init.d/haproxy reload",
41
+ :ensures => "nothing",
33
42
  :requires => get_package("haproxy")
34
43
 
35
- # Service is required
36
- has_service("haproxy", :ensures => "running") do
37
- stops get_service("apache2"), :immediately
38
- starts get_service("apache2")
39
- end
40
-
41
- has_directory "/var/run/haproxy"
42
-
43
44
  has_file "/etc/haproxy/haproxy.cfg" do
44
45
  template "#{::File.dirname(__FILE__)}/../templates/haproxy.conf"
45
46
  calls get_exec("reloadhaproxy")
46
47
  end
47
48
 
49
+ # Service is required
50
+ has_service("haproxy") do
51
+ action [:start, :enable]
52
+ stops get_service("apache2"), :immediately
53
+ starts get_service("apache2")
54
+ end
55
+
48
56
  end
49
57
  end
50
58
  end
@@ -3,7 +3,7 @@ module PoolParty
3
3
  plugin :poolparty_base_packages do
4
4
 
5
5
  def enable
6
- has_package "git"
6
+ has_package "git-core"
7
7
 
8
8
  has_cron "/usr/bin/server-manage-election" do
9
9
  minute "0,5,10,15,20,25,30,35,40,45,50,55"
@@ -39,7 +39,7 @@ module PoolParty
39
39
  end
40
40
 
41
41
  def set_role_for_all_instances(role, name)
42
- ips = get_cloud(name).list_of_running_instances.map {|ri| ri.ip }
42
+ ips = get_cloud(name).nodes(:status => "running").map {|ri| ri.ip }
43
43
  ips.each {|ip| send :role, role.to_sym, "#{ip}"}
44
44
  end
45
45
  end
@@ -6,31 +6,43 @@ class Array
6
6
  def to_os
7
7
  map {|a| a.to_os }
8
8
  end
9
+
9
10
  def collect_with_index &block
10
11
  self.enum_for(:each_with_index).collect &block
11
12
  end
13
+
12
14
  def runnable(quiet=true)
13
15
  self.join(" \n ").runnable(quiet)
14
16
  end
17
+
15
18
  def nice_runnable(quiet=true)
16
19
  self.flatten.reject{|e| (e.nil? || e.empty?) }.join(" \n ").chomp.nice_runnable(quiet)
17
20
  end
21
+
18
22
  def to_string(pre="")
19
23
  map {|a| a.to_string(pre)}.join("\n")
20
24
  end
25
+
21
26
  def get_named(str="")
22
27
  map {|a| a.name == str ? a : nil }.reject {|a| a.nil? }
23
28
  end
29
+
24
30
  def respec_string(ns=[])
25
31
  "'#{map {|e| e.to_option_string }.join("', '")}'"
26
32
  end
27
33
  # Example nodes.select_with_hash(:status=>'running')
28
34
  def select_with_hash(conditions={})
35
+ return self if conditions.empty?
29
36
  select do |node|
30
37
  conditions.any? do |k,v|
31
38
  ( node.has_key?(k) && node[k]==v ) or ( node.respond_to?(k) && node.send(k)==v )
32
39
  end
33
40
  end
34
41
  end
42
+
43
+ def wrapping_next(id)
44
+ raise "Element #{id} not in array" unless index(id)
45
+ index(id) >= size-1 ? at(0) : at(index(id)+1)
46
+ end
35
47
 
36
48
  end
@@ -3,7 +3,7 @@
3
3
  =end
4
4
  class Hash
5
5
  def choose(&block)
6
- Hash[*self.select(&block).inject([]){|res,(k,v)| res << k << v}]
6
+ Hash[*self.select(&block).inject([]){|res,(k,v)| res << k << v}]
7
7
  end
8
8
 
9
9
  def to_instance_variables(inst=nil)
@@ -30,6 +30,7 @@ class Hash
30
30
  # o.keys.each {|k| self.delete(k) }
31
31
  # o
32
32
  # end
33
+
33
34
  def append(other_hash)
34
35
  returning Hash.new do |h|
35
36
  h.merge!(self)
@@ -38,23 +39,33 @@ class Hash
38
39
  end
39
40
  end
40
41
  end
42
+
41
43
  def append!(other_hash)
42
44
  other_hash.each do |k,v|
43
45
  self[k] = has_key?(k) ? [self[k], v].flatten.uniq : v
44
46
  end
45
47
  self
46
48
  end
49
+
47
50
  def safe_merge(other_hash)
48
51
  merge(other_hash.delete_if {|k,v| has_key?(k) })
49
52
  end
53
+
50
54
  def safe_merge!(other_hash)
51
55
  merge!(other_hash.delete_if {|k,v| has_key?(k) && !v.nil? })
52
56
  end
57
+
53
58
  def to_os
54
59
  m={}
55
60
  each {|k,v| m[k] = v.to_os }
56
61
  MyOpenStruct.new(m)
57
62
  end
63
+
64
+ def next_sorted_key(from)
65
+ idx = (size - keys.sort.index(from))
66
+ keys.sort[idx - 1]
67
+ end
68
+
58
69
  def method_missing(sym, *args, &block)
59
70
  if has_key?(sym)
60
71
  fetch(sym)
@@ -64,8 +75,4 @@ class Hash
64
75
  super
65
76
  end
66
77
  end
67
- def next_sorted_key(from)
68
- idx = (size - keys.sort.index(from))
69
- keys.sort[idx - 1]
70
- end
71
78
  end
@@ -0,0 +1,8 @@
1
+ # Class: NilClas
2
+ #
3
+ #
4
+ class NilClass
5
+ def empty?
6
+ true
7
+ end
8
+ end
@@ -72,19 +72,29 @@ class Object
72
72
  # meta_undef name rescue ""
73
73
  # end
74
74
  def vputs(m="", o=self)
75
- puts m if o.verbose rescue ""
75
+ # puts m if o.verbose rescue ""
76
+ puts "[INFO] -- #{m}" if verbose?
76
77
  end
77
78
  def vprint(m="", o=self)
78
79
  print m if o.verbose rescue ""
79
80
  end
80
81
  def dputs(m="", o=self)
81
- puts "-- #{m}" if $DEBUGGING rescue ""
82
+ puts "[DEBUG] -- #{m.inspect}" if debugging?(o) rescue ""
82
83
  end
83
- def debugging(bool=false)
84
- $DEBUGGING = bool
84
+ def dprint(m="", o=self)
85
+ print "#{m}" if debugging?(o) || verbose?(o) rescue ""
86
+ end
87
+ def verbose?(o=self)
88
+ o.respond_to?(:verbose) ? o.verbose : ($TESTING ||= false)
89
+ end
90
+ def debugging?(o=self)
91
+ o.respond_to?(:debug) ? o.debug : ($DEBUGGING ||= false)
92
+ end
93
+ def debugging(bool=nil)
94
+ bool.nil? ? $DEBUGGING : $DEBUGGING = bool
85
95
  end
86
96
  def testing(bool=$TESTING)
87
- bool.nil? ? false : bool
97
+ bool.nil? ? $TESTING : $TESTING = bool
88
98
  end
89
99
  alias :debug :debugging
90
100
  def unix_hide_string
@@ -119,10 +119,10 @@ class String
119
119
  # Examples
120
120
  # "Module".constantize #=> Module
121
121
  # "Class".constantize #=> Class
122
- def constantize
122
+ def constantize(mod=Object)
123
123
  camelcased_word = camelcase
124
124
  begin
125
- Object.module_eval(camelcased_word, __FILE__, __LINE__)
125
+ mod.module_eval(camelcased_word, __FILE__, __LINE__)
126
126
  rescue NameError
127
127
  puts "#{camelcased_word} is not defined."
128
128
  nil
@@ -151,4 +151,30 @@ class String
151
151
  arr << self.split(/\n/).collect_with_index(&block)
152
152
  end.flatten
153
153
  end
154
+
155
+ # Read a new-line separated string and turn
156
+ # the string from the form
157
+ # a = "b"
158
+ # b = "c"
159
+ # into a hash
160
+ # {:a => "b", :b => "c"}
161
+ def to_hash
162
+ split("\n").inject({}) do |sum,line|
163
+ if line.include?("=")
164
+ l = line.split("=").map {|a| a.strip }
165
+ key = l[0].to_sym
166
+ value = l[1].gsub(/\"/, '')
167
+ sum.merge(key => value)
168
+ else
169
+ sum
170
+ end
171
+ end
172
+ end
173
+
174
+ # Take a mac address and split it to map to the arp -a response
175
+ # Just rip off the first 0 if the first char is 0
176
+ def macify
177
+ split(":").map {|a| a[0].chr == "0" ? a[1].chr : a}.join(":")
178
+ end
179
+
154
180
  end
@@ -1,35 +1,71 @@
1
+ =begin rdoc
2
+ ChefResolver
3
+
4
+ This takes the internal structure
5
+ {
6
+ :options => {},
7
+ :services => [{}],
8
+ :resources => []
9
+ }
10
+
11
+ and creates a chef recipe to reflect.
12
+
13
+ /cookbooks/
14
+ namespace/
15
+ recipes/
16
+ templates/
17
+ attributes/
18
+
19
+ TODO: This class is somewhat all over the place. Slim it down
20
+ =end
1
21
  module PoolParty
2
22
 
3
23
  class ChefResolver< DependencyResolver
4
24
 
25
+ # Compile and add to the zipper
5
26
  def compile(props=@properties_hash, tabs=0, default_namespace="poolparty")
27
+ base_dir(default_namespace)
28
+ build_base_recipe_directory( default_namespace )
29
+
30
+ # ::Suitcase::Zipper.add( base_dir, "chef/cookbooks")
31
+
32
+ _compile(props, tabs, default_namespace)
33
+ end
34
+
35
+ def _compile(props=@properties_hash, tabs=0, default_namespace="poolparty")
6
36
  cld_name = default_namespace
7
37
  comp(cld_name, props, tabs)
8
38
  end
9
39
 
10
40
  def comp(cld_name, props, tabs)
11
- base_dir cld_name
12
- basedir = build_base_recipe_directory( cld_name )
13
- # handle_print_variables(props[:options]) if props && props.has_key?(:options)
14
41
 
15
42
  default_recipe = [
16
43
  resources_to_string(props[:resources],tabs),
17
44
  services_to_string(props[:services],tabs)
18
45
  ].join("\n")
19
- ::File.open("#{basedir}/recipes/default.rb", "w+") {|f| f << default_recipe }
20
- ::Suitcase::Zipper.add(basedir, "chef/recipes/cookbooks")
46
+
47
+ ::File.open("#{base_dir}/recipes/default.rb", "w+") {|f| f << default_recipe }
48
+
21
49
  default_recipe
22
50
  end
23
51
 
24
52
  def build_base_recipe_directory(nm)
53
+ dputs "Making new #{base_dir}"
54
+ ::FileUtils.mkdir_p "#{base_dir}"
55
+
25
56
  [ "recipes", "templates", "attributes" ].each do |bdir|
26
- ::FileUtils.mkdir_p "#{base_dir}/#{bdir}" unless ::File.directory? "#{base_dir}/#{bdir}"
57
+ ::FileUtils.mkdir_p "#{base_dir}/#{bdir}" #unless ::File.directory? "#{base_dir}/#{bdir}"
58
+ end
59
+
60
+ ::File.open("#{base_dir}/attributes/poolparty.rb", "w") do |f|
61
+ f << "poolparty Mash.new unless attribute?('poolparty')\n"
27
62
  end
63
+
28
64
  base_dir
29
65
  end
30
66
 
31
- def base_dir(nm=nil)
32
- @base_dir ||= "#{Default.tmp_path}/dr_configure/chef/recipes/#{nm}"
67
+ def base_dir(nm="poolparty")
68
+ @base_dir ||= "#{Default.tmp_path}/dr_configure/chef/cookbooks/#{nm}"
33
69
  end
34
70
 
35
71
  def options_to_string(opts,tabs=0)
@@ -37,63 +73,42 @@ module PoolParty
37
73
  end
38
74
 
39
75
  def resources_to_string(opts,tabs=0)
40
- out = []
41
- if opts
42
-
43
- if opts[:variable] && !opts[:variable].empty?
44
- vars = opts.delete(:variable)
45
- handle_print_variables(vars)
46
- end
47
-
48
- if opts[:chef_recipe]
49
- opts.delete(:chef_recipe).each do |rcp|
50
- out << "include_recipe #{to_option_string(rcp.name)}"
51
- end
52
- end
53
-
54
- if opts.has_key?(:line_in_file)
55
- lines = opts.delete(:line_in_file).inject([]) do |sum, l|
56
- sum << PoolParty::Resources::Exec.new(:name => l[:name], :command => PoolParty::Resources::LineInFile.command(l[:line], l[:file]) ).to_properties_hash
57
- end
58
- if lines && lines.size > 0
59
- opts.has_key?(:exec) ? (opts[:exec] << lines) : opts.merge!(:exec => lines)
60
- end
61
- end
62
-
63
- out << opts.map do |type, arr|
64
- arr.map do |res|
65
- real_type = handle_types(type)
66
- real_name = handle_names(type, res)
67
- res = before_filter_check_on_hash(res, real_name)
68
- "#{tf(tabs)}#{real_type} \"#{real_name}\" do\n#{tf(tabs+1)}#{hash_flush_out(res).compact.join("\n#{tf(tabs+1)}")}\n#{tf(tabs)}end"
69
- end
76
+ out = []
77
+ out << opts.map do |resource|
78
+ case ty = resource.delete(:pp_type)
79
+ when "variable"
80
+ handle_print_variable(resource)
81
+ when "chef_recipe"
82
+ "#{tf(tabs)}include_recipe #{to_option_string(resource.name)}"
83
+ when "chef_library"
84
+ "#{tf(tabs)}require #{to_option_string("/etc/chef/lib/#{resource.name}")}"
85
+ else
86
+ real_type = handle_chef_types(ty)
87
+ real_name = resource[:name]
88
+ res = before_filter_check_on_hash(resource, real_name)
89
+ "#{tf(tabs)}#{real_type} \"#{real_name}\" do\n#{tf(tabs+1)}#{hash_flush_out(res).compact.join("\n#{tf(tabs+1)}")}\n#{tf(tabs)}end"
70
90
  end
71
- end
91
+ end
72
92
  out.join("\n")
73
93
  end
74
94
 
75
- def handle_print_variables(vars)
76
-
77
- out = ["\npoolparty Mash.new unless attribute?('poolparty')\n\n"]
78
- vars.each do |varhash|
79
- out << "#{varhash[:namespace] || "poolparty"}[:#{varhash[:name]}] = #{to_option_string(varhash[:value])}"
80
- end
81
- ::File.open("#{base_dir}/attributes/poolparty.rb", "w+") do |f|
82
- f << out.join("\n")
83
- end
84
- end
85
-
86
- def handle_chef_vars(nm, varname)
87
- case varname
88
- when :enable
89
- "action"
95
+ def handle_print_variable(varhash)
96
+ o = []
97
+ if varhash[:namespace]
98
+ o << ["\n#{varhash[:namespace]} Mash.new unless attribute?('#{varhash[:namespace]}')"]
99
+ o << "#{varhash[:namespace]}[:#{varhash[:name]}] = #{to_option_string(varhash[:value])}\n"
90
100
  else
91
- "#{nm}[:#{varname}]"
101
+ o << "poolparty[:#{varhash[:name]}] = #{to_option_string(varhash[:value])}"
92
102
  end
103
+ ::File.open("#{base_dir}/attributes/poolparty.rb", "a+") do |f|
104
+ f << o.join("\n")
105
+ f << "\n"
106
+ end
107
+ ""
93
108
  end
94
-
95
- def handle_types(ty)
96
- case ty
109
+
110
+ def handle_chef_types(ty)
111
+ case ty.to_sym
97
112
  when :exec
98
113
  "execute"
99
114
  when :file
@@ -102,27 +117,23 @@ module PoolParty
102
117
  "link"
103
118
  when :line_in_file
104
119
  "execute"
120
+ when :chef_deploy_definition
121
+ "deploy"
105
122
  else
106
123
  ty
107
124
  end
108
125
  end
109
-
110
- def handle_names(ty, res)
111
- case ty
112
- when :exec
113
- res.name
114
- else
115
- res.name
116
- end
117
- end
118
-
119
- # TODO: This is brittle, need to find a way to make them reactive, rather than
120
- # separate (the key/value pairs)
121
- def hash_flush_out(hash, pre="", post="")
126
+
127
+ # flush out the hash into something meaningful
128
+ def hash_flush_out(hash, pre="", post="")
122
129
  hash.map do |k,v|
123
- key = to_chef_key(k)
124
- res = to_option_string(v)
125
- (key.nil? || res.nil?) ? nil : "#{pre}#{key} #{res}#{post}"
130
+ if o = handle_actions(k,v)
131
+ o
132
+ else
133
+ key = to_chef_key(k)
134
+ res = to_option_string(v)
135
+ (key.nil? || res.nil?) ? nil : "#{pre}#{key} #{res}#{post}"
136
+ end
126
137
  end
127
138
  end
128
139
 
@@ -133,9 +144,9 @@ module PoolParty
133
144
  else
134
145
  kname = klassname.to_s.gsub(/pool_party_/, '').gsub(/_class/, '')
135
146
  str = "\n#{tf(tabs)}# #{kname}\n"
136
- str << "#{tf(tabs+1)}"
147
+ str << "#{tf(tabs)}"
137
148
  klassarray.each do |hsh|
138
- str << compile(hsh,tabs+1, klassname)
149
+ str << _compile(hsh,tabs+1, klassname)
139
150
  end
140
151
  str << "#{tf(tabs)}"
141
152
  end
@@ -147,12 +158,15 @@ module PoolParty
147
158
  if hsh.has_key?(:content)
148
159
  cont = hsh.delete(:content)
149
160
  temp_file = "#{base_dir}/templates/default/#{nm}.erb"
161
+
150
162
  ::FileUtils.mkdir_p(::File.dirname(temp_file)) unless ::File.directory? temp_file
151
163
  ::File.open(temp_file, "w+") {|f| f.print cont }
164
+
152
165
  hsh.merge!({:source => "#{nm}.erb"})
153
166
  end
154
167
  #
155
168
  hsh.delete(:require) if hsh.has_key?(:require)
169
+ hsh.delete(:name) # we don't need the names in the methods
156
170
  hsh
157
171
  end
158
172
 
@@ -171,6 +185,16 @@ module PoolParty
171
185
  end
172
186
  end
173
187
 
188
+ # Handle ensures
189
+ def handle_actions(key,value)
190
+ case key
191
+ when :ensures
192
+ value.nil? ? nil : "action :#{value}"
193
+ else
194
+ nil
195
+ end
196
+ end
197
+
174
198
  # Take the keys from the resource hash and turn them into chef-like
175
199
  # meaningful keys. This is how helpers are created for chef
176
200
  def to_chef_key(key)
@@ -189,9 +213,9 @@ module PoolParty
189
213
  nil
190
214
  when :if_not
191
215
  "not_if"
192
- when :notif
216
+ when :not_if
193
217
  "not_if"
194
- when :onlyif
218
+ when :only_if
195
219
  "only_if"
196
220
  else
197
221
  "#{key}"
@@ -203,12 +227,13 @@ module PoolParty
203
227
  def to_option_string(obj)
204
228
  case obj
205
229
  when PoolParty::Resources::Resource
206
- "resources(:#{handle_types(obj.class.to_s.top_level_class.downcase.to_sym)} => \"#{obj.name}\")"
230
+ "resources(:#{handle_chef_types(obj.class.to_s.top_level_class.downcase.to_sym)} => \"#{obj.name}\")"
207
231
  when Fixnum
208
232
  "#{obj.to_i}"
209
233
  when String
210
234
  "\"#{obj}\""
211
235
  when Array
236
+ # If we are sending a notifies with a second argument
212
237
  if obj[1] && [:immediately, :delayed].include?(obj[1])
213
238
  "#{to_option_string(obj[0])}, :#{obj[1]}"
214
239
  else
@@ -216,6 +241,8 @@ module PoolParty
216
241
  end
217
242
  when nil
218
243
  nil
244
+ when Symbol
245
+ ":#{obj}"
219
246
  when Hash
220
247
  "#{obj.map {|k,v| ":#{k} => #{to_option_string(v)}" unless v == obj }.compact.join(",\n")}"
221
248
  else
@@ -11,7 +11,7 @@ module PoolParty
11
11
  attr_reader :properties_hash, :the_cloud
12
12
 
13
13
  def initialize(hsh, contxt=nil)
14
- raise DependencyResolverException.new('must pass a hash') if hsh.nil? || (!hsh.instance_of?(OrderedHash) && !hsh.instance_of?(Hash))
14
+ raise DependencyResolverException.new('must pass a hash') if hsh.nil? || !(hsh.instance_of?(OrderedHash) || hsh.instance_of?(Hash))
15
15
  @properties_hash = hsh
16
16
  @the_cloud = contxt
17
17
  end
@@ -8,9 +8,10 @@ module PoolParty
8
8
  def to_properties_hash
9
9
  oh = OrderedHash.new
10
10
  oh[:options] = options.merge(:cloud_name => name)
11
- oh[:resources] = resources.keys.inject(OrderedHash.new) do |sum,k|
12
- sum.merge(k.to_sym => resources[k].map {|a| a.to_properties_hash } )
13
- end
11
+ oh[:resources] = ordered_resources.map {|a| a.to_properties_hash }
12
+ # oh[:resources] = resources.keys.inject(OrderedHash.new) do |sum,k|
13
+ # sum.merge(k.to_sym => resources[k].map {|a| a.to_properties_hash } )
14
+ # end
14
15
  oh[:services] = services.keys.inject(OrderedHash.new) do |sum,k|
15
16
  sum.merge(k.to_sym => services[k].map {|a| a.to_properties_hash } )
16
17
  end
@@ -22,7 +23,7 @@ module PoolParty
22
23
  # Adds the to_properties_hash method on top of resources, the lowest level
23
24
  module DependencyResolverResourceExtensions
24
25
  def to_properties_hash
25
- options
26
+ {:pp_type => self.class.to_s.top_level_class}.merge!(options)
26
27
  end
27
28
  end
28
29
  end