poolparty 0.2.18 → 0.2.69

Sign up to get free protection for your applications and to get access to all the features.
Files changed (335) hide show
  1. data/Manifest.txt +142 -47
  2. data/PostInstall.txt +5 -5
  3. data/README.txt +25 -4
  4. data/Rakefile +46 -2
  5. data/bin/cloud +12 -21
  6. data/bin/cloud-add-keypair +18 -13
  7. data/bin/cloud-configure +11 -18
  8. data/bin/cloud-contract +7 -17
  9. data/bin/cloud-ensure-provisioning +39 -0
  10. data/bin/cloud-expand +9 -17
  11. data/bin/cloud-handle-load +27 -0
  12. data/bin/cloud-list +3 -9
  13. data/bin/cloud-maintain +12 -18
  14. data/bin/cloud-osxcopy +3 -9
  15. data/bin/cloud-provision +20 -21
  16. data/bin/cloud-refresh +4 -13
  17. data/bin/cloud-run +3 -4
  18. data/bin/cloud-ssh +3 -2
  19. data/bin/cloud-start +18 -21
  20. data/bin/cloud-stats +17 -0
  21. data/bin/cloud-terminate +4 -7
  22. data/bin/messenger-get-current-nodes +14 -0
  23. data/bin/pool +12 -12
  24. data/bin/pool-describe +0 -1
  25. data/bin/{pool-spec → pool-generate} +1 -0
  26. data/bin/pool-init +28 -0
  27. data/bin/pool-list +14 -12
  28. data/bin/pool-start +11 -17
  29. data/bin/server-build-messenger +13 -6
  30. data/bin/server-fire-cmd +1 -1
  31. data/bin/server-get-load +5 -16
  32. data/bin/server-list-active +3 -10
  33. data/bin/server-rerun +4 -4
  34. data/bin/server-send-command +18 -0
  35. data/bin/server-show-stats +17 -0
  36. data/bin/server-start-client +29 -0
  37. data/bin/server-start-master +13 -14
  38. data/bin/server-start-node +14 -15
  39. data/bin/server-stop-client +3 -0
  40. data/bin/server-stop-master +3 -0
  41. data/bin/server-stop-node +3 -0
  42. data/bin/server-update-hosts +48 -0
  43. data/config/hoe.rb +4 -3
  44. data/examples/plugin_without_plugin_directory.rb +1 -2
  45. data/generators/poolspec/USAGE +2 -2
  46. data/generators/poolspec/poolspec_generator.rb +2 -1
  47. data/generators/poolspec/templates/pool_spec_template.erb +3 -2
  48. data/lib/erlang/messenger/Rakefile +12 -0
  49. data/lib/erlang/messenger/ebin/client.app +19 -0
  50. data/lib/erlang/messenger/ebin/master.app +1 -1
  51. data/lib/erlang/messenger/ebin/node.app +1 -1
  52. data/lib/erlang/messenger/ebin/pm_client_rel-0.1.rel +1 -0
  53. data/lib/erlang/messenger/ebin/pm_master_rel-0.1.rel +1 -1
  54. data/lib/erlang/messenger/ebin/pm_node_rel-0.1.rel +1 -1
  55. data/lib/erlang/messenger/include/defines.hrl +27 -0
  56. data/lib/erlang/messenger/lib/eunit/.svn/all-wcprops +53 -0
  57. data/lib/erlang/messenger/lib/eunit/.svn/entries +140 -0
  58. data/lib/erlang/messenger/lib/eunit/.svn/format +1 -0
  59. data/lib/erlang/messenger/lib/eunit/.svn/prop-base/NOTES.svn-base +5 -0
  60. data/lib/erlang/messenger/lib/eunit/.svn/text-base/AUTHORS.svn-base +2 -0
  61. data/lib/erlang/messenger/lib/eunit/.svn/text-base/CHANGELOG.svn-base +14 -0
  62. data/lib/erlang/messenger/lib/eunit/.svn/text-base/COPYING.svn-base +504 -0
  63. data/lib/erlang/messenger/lib/eunit/.svn/text-base/NOTES.svn-base +276 -0
  64. data/lib/erlang/messenger/lib/eunit/.svn/text-base/README.svn-base +3 -0
  65. data/lib/erlang/messenger/lib/eunit/.svn/text-base/sys.config.svn-base +9 -0
  66. data/lib/erlang/messenger/lib/eunit/.svn/text-base/vsn.mk.svn-base +1 -0
  67. data/lib/erlang/messenger/lib/eunit/doc/.svn/all-wcprops +59 -0
  68. data/lib/erlang/messenger/lib/eunit/doc/.svn/entries +142 -0
  69. data/lib/erlang/messenger/lib/eunit/doc/.svn/format +1 -0
  70. data/lib/erlang/messenger/lib/eunit/doc/.svn/prop-base/erlang.png.svn-base +5 -0
  71. data/lib/erlang/messenger/lib/eunit/doc/.svn/prop-base/eunit.html.svn-base +5 -0
  72. data/lib/erlang/messenger/lib/eunit/doc/.svn/prop-base/index.html.svn-base +5 -0
  73. data/lib/erlang/messenger/lib/eunit/doc/.svn/prop-base/modules-frame.html.svn-base +5 -0
  74. data/lib/erlang/messenger/lib/eunit/doc/.svn/prop-base/overview-summary.html.svn-base +5 -0
  75. data/lib/erlang/messenger/lib/eunit/doc/.svn/prop-base/packages-frame.html.svn-base +5 -0
  76. data/lib/erlang/messenger/lib/eunit/doc/.svn/text-base/edoc-info.svn-base +3 -0
  77. data/lib/erlang/messenger/lib/eunit/doc/.svn/text-base/erlang.png.svn-base +0 -0
  78. data/lib/erlang/messenger/lib/eunit/doc/.svn/text-base/eunit.html.svn-base +172 -0
  79. data/lib/erlang/messenger/lib/eunit/doc/.svn/text-base/index.html.svn-base +17 -0
  80. data/lib/erlang/messenger/lib/eunit/doc/.svn/text-base/modules-frame.html.svn-base +12 -0
  81. data/lib/erlang/messenger/lib/eunit/doc/.svn/text-base/overview-summary.html.svn-base +984 -0
  82. data/lib/erlang/messenger/lib/eunit/doc/.svn/text-base/overview.edoc.svn-base +980 -0
  83. data/lib/erlang/messenger/lib/eunit/doc/.svn/text-base/packages-frame.html.svn-base +11 -0
  84. data/lib/erlang/messenger/lib/eunit/doc/.svn/text-base/stylesheet.css.svn-base +55 -0
  85. data/lib/erlang/messenger/lib/eunit/ebin/.svn/all-wcprops +5 -0
  86. data/lib/erlang/messenger/lib/eunit/ebin/.svn/dir-prop-base +8 -0
  87. data/lib/erlang/messenger/lib/eunit/ebin/.svn/entries +28 -0
  88. data/lib/erlang/messenger/lib/eunit/ebin/.svn/format +1 -0
  89. data/lib/erlang/messenger/lib/eunit/examples/.svn/all-wcprops +23 -0
  90. data/lib/erlang/messenger/lib/eunit/examples/.svn/entries +66 -0
  91. data/lib/erlang/messenger/lib/eunit/examples/.svn/format +1 -0
  92. data/lib/erlang/messenger/lib/eunit/examples/.svn/prop-base/eunit_examples.erl.svn-base +5 -0
  93. data/lib/erlang/messenger/lib/eunit/examples/.svn/prop-base/fib.erl.svn-base +5 -0
  94. data/lib/erlang/messenger/lib/eunit/examples/.svn/text-base/eunit_examples.erl.svn-base +339 -0
  95. data/lib/erlang/messenger/lib/eunit/examples/.svn/text-base/fib.erl.svn-base +19 -0
  96. data/lib/erlang/messenger/lib/eunit/examples/.svn/text-base/tests.txt.svn-base +1 -0
  97. data/lib/erlang/messenger/lib/eunit/include/.svn/all-wcprops +11 -0
  98. data/lib/erlang/messenger/lib/eunit/include/.svn/entries +41 -0
  99. data/lib/erlang/messenger/lib/eunit/include/.svn/format +1 -0
  100. data/lib/erlang/messenger/lib/eunit/include/.svn/prop-base/eunit.hrl.svn-base +5 -0
  101. data/lib/erlang/messenger/lib/eunit/include/.svn/text-base/eunit.hrl.svn-base +313 -0
  102. data/lib/erlang/messenger/lib/eunit/src/.svn/all-wcprops +113 -0
  103. data/lib/erlang/messenger/lib/eunit/src/.svn/entries +259 -0
  104. data/lib/erlang/messenger/lib/eunit/src/.svn/format +1 -0
  105. data/lib/erlang/messenger/lib/eunit/src/.svn/prop-base/autoload.erl.svn-base +5 -0
  106. data/lib/erlang/messenger/lib/eunit/src/.svn/prop-base/code_monitor.erl.svn-base +5 -0
  107. data/lib/erlang/messenger/lib/eunit/src/.svn/prop-base/eunit.erl.svn-base +5 -0
  108. data/lib/erlang/messenger/lib/eunit/src/.svn/prop-base/eunit_autoexport.erl.svn-base +5 -0
  109. data/lib/erlang/messenger/lib/eunit/src/.svn/prop-base/eunit_data.erl.svn-base +5 -0
  110. data/lib/erlang/messenger/lib/eunit/src/.svn/prop-base/eunit_internal.hrl.svn-base +5 -0
  111. data/lib/erlang/messenger/lib/eunit/src/.svn/prop-base/eunit_lib.erl.svn-base +5 -0
  112. data/lib/erlang/messenger/lib/eunit/src/.svn/prop-base/eunit_proc.erl.svn-base +5 -0
  113. data/lib/erlang/messenger/lib/eunit/src/.svn/prop-base/eunit_serial.erl.svn-base +5 -0
  114. data/lib/erlang/messenger/lib/eunit/src/.svn/prop-base/eunit_server.erl.svn-base +5 -0
  115. data/lib/erlang/messenger/lib/eunit/src/.svn/prop-base/eunit_striptests.erl.svn-base +5 -0
  116. data/lib/erlang/messenger/lib/eunit/src/.svn/prop-base/eunit_test.erl.svn-base +5 -0
  117. data/lib/erlang/messenger/lib/eunit/src/.svn/prop-base/eunit_tests.erl.svn-base +5 -0
  118. data/lib/erlang/messenger/lib/eunit/src/.svn/prop-base/eunit_tty.erl.svn-base +5 -0
  119. data/lib/erlang/messenger/lib/eunit/src/.svn/prop-base/file_monitor.erl.svn-base +5 -0
  120. data/lib/erlang/messenger/lib/eunit/src/.svn/text-base/autoload.erl.svn-base +388 -0
  121. data/lib/erlang/messenger/lib/eunit/src/.svn/text-base/code_monitor.erl.svn-base +243 -0
  122. data/lib/erlang/messenger/lib/eunit/src/.svn/text-base/eunit.app.src.svn-base +21 -0
  123. data/lib/erlang/messenger/lib/eunit/src/.svn/text-base/eunit.appup.src.svn-base +1 -0
  124. data/lib/erlang/messenger/lib/eunit/src/.svn/text-base/eunit.erl.svn-base +196 -0
  125. data/lib/erlang/messenger/lib/eunit/src/.svn/text-base/eunit_autoexport.erl.svn-base +102 -0
  126. data/lib/erlang/messenger/lib/eunit/src/.svn/text-base/eunit_data.erl.svn-base +798 -0
  127. data/lib/erlang/messenger/lib/eunit/src/.svn/text-base/eunit_internal.hrl.svn-base +48 -0
  128. data/lib/erlang/messenger/lib/eunit/src/.svn/text-base/eunit_lib.erl.svn-base +682 -0
  129. data/lib/erlang/messenger/lib/eunit/src/.svn/text-base/eunit_proc.erl.svn-base +552 -0
  130. data/lib/erlang/messenger/lib/eunit/src/.svn/text-base/eunit_serial.erl.svn-base +157 -0
  131. data/lib/erlang/messenger/lib/eunit/src/.svn/text-base/eunit_server.erl.svn-base +340 -0
  132. data/lib/erlang/messenger/lib/eunit/src/.svn/text-base/eunit_striptests.erl.svn-base +64 -0
  133. data/lib/erlang/messenger/lib/eunit/src/.svn/text-base/eunit_test.erl.svn-base +334 -0
  134. data/lib/erlang/messenger/lib/eunit/src/.svn/text-base/eunit_tests.erl.svn-base +45 -0
  135. data/lib/erlang/messenger/lib/eunit/src/.svn/text-base/eunit_tty.erl.svn-base +272 -0
  136. data/lib/erlang/messenger/lib/eunit/src/.svn/text-base/file_monitor.erl.svn-base +409 -0
  137. data/lib/erlang/messenger/pm_client_rel-0.1.boot +0 -0
  138. data/lib/erlang/messenger/pm_client_rel-0.1.script +238 -0
  139. data/lib/erlang/messenger/pm_master_rel-0.1.boot +0 -0
  140. data/lib/erlang/messenger/pm_master_rel-0.1.script +82 -85
  141. data/lib/erlang/messenger/pm_node_rel-0.1.boot +0 -0
  142. data/lib/erlang/messenger/pm_node_rel-0.1.script +80 -85
  143. data/lib/erlang/messenger/src/client_app.erl +39 -0
  144. data/lib/erlang/messenger/src/client_server.erl +60 -0
  145. data/lib/erlang/messenger/src/pm_client.erl +48 -18
  146. data/lib/erlang/messenger/src/pm_client_old.erl +52 -0
  147. data/lib/erlang/messenger/src/pm_client_supervisor.erl +38 -0
  148. data/lib/erlang/messenger/src/pm_cluster.erl +20 -16
  149. data/lib/erlang/messenger/src/pm_event_manager.erl +27 -0
  150. data/lib/erlang/messenger/src/pm_master.erl +126 -34
  151. data/lib/erlang/messenger/src/pm_master_event_handler.erl +72 -0
  152. data/lib/erlang/messenger/src/pm_master_supervisor.erl +9 -10
  153. data/lib/erlang/messenger/src/pm_node.erl +107 -30
  154. data/lib/erlang/messenger/src/pm_node_supervisor.erl +13 -15
  155. data/lib/erlang/messenger/src/pm_packager.erl +5 -2
  156. data/lib/erlang/messenger/src/pm_strings.erl +11 -0
  157. data/lib/erlang/messenger/src/utils.erl +43 -8
  158. data/lib/erlang/messenger/useful_snippets +17 -0
  159. data/lib/poolparty/aska/aska.rb +150 -0
  160. data/lib/poolparty/base_packages/haproxy.rb +19 -26
  161. data/lib/poolparty/base_packages/heartbeat.rb +48 -47
  162. data/lib/poolparty/base_packages/poolparty.rb +88 -36
  163. data/lib/poolparty/base_packages/runit.rb +21 -0
  164. data/lib/poolparty/config/postlaunchmessage.txt +5 -0
  165. data/lib/poolparty/core/array.rb +4 -1
  166. data/lib/poolparty/core/class.rb +2 -0
  167. data/lib/poolparty/core/exception.rb +2 -1
  168. data/lib/poolparty/core/hash.rb +2 -2
  169. data/lib/poolparty/core/kernel.rb +3 -3
  170. data/lib/poolparty/core/metaid.rb +15 -0
  171. data/lib/poolparty/core/object.rb +42 -2
  172. data/lib/poolparty/core/string.rb +21 -6
  173. data/lib/poolparty/core/symbol.rb +9 -0
  174. data/lib/poolparty/dependency_resolutions/puppet.rb +20 -7
  175. data/lib/poolparty/exceptions/CloudNotFoundException.rb +7 -0
  176. data/lib/poolparty/exceptions/LoadRulesException.rb +7 -0
  177. data/lib/poolparty/exceptions/MasterException.rb +10 -0
  178. data/lib/poolparty/helpers/binary.rb +37 -4
  179. data/lib/poolparty/helpers/console.rb +25 -8
  180. data/lib/poolparty/helpers/nice_printer.rb +36 -0
  181. data/lib/poolparty/helpers/optioner.rb +51 -16
  182. data/lib/poolparty/helpers/provisioner_base.rb +117 -28
  183. data/lib/poolparty/helpers/provisioners/master.rb +102 -35
  184. data/lib/poolparty/helpers/provisioners/slave.rb +25 -9
  185. data/lib/poolparty/modules/cloud_dsl.rb +13 -0
  186. data/lib/poolparty/modules/cloud_resourcer.rb +51 -8
  187. data/lib/poolparty/modules/configurable.rb +1 -1
  188. data/lib/poolparty/modules/definable_resource.rb +2 -2
  189. data/lib/poolparty/modules/file_writer.rb +37 -6
  190. data/lib/poolparty/modules/method_missing_sugar.rb +8 -3
  191. data/lib/poolparty/modules/pretty_printer.rb +1 -0
  192. data/lib/poolparty/modules/resourcing_dsl.rb +4 -2
  193. data/lib/poolparty/modules/thread_pool.rb +106 -0
  194. data/lib/poolparty/monitors/base_monitor.rb +65 -6
  195. data/lib/poolparty/monitors/monitors/cpu_monitor.rb +1 -1
  196. data/lib/poolparty/monitors/monitors/memory_monitor.rb +28 -1
  197. data/lib/poolparty/monitors/monitors/web_monitor.rb +18 -0
  198. data/lib/poolparty/net/messenger.rb +72 -0
  199. data/lib/poolparty/net/remote.rb +5 -2
  200. data/lib/poolparty/net/remote_bases/ec2/ec2_response_object.rb +66 -0
  201. data/lib/poolparty/net/remote_bases/ec2.rb +133 -131
  202. data/lib/poolparty/net/remote_instance.rb +28 -6
  203. data/lib/poolparty/net/remoter.rb +117 -64
  204. data/lib/poolparty/net/remoter_base.rb +49 -11
  205. data/lib/poolparty/plugins/deploydirectory.rb +66 -0
  206. data/lib/poolparty/plugins/line.rb +5 -4
  207. data/lib/poolparty/plugins/rsyncmirror.rb +26 -0
  208. data/lib/poolparty/plugins/runit.rb +96 -0
  209. data/lib/poolparty/plugins/svn.rb +1 -1
  210. data/lib/poolparty/pool/base.rb +47 -18
  211. data/lib/poolparty/pool/cloud.rb +121 -65
  212. data/lib/poolparty/pool/custom_resource.rb +4 -20
  213. data/lib/poolparty/pool/loggable.rb +3 -8
  214. data/lib/poolparty/pool/plugin.rb +14 -19
  215. data/lib/poolparty/pool/plugin_model.rb +8 -8
  216. data/lib/poolparty/pool/pool.rb +28 -11
  217. data/lib/poolparty/pool/resource.rb +109 -40
  218. data/lib/poolparty/pool/resources/class_package.rb +74 -33
  219. data/lib/poolparty/pool/resources/conditional.rb +32 -10
  220. data/lib/poolparty/pool/resources/custom_service.rb +30 -0
  221. data/lib/poolparty/pool/resources/exec.rb +6 -5
  222. data/lib/poolparty/pool/resources/gem_package.rb +52 -0
  223. data/lib/poolparty/pool/resources/mount.rb +22 -0
  224. data/lib/poolparty/pool/resources/package.rb +13 -3
  225. data/lib/poolparty/pool/resources/sshkey.rb +1 -1
  226. data/lib/poolparty/pool/resources/variable.rb +4 -0
  227. data/lib/poolparty/pool/script.rb +8 -6
  228. data/lib/poolparty/templates/haproxy.conf +1 -1
  229. data/lib/poolparty/templates/messenger/client/log-run.erb +2 -0
  230. data/lib/poolparty/templates/messenger/client/run.erb +4 -0
  231. data/lib/poolparty/templates/messenger/master/log-run.erb +2 -0
  232. data/lib/poolparty/templates/messenger/master/run.erb +4 -0
  233. data/lib/poolparty/templates/messenger/node/log-run.erb +2 -0
  234. data/lib/poolparty/templates/messenger/node/run.erb +4 -0
  235. data/lib/poolparty/templates/poolparty.monitor +1 -1
  236. data/lib/poolparty/templates/puppet.conf +0 -0
  237. data/lib/poolparty/templates/puppetcleaner +6 -0
  238. data/lib/poolparty/templates/puppetrerun +9 -0
  239. data/lib/poolparty/templates/puppetrunner +8 -0
  240. data/lib/poolparty/templates/yaws.conf +19 -0
  241. data/lib/poolparty/version.rb +1 -1
  242. data/lib/poolparty.rb +35 -6
  243. data/lib/poolpartycl.rb +4 -0
  244. data/log/pool.logs +0 -0
  245. data/poolparty.gemspec +574 -61
  246. data/spec/poolparty/aska/aska_spec.rb +122 -0
  247. data/spec/poolparty/bin/console_spec.rb +18 -0
  248. data/spec/poolparty/core/hash_spec.rb +4 -4
  249. data/spec/poolparty/core/object_spec.rb +29 -0
  250. data/spec/poolparty/core/string_spec.rb +6 -0
  251. data/spec/poolparty/core/time_spec.rb +0 -3
  252. data/spec/poolparty/helpers/binary_spec.rb +2 -2
  253. data/spec/poolparty/helpers/optioner_spec.rb +1 -4
  254. data/spec/poolparty/helpers/provisioner_base_spec.rb +14 -1
  255. data/spec/poolparty/helpers/provisioners/master_spec.rb +3 -3
  256. data/spec/poolparty/modules/cloud_resourcer_spec.rb +3 -3
  257. data/spec/poolparty/modules/configurable_spec.rb +4 -1
  258. data/spec/poolparty/monitors/base_monitor_spec.rb +94 -2
  259. data/spec/poolparty/monitors/monitors/cpu_monitor_spec.rb +0 -1
  260. data/spec/poolparty/monitors/monitors/memory_monitor_spec.rb +47 -0
  261. data/spec/poolparty/{helpers → net}/messenger_spec.rb +3 -1
  262. data/spec/poolparty/net/remote_bases/ec2_spec.rb +46 -5
  263. data/spec/poolparty/net/remote_instance_spec.rb +2 -1
  264. data/spec/poolparty/net/remote_spec.rb +30 -8
  265. data/spec/poolparty/net/remoter_base_spec.rb +4 -1
  266. data/spec/poolparty/net/remoter_spec.rb +11 -108
  267. data/spec/poolparty/plugins/deploydirectory_spec.rb +51 -0
  268. data/spec/poolparty/pool/base_spec.rb +43 -33
  269. data/spec/poolparty/pool/cloud_spec.rb +299 -248
  270. data/spec/poolparty/pool/custom_resource_spec.rb +10 -5
  271. data/spec/poolparty/pool/example_spec.rb +0 -84
  272. data/spec/poolparty/pool/plugin_model_spec.rb +3 -2
  273. data/spec/poolparty/pool/plugin_spec.rb +89 -62
  274. data/spec/poolparty/pool/pool_spec.rb +17 -2
  275. data/spec/poolparty/pool/resource_spec.rb +341 -236
  276. data/spec/poolparty/pool/resources/class_package_spec.rb +102 -66
  277. data/spec/poolparty/pool/resources/conditional_spec.rb +65 -26
  278. data/spec/poolparty/pool/resources/cron_spec.rb +3 -2
  279. data/spec/poolparty/pool/resources/exec_spec.rb +1 -1
  280. data/spec/poolparty/pool/resources/gem_spec.rb +18 -14
  281. data/spec/poolparty/pool/resources/remote_file_spec.rb +1 -1
  282. data/spec/poolparty/pool/resources/variable_spec.rb +1 -1
  283. data/spec/poolparty/pool/script_spec.rb +58 -37
  284. data/spec/poolparty/pool/test_plugins/webserver.rb +1 -0
  285. data/spec/poolparty/spec_helper.rb +16 -5
  286. data/tasks/deployment.rake +19 -3
  287. data/tasks/development.rake +11 -2
  288. data/tasks/ec2.rake +9 -1
  289. data/website/index.html +2 -2
  290. metadata +167 -70
  291. data/bin/pool-provision +0 -34
  292. data/erl_crash.dump +0 -8409
  293. data/examples/with_apache_plugin.rb +0 -22
  294. data/lib/erlang/messenger/Makefile +0 -15
  295. data/lib/erlang/messenger/ebin/master_app.beam +0 -0
  296. data/lib/erlang/messenger/ebin/node_app.beam +0 -0
  297. data/lib/erlang/messenger/ebin/pm_client.beam +0 -0
  298. data/lib/erlang/messenger/ebin/pm_cluster.beam +0 -0
  299. data/lib/erlang/messenger/ebin/pm_event_handler.beam +0 -0
  300. data/lib/erlang/messenger/ebin/pm_master.beam +0 -0
  301. data/lib/erlang/messenger/ebin/pm_master_supervisor.beam +0 -0
  302. data/lib/erlang/messenger/ebin/pm_node.beam +0 -0
  303. data/lib/erlang/messenger/ebin/pm_node_supervisor.beam +0 -0
  304. data/lib/erlang/messenger/ebin/pm_packager.beam +0 -0
  305. data/lib/erlang/messenger/ebin/utils.beam +0 -0
  306. data/lib/erlang/messenger/lib/eunit/Makefile +0 -28
  307. data/lib/erlang/messenger/lib/eunit/ebin/autoload.beam +0 -0
  308. data/lib/erlang/messenger/lib/eunit/ebin/code_monitor.beam +0 -0
  309. data/lib/erlang/messenger/lib/eunit/ebin/eunit.beam +0 -0
  310. data/lib/erlang/messenger/lib/eunit/ebin/eunit_autoexport.beam +0 -0
  311. data/lib/erlang/messenger/lib/eunit/ebin/eunit_data.beam +0 -0
  312. data/lib/erlang/messenger/lib/eunit/ebin/eunit_lib.beam +0 -0
  313. data/lib/erlang/messenger/lib/eunit/ebin/eunit_proc.beam +0 -0
  314. data/lib/erlang/messenger/lib/eunit/ebin/eunit_serial.beam +0 -0
  315. data/lib/erlang/messenger/lib/eunit/ebin/eunit_server.beam +0 -0
  316. data/lib/erlang/messenger/lib/eunit/ebin/eunit_striptests.beam +0 -0
  317. data/lib/erlang/messenger/lib/eunit/ebin/eunit_test.beam +0 -0
  318. data/lib/erlang/messenger/lib/eunit/ebin/eunit_tests.beam +0 -0
  319. data/lib/erlang/messenger/lib/eunit/ebin/eunit_tty.beam +0 -0
  320. data/lib/erlang/messenger/lib/eunit/ebin/file_monitor.beam +0 -0
  321. data/lib/erlang/messenger/lib/eunit/src/Makefile +0 -46
  322. data/lib/erlang/messenger/src/pm_event_handler.erl +0 -21
  323. data/lib/poolparty/config/allowed_commands.yml +0 -1
  324. data/lib/poolparty/helpers/messenger.rb +0 -29
  325. data/lib/poolparty/plugins/git.rb +0 -39
  326. data/lib/poolparty/pool/resources/gem.rb +0 -28
  327. data/lib/poolparty/pool/tmp/.ppkeys +0 -3
  328. data/lib/poolparty/pool/tmp/happydayz +0 -1
  329. data/lib/poolparty/pool/tmp/install_master.sh +0 -33
  330. data/lib/poolparty/pool/tmp/pool.spec +0 -11
  331. data/lib/poolparty/pool/tmp/poolparty.pp +0 -600
  332. data/lib/poolparty/pool/tmp/tc-instances.list +0 -1
  333. data/lib/poolparty/templates/fileserver.conf +0 -4
  334. data/spec/poolparty/plugins/git_spec.rb +0 -33
  335. data/test_manifest.pp +0 -658
@@ -0,0 +1,340 @@
1
+ %% This library is free software; you can redistribute it and/or modify
2
+ %% it under the terms of the GNU Lesser General Public License as
3
+ %% published by the Free Software Foundation; either version 2 of the
4
+ %% License, or (at your option) any later version.
5
+ %%
6
+ %% This library is distributed in the hope that it will be useful, but
7
+ %% WITHOUT ANY WARRANTY; without even the implied warranty of
8
+ %% MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
9
+ %% Lesser General Public License for more details.
10
+ %%
11
+ %% You should have received a copy of the GNU Lesser General Public
12
+ %% License along with this library; if not, write to the Free Software
13
+ %% Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
14
+ %% USA
15
+ %%
16
+ %% $Id:$
17
+ %%
18
+ %% @author Richard Carlsson <richardc@it.uu.se>
19
+ %% @copyright 2006 Richard Carlsson
20
+ %% @private
21
+ %% @see eunit
22
+ %% @doc EUnit server process
23
+
24
+ -module(eunit_server).
25
+
26
+ -export([start/1, stop/1, start_test/4, watch/3, watch_path/3,
27
+ watch_regexp/3]).
28
+
29
+ -export([main/1]). % private
30
+
31
+ -include("eunit.hrl").
32
+ -include("eunit_internal.hrl").
33
+
34
+
35
+ -define(AUTO_TIMEOUT, 60000). %% auto test time limit
36
+
37
+ %% TODO: pass options to server, such as default timeout?
38
+
39
+ start(Server) when is_atom(Server) ->
40
+ ensure_started(Server).
41
+
42
+ stop(Server) ->
43
+ command(Server, stop).
44
+
45
+
46
+ -record(job, {super, test, options}).
47
+
48
+ %% The `Super' process will receive a stream of status messages; see
49
+ %% eunit_proc:status_message/3 for details.
50
+
51
+ start_test(Server, Super, T, Options) ->
52
+ command(Server, {start, #job{super = Super,
53
+ test = T,
54
+ options = Options}}).
55
+
56
+ watch(Server, Module, Opts) when is_atom(Module) ->
57
+ command(Server, {watch, {module, Module}, Opts}).
58
+
59
+ watch_path(Server, Path, Opts) ->
60
+ command(Server, {watch, {path, filename:flatten(Path)}, Opts}).
61
+
62
+ watch_regexp(Server, Regex, Opts) ->
63
+ case regexp:parse(Regex) of
64
+ {ok, R} ->
65
+ command(Server, {watch, {regexp, R}, Opts});
66
+ {error, _}=Error ->
67
+ Error
68
+ end.
69
+
70
+ %% This makes sure the server is started before sending the command, and
71
+ %% returns {ok, Result} if the server accepted the command or {error,
72
+ %% server_down} if the server process crashes. If the server does not
73
+ %% reply, this function will wait until the server is killed.
74
+
75
+ command(Server, Cmd) ->
76
+ if is_atom(Server), Cmd /= stop -> ensure_started(Server);
77
+ true -> ok
78
+ end,
79
+ if is_pid(Server) -> command_1(Server, Cmd);
80
+ true ->
81
+ case whereis(Server) of
82
+ undefined -> {error, server_down};
83
+ Pid -> command_1(Pid, Cmd)
84
+ end
85
+ end.
86
+
87
+ command_1(Pid, Cmd) when is_pid(Pid) ->
88
+ Pid ! {command, self(), Cmd},
89
+ command_wait(Pid, 1000, undefined).
90
+
91
+ command_wait(Pid, Timeout, Monitor) ->
92
+ receive
93
+ {Pid, Result} -> Result;
94
+ {'DOWN', Monitor, process, Pid, _R} -> {error, server_down}
95
+ after Timeout ->
96
+ %% avoid creating a monitor unless some time has passed
97
+ command_wait(Pid, infinity, erlang:monitor(process, Pid))
98
+ end.
99
+
100
+ %% Starting the server
101
+
102
+ ensure_started(Name) ->
103
+ ensure_started(Name, 5).
104
+
105
+ ensure_started(Name, N) when N > 0 ->
106
+ case whereis(Name) of
107
+ undefined ->
108
+ Parent = self(),
109
+ Pid = spawn(fun () -> server_start(Name, Parent) end),
110
+ receive
111
+ {Pid, ok} ->
112
+ Pid;
113
+ {Pid, error} ->
114
+ receive after 200 -> ensure_started(N - 1) end
115
+ end;
116
+ Pid ->
117
+ Pid
118
+ end;
119
+ ensure_started(_, _) ->
120
+ throw(no_server).
121
+
122
+ server_start(undefined = Name, Parent) ->
123
+ %% anonymous server
124
+ server_start_1(Name, Parent);
125
+ server_start(Name, Parent) ->
126
+ try register(Name, self()) of
127
+ true -> server_start_1(Name, Parent)
128
+ catch
129
+ _:_ ->
130
+ Parent ! {self(), error},
131
+ exit(error)
132
+ end.
133
+
134
+ server_start_1(Name, Parent) ->
135
+ Parent ! {self(), ok},
136
+ server_init(Name).
137
+
138
+ -record(state, {name,
139
+ stopped,
140
+ jobs,
141
+ queue,
142
+ auto_test,
143
+ modules,
144
+ paths,
145
+ regexps}).
146
+
147
+ server_init(Name) ->
148
+ server(#state{name = Name,
149
+ stopped = false,
150
+ jobs = dict:new(),
151
+ queue = queue:new(),
152
+ auto_test = queue:new(),
153
+ modules = sets:new(),
154
+ paths = sets:new(),
155
+ regexps = sets:new()}).
156
+
157
+ server(St) ->
158
+ server_check_exit(St),
159
+ ?MODULE:main(St).
160
+
161
+ %% @private
162
+ main(St) ->
163
+ receive
164
+ {done, auto_test, _Pid} ->
165
+ server(auto_test_done(St));
166
+ {done, Reference, _Pid} ->
167
+ server(handle_done(Reference, St));
168
+ {command, From, _Cmd} when St#state.stopped ->
169
+ From ! {self(), stopped};
170
+ {command, From, Cmd} ->
171
+ server_command(From, Cmd, St);
172
+ {code_monitor, {loaded, M, _Time}} ->
173
+ case is_watched(M, St) of
174
+ true ->
175
+ server(new_auto_test(self(), M, St));
176
+ false ->
177
+ server(St)
178
+ end
179
+ end.
180
+
181
+ server_check_exit(St) ->
182
+ case dict:size(St#state.jobs) of
183
+ 0 when St#state.stopped -> exit(normal);
184
+ _ -> ok
185
+ end.
186
+
187
+ server_command(From, {start, Job}, St) ->
188
+ Reference = make_ref(),
189
+ St1 = case proplists:get_bool(enqueue, Job#job.options) of
190
+ true ->
191
+ enqueue(Job, From, Reference, St);
192
+ false ->
193
+ start_job(Job, From, Reference, St)
194
+ end,
195
+ server_command_reply(From, {ok, Reference}),
196
+ server(St1);
197
+ server_command(From, stop, St) ->
198
+ %% unregister the server name and let remaining jobs finish
199
+ server_command_reply(From, {error, stopped}),
200
+ catch unregister(St#state.name),
201
+ server(St#state{stopped = true});
202
+ server_command(From, {watch, Target, _Opts}, St) ->
203
+ %% the code watcher is only started on demand
204
+ code_monitor:monitor(self()),
205
+ %% TODO: propagate options to testing stage
206
+ St1 = add_watch(Target, St),
207
+ server_command_reply(From, ok),
208
+ server(St1);
209
+ server_command(From, {forget, Target}, St) ->
210
+ St1 = delete_watch(Target, St),
211
+ server_command_reply(From, ok),
212
+ server(St1);
213
+ server_command(From, Cmd, St) ->
214
+ server_command_reply(From, {error, {unknown_command, Cmd}}),
215
+ server(St).
216
+
217
+ server_command_reply(From, Result) ->
218
+ From ! {self(), Result}.
219
+
220
+ enqueue(Job, From, Reference, St) ->
221
+ case dict:size(St#state.jobs) of
222
+ 0 ->
223
+ start_job(Job, From, Reference, St);
224
+ _ ->
225
+ St#state{queue = queue:in({Job, From, Reference},
226
+ St#state.queue)}
227
+ end.
228
+
229
+ dequeue(St) ->
230
+ case queue:out(St#state.queue) of
231
+ {empty, _} ->
232
+ St;
233
+ {{value, {Job, From, Reference}}, Queue} ->
234
+ start_job(Job, From, Reference, St#state{queue = Queue})
235
+ end.
236
+
237
+ start_job(Job, From, Reference, St) ->
238
+ From ! {start, Reference},
239
+ %% The default is to run tests in order unless otherwise specified
240
+ Order = proplists:get_value(order, Job#job.options, inorder),
241
+ eunit_proc:start(Job#job.test, Order, Job#job.super, Reference),
242
+ St#state{jobs = dict:store(Reference, From, St#state.jobs)}.
243
+
244
+ handle_done(Reference, St) ->
245
+ case dict:find(Reference, St#state.jobs) of
246
+ {ok, From} ->
247
+ From ! {done, Reference},
248
+ dequeue(St#state{jobs = dict:erase(Reference,
249
+ St#state.jobs)});
250
+ error ->
251
+ St
252
+ end.
253
+
254
+ %% Adding and removing watched modules or paths
255
+
256
+ add_watch({module, M}, St) ->
257
+ St#state{modules = sets:add_element(M, St#state.modules)};
258
+ add_watch({path, P}, St) ->
259
+ St#state{paths = sets:add_element(P, St#state.paths)};
260
+ add_watch({regexp, R}, St) ->
261
+ St#state{regexps = sets:add_element(R, St#state.regexps)}.
262
+
263
+ delete_watch({module, M}, St) ->
264
+ St#state{modules = sets:del_element(M, St#state.modules)};
265
+ delete_watch({path, P}, St) ->
266
+ St#state{paths = sets:del_element(P, St#state.paths)};
267
+ delete_watch({regexp, R}, St) ->
268
+ St#state{regexps = sets:del_element(R, St#state.regexps)}.
269
+
270
+ %% Checking if a module is being watched
271
+
272
+ is_watched(M, St) when is_atom(M) ->
273
+ sets:is_element(M, St#state.modules) orelse
274
+ is_watched(code:which(M), St);
275
+ is_watched(Path, St) ->
276
+ sets:is_element(filename:dirname(Path), St#state.paths) orelse
277
+ match_any(sets:to_list(St#state.regexps), Path).
278
+
279
+ match_any([R | Rs], Str) ->
280
+ case regexp:first_match(Str, R) of
281
+ {match, _, _} -> true;
282
+ _ -> match_any(Rs, Str)
283
+ end;
284
+ match_any([], _Str) -> false.
285
+
286
+ %% Running automatic tests when a watched module is loaded.
287
+ %% Uses a queue in order to avoid overlapping output when several
288
+ %% watched modules are loaded simultaneously. (The currently running
289
+ %% automatic test is kept in the queue until it is done. An empty queue
290
+ %% means that no automatic test is running.)
291
+
292
+ new_auto_test(Server, M, St) ->
293
+ case queue:is_empty(St#state.auto_test) of
294
+ true ->
295
+ start_auto_test(Server, M);
296
+ false ->
297
+ ok
298
+ end,
299
+ St#state{auto_test = queue:in({Server, M}, St#state.auto_test)}.
300
+
301
+ auto_test_done(St) ->
302
+ %% remove finished test from queue before checking for more
303
+ {_, Queue} = queue:out(St#state.auto_test),
304
+ case queue:out(Queue) of
305
+ {{value, {Server, M}}, _} ->
306
+ %% this is just lookahead - the item is not removed
307
+ start_auto_test(Server, M);
308
+ {empty, _} ->
309
+ ok
310
+ end,
311
+ St#state{auto_test = Queue}.
312
+
313
+ start_auto_test(Server, M) ->
314
+ spawn(fun () -> auto_super(Server, M) end).
315
+
316
+ auto_super(Server, M) ->
317
+ process_flag(trap_exit, true),
318
+ %% Give the user a short delay before any output is produced
319
+ receive after 333 -> ok end,
320
+ %% Make sure output is sent to console on server node
321
+ group_leader(whereis(user), self()),
322
+ Pid = spawn_link(fun () -> auto_proc(Server, M) end),
323
+ receive
324
+ {'EXIT', Pid, _} ->
325
+ ok
326
+ after ?AUTO_TIMEOUT ->
327
+ exit(Pid, kill),
328
+ io:put_chars("\n== EUnit: automatic test was aborted ==\n"),
329
+ io:put_chars("\n> ")
330
+ end,
331
+ Server ! {done, auto_test, self()}.
332
+
333
+ auto_proc(Server, M) ->
334
+ %% Make the output start on a new line instead of on the same line
335
+ %% as the current shell prompt.
336
+ io:fwrite("\n== EUnit: testing module ~w ==\n", [M]),
337
+ eunit:test(Server, M, [enqueue]),
338
+ %% Make sure to print a dummy prompt at the end of the output, most
339
+ %% of all so that the Emacs mode realizes that input is active.
340
+ io:put_chars("\n-> ").
@@ -0,0 +1,64 @@
1
+ %% This library is free software; you can redistribute it and/or modify
2
+ %% it under the terms of the GNU Lesser General Public License as
3
+ %% published by the Free Software Foundation; either version 2 of the
4
+ %% License, or (at your option) any later version.
5
+ %%
6
+ %% This library is distributed in the hope that it will be useful, but
7
+ %% WITHOUT ANY WARRANTY; without even the implied warranty of
8
+ %% MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
9
+ %% Lesser General Public License for more details.
10
+ %%
11
+ %% You should have received a copy of the GNU Lesser General Public
12
+ %% License along with this library; if not, write to the Free Software
13
+ %% Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
14
+ %% USA
15
+ %%
16
+ %% $Id:$
17
+ %%
18
+ %% @author Richard Carlsson <richardc@it.uu.se>
19
+ %% @author Eric Merritt <cyberlync@gmail.com>
20
+ %% @copyright 2006 Richard Carlsson, Eric Merritt
21
+ %% @private
22
+ %% @see eunit
23
+ %% @doc Parse transform for stripping EUnit test functions.
24
+
25
+ -module(eunit_striptests).
26
+
27
+ -include("eunit_internal.hrl").
28
+
29
+ -export([parse_transform/2]).
30
+
31
+ parse_transform(Forms, Options) ->
32
+ TestSuffix = proplists:get_value(eunit_test_suffix, Options,
33
+ ?DEFAULT_TEST_SUFFIX),
34
+ GeneratorSuffix = proplists:get_value(eunit_generator_suffix,
35
+ Options,
36
+ ?DEFAULT_GENERATOR_SUFFIX),
37
+ ExportSuffix = proplists:get_value(eunit_export_suffix, Options,
38
+ ?DEFAULT_EXPORT_SUFFIX),
39
+ Exports = lists:foldl(fun ({attribute,_,export,Es}, S) ->
40
+ sets:union(sets:from_list(Es), S);
41
+ (_F, S) -> S
42
+ end,
43
+ sets:new(), Forms),
44
+ F = fun (Form, Acc) ->
45
+ form(Form, Acc, Exports, TestSuffix, GeneratorSuffix,
46
+ ExportSuffix)
47
+ end,
48
+ lists:reverse(lists:foldl(F, [], Forms)).
49
+
50
+ form({function, _L, Name, 0, _Cs}=Form, Acc, Exports, TestSuffix,
51
+ GeneratorSuffix, ExportSuffix) ->
52
+ N = atom_to_list(Name),
53
+ case not sets:is_element({Name, 0}, Exports)
54
+ andalso (lists:suffix(TestSuffix, N)
55
+ orelse lists:suffix(GeneratorSuffix, N)
56
+ orelse lists:suffix(ExportSuffix, N))
57
+ of
58
+ true ->
59
+ Acc;
60
+ false ->
61
+ [Form | Acc]
62
+ end;
63
+ form(Form, Acc, _, _, _, _) ->
64
+ [Form | Acc].