warbler 1.4.10 → 2.0.0.pre1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (186) hide show
  1. checksums.yaml +4 -4
  2. data/.travis.yml +12 -29
  3. data/Gemfile +1 -12
  4. data/History.txt +5 -7
  5. data/Mavenfile +1 -2
  6. data/README.rdoc +51 -53
  7. data/Rakefile +7 -13
  8. data/ext/JarMain.java +12 -58
  9. data/ext/WarMain.java +13 -41
  10. data/ext/WarblerJar.java +8 -12
  11. data/lib/warbler.rb +0 -1
  12. data/lib/warbler/config.rb +11 -2
  13. data/lib/warbler/gems.rb +9 -9
  14. data/lib/warbler/jar.rb +2 -4
  15. data/lib/warbler/rake_helper.rb +0 -7
  16. data/lib/warbler/traits.rb +0 -1
  17. data/lib/warbler/traits/bundler.rb +12 -12
  18. data/lib/warbler/traits/gemspec.rb +12 -22
  19. data/lib/warbler/traits/rails.rb +5 -5
  20. data/lib/warbler/traits/war.rb +2 -7
  21. data/lib/warbler/version.rb +1 -1
  22. data/lib/warbler/web_server.rb +4 -16
  23. data/lib/warbler/zip_support.rb +3 -21
  24. data/lib/warbler_jar.jar +0 -0
  25. data/pom.xml +23 -6
  26. data/spec/drb_default_id_conv.rb +48 -50
  27. data/spec/sample_bundler/Gemfile +1 -1
  28. data/spec/sample_bundler/vendor/bundle/jruby/{1.8 → 2.2.0}/bin/rake +7 -3
  29. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/cache/rake-10.4.2.gem +0 -0
  30. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/.autotest +7 -0
  31. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/.gemtest +0 -0
  32. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/.rubocop.yml +27 -0
  33. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/.togglerc +7 -0
  34. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/CONTRIBUTING.rdoc +34 -0
  35. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/History.rdoc +651 -0
  36. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/MIT-LICENSE +21 -0
  37. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/Manifest.txt +166 -0
  38. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/README.rdoc +140 -0
  39. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/Rakefile +81 -0
  40. data/spec/sample_bundler/vendor/bundle/{ruby/1.8/gems/rake-0.8.7 → jruby/2.2.0/gems/rake-10.4.2}/bin/rake +5 -3
  41. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/lib/rake.rb +79 -0
  42. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/lib/rake/alt_system.rb +110 -0
  43. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/lib/rake/application.rb +790 -0
  44. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/lib/rake/backtrace.rb +23 -0
  45. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/lib/rake/clean.rb +76 -0
  46. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/lib/rake/cloneable.rb +16 -0
  47. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/lib/rake/contrib/.document +1 -0
  48. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/lib/rake/contrib/compositepublisher.rb +21 -0
  49. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/lib/rake/contrib/ftptools.rb +137 -0
  50. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/lib/rake/contrib/publisher.rb +81 -0
  51. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/lib/rake/contrib/rubyforgepublisher.rb +18 -0
  52. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/lib/rake/contrib/sshpublisher.rb +61 -0
  53. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/lib/rake/contrib/sys.rb +4 -0
  54. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/lib/rake/cpu_counter.rb +125 -0
  55. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/lib/rake/default_loader.rb +14 -0
  56. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/lib/rake/dsl_definition.rb +201 -0
  57. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/lib/rake/early_time.rb +21 -0
  58. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/lib/rake/ext/core.rb +25 -0
  59. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/lib/rake/ext/module.rb +2 -0
  60. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/lib/rake/ext/pathname.rb +25 -0
  61. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/lib/rake/ext/string.rb +173 -0
  62. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/lib/rake/ext/time.rb +16 -0
  63. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/lib/rake/file_creation_task.rb +24 -0
  64. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/lib/rake/file_list.rb +428 -0
  65. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/lib/rake/file_task.rb +46 -0
  66. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/lib/rake/file_utils.rb +128 -0
  67. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/lib/rake/file_utils_ext.rb +144 -0
  68. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/lib/rake/gempackagetask.rb +4 -0
  69. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/lib/rake/invocation_chain.rb +56 -0
  70. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/lib/rake/invocation_exception_mixin.rb +16 -0
  71. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/lib/rake/late_time.rb +17 -0
  72. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/lib/rake/linked_list.rb +103 -0
  73. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/lib/rake/loaders/makefile.rb +40 -0
  74. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/lib/rake/multi_task.rb +13 -0
  75. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/lib/rake/name_space.rb +38 -0
  76. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/lib/rake/packagetask.rb +199 -0
  77. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/lib/rake/pathmap.rb +3 -0
  78. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/lib/rake/phony.rb +15 -0
  79. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/lib/rake/private_reader.rb +20 -0
  80. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/lib/rake/promise.rb +99 -0
  81. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/lib/rake/pseudo_status.rb +29 -0
  82. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/lib/rake/rake_module.rb +38 -0
  83. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/lib/rake/rake_test_loader.rb +22 -0
  84. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/lib/rake/rdoctask.rb +4 -0
  85. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/lib/rake/ruby182_test_unit_fix.rb +29 -0
  86. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/lib/rake/rule_recursion_overflow_error.rb +20 -0
  87. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/lib/rake/runtest.rb +27 -0
  88. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/lib/rake/scope.rb +42 -0
  89. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/lib/rake/task.rb +383 -0
  90. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/lib/rake/task_argument_error.rb +7 -0
  91. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/lib/rake/task_arguments.rb +98 -0
  92. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/lib/rake/task_manager.rb +310 -0
  93. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/lib/rake/tasklib.rb +24 -0
  94. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/lib/rake/testtask.rb +212 -0
  95. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/lib/rake/thread_history_display.rb +48 -0
  96. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/lib/rake/thread_pool.rb +164 -0
  97. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/lib/rake/trace_output.rb +22 -0
  98. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/lib/rake/version.rb +7 -0
  99. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/lib/rake/win32.rb +56 -0
  100. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/rakelib/publish.rake +20 -0
  101. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/rakelib/test_times.rake +25 -0
  102. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/test/file_creation.rb +34 -0
  103. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/test/helper.rb +130 -0
  104. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/test/support/rakefile_definitions.rb +478 -0
  105. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/test/support/ruby_runner.rb +34 -0
  106. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/test/test_private_reader.rb +42 -0
  107. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/test/test_rake.rb +40 -0
  108. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/test/test_rake_application.rb +643 -0
  109. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/test/test_rake_application_options.rb +466 -0
  110. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/test/test_rake_backtrace.rb +119 -0
  111. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/test/test_rake_clean.rb +61 -0
  112. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/test/test_rake_cpu_counter.rb +68 -0
  113. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/test/test_rake_definitions.rb +84 -0
  114. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/test/test_rake_directory_task.rb +76 -0
  115. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/test/test_rake_dsl.rb +40 -0
  116. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/test/test_rake_early_time.rb +31 -0
  117. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/test/test_rake_extension.rb +59 -0
  118. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/test/test_rake_file_creation_task.rb +56 -0
  119. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/test/test_rake_file_list.rb +655 -0
  120. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/test/test_rake_file_list_path_map.rb +8 -0
  121. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/test/test_rake_file_task.rb +197 -0
  122. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/test/test_rake_file_utils.rb +309 -0
  123. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/test/test_rake_ftp_file.rb +74 -0
  124. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/test/test_rake_functional.rb +482 -0
  125. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/test/test_rake_invocation_chain.rb +64 -0
  126. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/test/test_rake_late_time.rb +18 -0
  127. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/test/test_rake_linked_list.rb +84 -0
  128. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/test/test_rake_makefile_loader.rb +46 -0
  129. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/test/test_rake_multi_task.rb +64 -0
  130. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/test/test_rake_name_space.rb +57 -0
  131. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/test/test_rake_package_task.rb +79 -0
  132. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/test/test_rake_path_map.rb +168 -0
  133. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/test/test_rake_path_map_explode.rb +34 -0
  134. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/test/test_rake_path_map_partial.rb +18 -0
  135. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/test/test_rake_pathname_extensions.rb +15 -0
  136. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/test/test_rake_pseudo_status.rb +21 -0
  137. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/test/test_rake_rake_test_loader.rb +20 -0
  138. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/test/test_rake_reduce_compat.rb +26 -0
  139. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/test/test_rake_require.rb +40 -0
  140. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/test/test_rake_rules.rb +388 -0
  141. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/test/test_rake_scope.rb +44 -0
  142. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/test/test_rake_task.rb +393 -0
  143. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/test/test_rake_task_argument_parsing.rb +119 -0
  144. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/test/test_rake_task_arguments.rb +127 -0
  145. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/test/test_rake_task_lib.rb +9 -0
  146. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/test/test_rake_task_manager.rb +178 -0
  147. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/test/test_rake_task_manager_argument_resolution.rb +19 -0
  148. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/test/test_rake_task_with_arguments.rb +172 -0
  149. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/test/test_rake_test_task.rb +146 -0
  150. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/test/test_rake_thread_pool.rb +145 -0
  151. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/test/test_rake_top_level_functions.rb +71 -0
  152. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/test/test_rake_win32.rb +72 -0
  153. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/test/test_thread_history_display.rb +101 -0
  154. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/gems/rake-10.4.2/test/test_trace_output.rb +52 -0
  155. data/spec/sample_bundler/vendor/bundle/jruby/2.2.0/specifications/rake-10.4.2.gemspec +43 -0
  156. data/spec/sample_jar/sample_jar.gemspec +1 -2
  157. data/spec/spec_helper.rb +2 -8
  158. data/spec/warbler/bundler_spec.rb +11 -22
  159. data/spec/warbler/config_spec.rb +0 -3
  160. data/spec/warbler/jar_spec.rb +3 -77
  161. data/spec/warbler/task_spec.rb +5 -6
  162. data/spec/warbler/web_server_spec.rb +2 -2
  163. data/warble.rb +4 -4
  164. data/warbler.gemspec +8 -8
  165. metadata +451 -64
  166. data/lib/warbler/bundler_helper.rb +0 -22
  167. data/lib/warbler/traits/merb.rb +0 -35
  168. data/spec/sample_bundler/vendor/bundle/jruby/1.8/cache/rake-0.8.7.gem +0 -0
  169. data/spec/sample_bundler/vendor/bundle/jruby/1.8/gems/rake-0.8.7/bin/rake +0 -31
  170. data/spec/sample_bundler/vendor/bundle/jruby/1.8/gems/rake-0.8.7/lib/rake.rb +0 -2506
  171. data/spec/sample_bundler/vendor/bundle/jruby/1.8/specifications/rake-0.8.7.gemspec +0 -31
  172. data/spec/sample_bundler/vendor/bundle/jruby/1.9/bin/rake +0 -19
  173. data/spec/sample_bundler/vendor/bundle/jruby/1.9/cache/rake-0.8.7.gem +0 -0
  174. data/spec/sample_bundler/vendor/bundle/jruby/1.9/gems/rake-0.8.7/bin/rake +0 -31
  175. data/spec/sample_bundler/vendor/bundle/jruby/1.9/gems/rake-0.8.7/lib/rake.rb +0 -2506
  176. data/spec/sample_bundler/vendor/bundle/jruby/1.9/specifications/rake-0.8.7.gemspec +0 -30
  177. data/spec/sample_bundler/vendor/bundle/ruby/1.8/bin/rake +0 -19
  178. data/spec/sample_bundler/vendor/bundle/ruby/1.8/cache/rake-0.8.7.gem +0 -0
  179. data/spec/sample_bundler/vendor/bundle/ruby/1.8/gems/rake-0.8.7/lib/rake.rb +0 -2506
  180. data/spec/sample_bundler/vendor/bundle/ruby/1.8/specifications/rake-0.8.7.gemspec +0 -30
  181. data/spec/sample_bundler/vendor/bundle/ruby/1.9.1/bin/rake +0 -19
  182. data/spec/sample_bundler/vendor/bundle/ruby/1.9.1/cache/rake-0.8.7.gem +0 -0
  183. data/spec/sample_bundler/vendor/bundle/ruby/1.9.1/gems/rake-0.8.7/bin/rake +0 -31
  184. data/spec/sample_bundler/vendor/bundle/ruby/1.9.1/gems/rake-0.8.7/lib/rake.rb +0 -2506
  185. data/spec/sample_bundler/vendor/bundle/ruby/1.9.1/specifications/rake-0.8.7.gemspec +0 -30
  186. data/spec/sample_jar/sbin/sample_jar +0 -5
@@ -0,0 +1,48 @@
1
+ require 'rake/private_reader'
2
+
3
+ module Rake
4
+
5
+ class ThreadHistoryDisplay # :nodoc: all
6
+ include Rake::PrivateReader
7
+
8
+ private_reader :stats, :items, :threads
9
+
10
+ def initialize(stats)
11
+ @stats = stats
12
+ @items = { :_seq_ => 1 }
13
+ @threads = { :_seq_ => "A" }
14
+ end
15
+
16
+ def show
17
+ puts "Job History:"
18
+ stats.each do |stat|
19
+ stat[:data] ||= {}
20
+ rename(stat, :thread, threads)
21
+ rename(stat[:data], :item_id, items)
22
+ rename(stat[:data], :new_thread, threads)
23
+ rename(stat[:data], :deleted_thread, threads)
24
+ printf("%8d %2s %-20s %s\n",
25
+ (stat[:time] * 1_000_000).round,
26
+ stat[:thread],
27
+ stat[:event],
28
+ stat[:data].map do |k, v| "#{k}:#{v}" end.join(" "))
29
+ end
30
+ end
31
+
32
+ private
33
+
34
+ def rename(hash, key, renames)
35
+ if hash && hash[key]
36
+ original = hash[key]
37
+ value = renames[original]
38
+ unless value
39
+ value = renames[:_seq_]
40
+ renames[:_seq_] = renames[:_seq_].succ
41
+ renames[original] = value
42
+ end
43
+ hash[key] = value
44
+ end
45
+ end
46
+ end
47
+
48
+ end
@@ -0,0 +1,164 @@
1
+ require 'thread'
2
+ require 'set'
3
+
4
+ require 'rake/promise'
5
+
6
+ module Rake
7
+
8
+ class ThreadPool # :nodoc: all
9
+
10
+ # Creates a ThreadPool object. The +thread_count+ parameter is the size
11
+ # of the pool.
12
+ def initialize(thread_count)
13
+ @max_active_threads = [thread_count, 0].max
14
+ @threads = Set.new
15
+ @threads_mon = Monitor.new
16
+ @queue = Queue.new
17
+ @join_cond = @threads_mon.new_cond
18
+
19
+ @history_start_time = nil
20
+ @history = []
21
+ @history_mon = Monitor.new
22
+ @total_threads_in_play = 0
23
+ end
24
+
25
+ # Creates a future executed by the +ThreadPool+.
26
+ #
27
+ # The args are passed to the block when executing (similarly to
28
+ # Thread#new) The return value is an object representing
29
+ # a future which has been created and added to the queue in the
30
+ # pool. Sending #value to the object will sleep the
31
+ # current thread until the future is finished and will return the
32
+ # result (or raise an exception thrown from the future)
33
+ def future(*args, &block)
34
+ promise = Promise.new(args, &block)
35
+ promise.recorder = lambda { |*stats| stat(*stats) }
36
+
37
+ @queue.enq promise
38
+ stat :queued, :item_id => promise.object_id
39
+ start_thread
40
+ promise
41
+ end
42
+
43
+ # Waits until the queue of futures is empty and all threads have exited.
44
+ def join
45
+ @threads_mon.synchronize do
46
+ begin
47
+ stat :joining
48
+ @join_cond.wait unless @threads.empty?
49
+ stat :joined
50
+ rescue Exception => e
51
+ stat :joined
52
+ $stderr.puts e
53
+ $stderr.print "Queue contains #{@queue.size} items. " +
54
+ "Thread pool contains #{@threads.count} threads\n"
55
+ $stderr.print "Current Thread #{Thread.current} status = " +
56
+ "#{Thread.current.status}\n"
57
+ $stderr.puts e.backtrace.join("\n")
58
+ @threads.each do |t|
59
+ $stderr.print "Thread #{t} status = #{t.status}\n"
60
+ # 1.8 doesn't support Thread#backtrace
61
+ $stderr.puts t.backtrace.join("\n") if t.respond_to? :backtrace
62
+ end
63
+ raise e
64
+ end
65
+ end
66
+ end
67
+
68
+ # Enable the gathering of history events.
69
+ def gather_history #:nodoc:
70
+ @history_start_time = Time.now if @history_start_time.nil?
71
+ end
72
+
73
+ # Return a array of history events for the thread pool.
74
+ #
75
+ # History gathering must be enabled to be able to see the events
76
+ # (see #gather_history). Best to call this when the job is
77
+ # complete (i.e. after ThreadPool#join is called).
78
+ def history # :nodoc:
79
+ @history_mon.synchronize { @history.dup }.
80
+ sort_by { |i| i[:time] }.
81
+ each { |i| i[:time] -= @history_start_time }
82
+ end
83
+
84
+ # Return a hash of always collected statistics for the thread pool.
85
+ def statistics # :nodoc:
86
+ {
87
+ :total_threads_in_play => @total_threads_in_play,
88
+ :max_active_threads => @max_active_threads,
89
+ }
90
+ end
91
+
92
+ private
93
+
94
+ # processes one item on the queue. Returns true if there was an
95
+ # item to process, false if there was no item
96
+ def process_queue_item #:nodoc:
97
+ return false if @queue.empty?
98
+
99
+ # Even though we just asked if the queue was empty, it
100
+ # still could have had an item which by this statement
101
+ # is now gone. For this reason we pass true to Queue#deq
102
+ # because we will sleep indefinitely if it is empty.
103
+ promise = @queue.deq(true)
104
+ stat :dequeued, :item_id => promise.object_id
105
+ promise.work
106
+ return true
107
+
108
+ rescue ThreadError # this means the queue is empty
109
+ false
110
+ end
111
+
112
+ def safe_thread_count
113
+ @threads_mon.synchronize do
114
+ @threads.count
115
+ end
116
+ end
117
+
118
+ def start_thread # :nodoc:
119
+ @threads_mon.synchronize do
120
+ next unless @threads.count < @max_active_threads
121
+
122
+ t = Thread.new do
123
+ begin
124
+ while safe_thread_count <= @max_active_threads
125
+ break unless process_queue_item
126
+ end
127
+ ensure
128
+ @threads_mon.synchronize do
129
+ @threads.delete Thread.current
130
+ stat :ended, :thread_count => @threads.count
131
+ @join_cond.broadcast if @threads.empty?
132
+ end
133
+ end
134
+ end
135
+
136
+ @threads << t
137
+ stat(
138
+ :spawned,
139
+ :new_thread => t.object_id,
140
+ :thread_count => @threads.count)
141
+ @total_threads_in_play = @threads.count if
142
+ @threads.count > @total_threads_in_play
143
+ end
144
+ end
145
+
146
+ def stat(event, data=nil) # :nodoc:
147
+ return if @history_start_time.nil?
148
+ info = {
149
+ :event => event,
150
+ :data => data,
151
+ :time => Time.now,
152
+ :thread => Thread.current.object_id,
153
+ }
154
+ @history_mon.synchronize { @history << info }
155
+ end
156
+
157
+ # for testing only
158
+
159
+ def __queue__ # :nodoc:
160
+ @queue
161
+ end
162
+ end
163
+
164
+ end
@@ -0,0 +1,22 @@
1
+ module Rake
2
+ module TraceOutput # :nodoc: all
3
+
4
+ # Write trace output to output stream +out+.
5
+ #
6
+ # The write is done as a single IO call (to print) to lessen the
7
+ # chance that the trace output is interrupted by other tasks also
8
+ # producing output.
9
+ def trace_on(out, *strings)
10
+ sep = $\ || "\n"
11
+ if strings.empty?
12
+ output = sep
13
+ else
14
+ output = strings.map { |s|
15
+ next if s.nil?
16
+ s =~ /#{sep}$/ ? s : s + sep
17
+ }.join
18
+ end
19
+ out.print(output)
20
+ end
21
+ end
22
+ end
@@ -0,0 +1,7 @@
1
+ module Rake
2
+ module Version # :nodoc: all
3
+ MAJOR, MINOR, BUILD, *OTHER = Rake::VERSION.split '.'
4
+
5
+ NUMBERS = [MAJOR, MINOR, BUILD, *OTHER]
6
+ end
7
+ end
@@ -0,0 +1,56 @@
1
+
2
+ module Rake
3
+ require 'rake/alt_system'
4
+
5
+ # Win 32 interface methods for Rake. Windows specific functionality
6
+ # will be placed here to collect that knowledge in one spot.
7
+ module Win32 # :nodoc: all
8
+
9
+ # Error indicating a problem in locating the home directory on a
10
+ # Win32 system.
11
+ class Win32HomeError < RuntimeError
12
+ end
13
+
14
+ class << self
15
+ # True if running on a windows system.
16
+ def windows?
17
+ AltSystem::WINDOWS
18
+ end
19
+
20
+ # Run a command line on windows.
21
+ def rake_system(*cmd)
22
+ AltSystem.system(*cmd)
23
+ end
24
+
25
+ # The standard directory containing system wide rake files on
26
+ # Win 32 systems. Try the following environment variables (in
27
+ # order):
28
+ #
29
+ # * HOME
30
+ # * HOMEDRIVE + HOMEPATH
31
+ # * APPDATA
32
+ # * USERPROFILE
33
+ #
34
+ # If the above are not defined, the return nil.
35
+ def win32_system_dir #:nodoc:
36
+ win32_shared_path = ENV['HOME']
37
+ if win32_shared_path.nil? && ENV['HOMEDRIVE'] && ENV['HOMEPATH']
38
+ win32_shared_path = ENV['HOMEDRIVE'] + ENV['HOMEPATH']
39
+ end
40
+
41
+ win32_shared_path ||= ENV['APPDATA']
42
+ win32_shared_path ||= ENV['USERPROFILE']
43
+ raise Win32HomeError,
44
+ "Unable to determine home path environment variable." if
45
+ win32_shared_path.nil? or win32_shared_path.empty?
46
+ normalize(File.join(win32_shared_path, 'Rake'))
47
+ end
48
+
49
+ # Normalize a win32 path so that the slashes are all forward slashes.
50
+ def normalize(path)
51
+ path.gsub(/\\/, '/')
52
+ end
53
+
54
+ end
55
+ end
56
+ end
@@ -0,0 +1,20 @@
1
+ # Optional publish task for Rake
2
+
3
+ begin
4
+ require 'rake/contrib/sshpublisher'
5
+ require 'rake/contrib/rubyforgepublisher'
6
+
7
+ publisher = Rake::SshDirPublisher.new(
8
+ 'linode',
9
+ 'htdocs/software/rake',
10
+ 'html')
11
+
12
+ desc "Publish the Documentation to RubyForge."
13
+ task :publish => [:rdoc] do
14
+ publisher.upload
15
+ end
16
+
17
+ rescue LoadError => ex
18
+ puts "#{ex.message} (#{ex.class})"
19
+ puts "No Publisher Task Available"
20
+ end
@@ -0,0 +1,25 @@
1
+ module TestTimes
2
+ def self.run(test_results, limit=0)
3
+ limit = limit.nonzero? || 10
4
+ tests = []
5
+ test_results.split(/\n/).each do |line|
6
+ if line =~ /^(.+?#[^:]+): ([0-9.]+) s: \.$/
7
+ tests << [$1, $2.to_f, line]
8
+ end
9
+ end
10
+
11
+ puts "#{limit} Slowest tests"
12
+ puts tests.sort_by { |item|
13
+ item[1]
14
+ }.reverse[0...limit].map { |item|
15
+ "%6.3f: %-s\n" % [item[1], item[0]]
16
+ }
17
+ end
18
+ end
19
+
20
+ namespace :test do
21
+ desc "Find the slowest unit tests"
22
+ task :times, [:limit] do |t, args|
23
+ TestTimes.run `rake test:units TESTOPTS='--verbose'`, args.limit.to_i
24
+ end
25
+ end
@@ -0,0 +1,34 @@
1
+ module FileCreation
2
+ OLDFILE = "old"
3
+ NEWFILE = "new"
4
+
5
+ def create_timed_files(oldfile, *newfiles)
6
+ return if (File.exist?(oldfile) &&
7
+ newfiles.all? { |newfile|
8
+ File.exist?(newfile) && File.stat(newfile).mtime > File.stat(oldfile).mtime
9
+ })
10
+ now = Time.now
11
+
12
+ create_file(oldfile, now - 60)
13
+
14
+ newfiles.each do |newfile|
15
+ create_file(newfile, now)
16
+ end
17
+ end
18
+
19
+ def create_dir(dirname)
20
+ FileUtils.mkdir_p(dirname) unless File.exist?(dirname)
21
+ File.stat(dirname).mtime
22
+ end
23
+
24
+ def create_file(name, file_time=nil)
25
+ create_dir(File.dirname(name))
26
+ FileUtils.touch(name) unless File.exist?(name)
27
+ File.utime(file_time, file_time, name) unless file_time.nil?
28
+ File.stat(name).mtime
29
+ end
30
+
31
+ def delete_file(name)
32
+ File.delete(name) rescue nil
33
+ end
34
+ end
@@ -0,0 +1,130 @@
1
+ require 'rubygems'
2
+ $:.unshift File.expand_path('../../lib', __FILE__)
3
+
4
+ begin
5
+ gem 'minitest', '~> 5'
6
+ rescue Gem::LoadError
7
+ end
8
+
9
+ require 'minitest/autorun'
10
+ require 'rake'
11
+ require 'tmpdir'
12
+ require File.expand_path('../file_creation', __FILE__)
13
+
14
+
15
+ begin
16
+ require_relative '../ruby/envutil'
17
+ require_relative 'support/ruby_runner'
18
+ require_relative 'support/rakefile_definitions'
19
+ rescue NoMethodError, LoadError
20
+ # ruby 1.8
21
+ require 'test/support/ruby_runner'
22
+ require 'test/support/rakefile_definitions'
23
+ end
24
+
25
+ class Rake::TestCase < Minitest::Test
26
+ include FileCreation
27
+
28
+ include Rake::DSL
29
+
30
+ class TaskManager
31
+ include Rake::TaskManager
32
+ end
33
+
34
+ RUBY = defined?(EnvUtil) ? EnvUtil.rubybin : Gem.ruby
35
+
36
+ def setup
37
+ ARGV.clear
38
+
39
+ test_dir = File.basename File.dirname File.expand_path __FILE__
40
+
41
+ @rake_root =
42
+ if test_dir == 'test'
43
+ # rake repository
44
+ File.expand_path '../../', __FILE__
45
+ else
46
+ # ruby repository
47
+ File.expand_path '../../../', __FILE__
48
+ end
49
+
50
+ @verbose = ENV['VERBOSE']
51
+
52
+ @rake_exec = File.join @rake_root, 'bin', 'rake'
53
+ @rake_lib = File.join @rake_root, 'lib'
54
+ @ruby_options = ["-I#{@rake_lib}", "-I."]
55
+
56
+ @orig_pwd = Dir.pwd
57
+ @orig_appdata = ENV['APPDATA']
58
+ @orig_home = ENV['HOME']
59
+ @orig_homedrive = ENV['HOMEDRIVE']
60
+ @orig_homepath = ENV['HOMEPATH']
61
+ @orig_rake_columns = ENV['RAKE_COLUMNS']
62
+ @orig_rake_system = ENV['RAKE_SYSTEM']
63
+ @orig_rakeopt = ENV['RAKEOPT']
64
+ @orig_userprofile = ENV['USERPROFILE']
65
+ ENV.delete 'RAKE_COLUMNS'
66
+ ENV.delete 'RAKE_SYSTEM'
67
+ ENV.delete 'RAKEOPT'
68
+
69
+ tmpdir = Dir.chdir Dir.tmpdir do Dir.pwd end
70
+ @tempdir = File.join tmpdir, "test_rake_#{$$}"
71
+
72
+ FileUtils.mkdir_p @tempdir
73
+
74
+ Dir.chdir @tempdir
75
+
76
+ Rake.application = Rake::Application.new
77
+ Rake::TaskManager.record_task_metadata = true
78
+ RakeFileUtils.verbose_flag = false
79
+ end
80
+
81
+ def teardown
82
+ Dir.chdir @orig_pwd
83
+ FileUtils.rm_rf @tempdir
84
+
85
+ if @orig_appdata
86
+ ENV['APPDATA'] = @orig_appdata
87
+ else
88
+ ENV.delete 'APPDATA'
89
+ end
90
+
91
+ ENV['HOME'] = @orig_home
92
+ ENV['HOMEDRIVE'] = @orig_homedrive
93
+ ENV['HOMEPATH'] = @orig_homepath
94
+ ENV['RAKE_COLUMNS'] = @orig_rake_columns
95
+ ENV['RAKE_SYSTEM'] = @orig_rake_system
96
+ ENV['RAKEOPT'] = @orig_rakeopt
97
+ ENV['USERPROFILE'] = @orig_userprofile
98
+ end
99
+
100
+ def ignore_deprecations
101
+ Rake.application.options.ignore_deprecate = true
102
+ yield
103
+ ensure
104
+ Rake.application.options.ignore_deprecate = false
105
+ end
106
+
107
+ def rake_system_dir
108
+ @system_dir = 'system'
109
+
110
+ FileUtils.mkdir_p @system_dir
111
+
112
+ open File.join(@system_dir, 'sys1.rake'), 'w' do |io|
113
+ io << <<-SYS
114
+ task "sys1" do
115
+ puts "SYS1"
116
+ end
117
+ SYS
118
+ end
119
+
120
+ ENV['RAKE_SYSTEM'] = @system_dir
121
+ end
122
+
123
+ def rakefile(contents)
124
+ open 'Rakefile', 'w' do |io|
125
+ io << contents
126
+ end
127
+ end
128
+
129
+ include RakefileDefinitions
130
+ end