vergissberlin 0.0.5 → 0.0.7

Sign up to get free protection for your applications and to get access to all the features.
Files changed (127) hide show
  1. checksums.yaml +4 -4
  2. data/Rakefile +10 -1
  3. data/bin/vergissberlin +1 -1
  4. data/lib/vergissberlin/version.rb +1 -1
  5. data/test/test_test.rb +7 -0
  6. data/test/utils.rb +37 -0
  7. data/vendor/bundle/bin/rake +23 -0
  8. data/vendor/bundle/bin/vergissberlin +23 -0
  9. data/vendor/bundle/build_info/capistrano_colors-0.5.5.info +1 -0
  10. data/vendor/bundle/build_info/rake-10.0.4.info +1 -0
  11. data/vendor/bundle/gems/capistrano_colors-0.5.5/Manifest +7 -0
  12. data/vendor/bundle/gems/capistrano_colors-0.5.5/README.rdoc +130 -0
  13. data/vendor/bundle/gems/capistrano_colors-0.5.5/Rakefile +1 -0
  14. data/vendor/bundle/gems/capistrano_colors-0.5.5/capistrano_colors.gemspec +33 -0
  15. data/vendor/bundle/gems/capistrano_colors-0.5.5/lib/capistrano_colors/configuration.rb +70 -0
  16. data/vendor/bundle/gems/capistrano_colors-0.5.5/lib/capistrano_colors/logger.rb +72 -0
  17. data/vendor/bundle/gems/capistrano_colors-0.5.5/lib/capistrano_colors.rb +18 -0
  18. data/vendor/bundle/gems/rake-10.0.4/CHANGES +530 -0
  19. data/vendor/bundle/gems/rake-10.0.4/MIT-LICENSE +21 -0
  20. data/vendor/bundle/gems/rake-10.0.4/README.rdoc +187 -0
  21. data/vendor/bundle/gems/rake-10.0.4/Rakefile +375 -0
  22. data/vendor/bundle/gems/rake-10.0.4/TODO +21 -0
  23. data/vendor/bundle/gems/rake-10.0.4/bin/rake +33 -0
  24. data/vendor/bundle/gems/rake-10.0.4/install.rb +90 -0
  25. data/vendor/bundle/gems/rake-10.0.4/lib/rake/alt_system.rb +109 -0
  26. data/vendor/bundle/gems/rake-10.0.4/lib/rake/application.rb +681 -0
  27. data/vendor/bundle/gems/rake-10.0.4/lib/rake/backtrace.rb +19 -0
  28. data/vendor/bundle/gems/rake-10.0.4/lib/rake/clean.rb +32 -0
  29. data/vendor/bundle/gems/rake-10.0.4/lib/rake/cloneable.rb +16 -0
  30. data/vendor/bundle/gems/rake-10.0.4/lib/rake/contrib/compositepublisher.rb +21 -0
  31. data/vendor/bundle/gems/rake-10.0.4/lib/rake/contrib/ftptools.rb +151 -0
  32. data/vendor/bundle/gems/rake-10.0.4/lib/rake/contrib/publisher.rb +73 -0
  33. data/vendor/bundle/gems/rake-10.0.4/lib/rake/contrib/rubyforgepublisher.rb +16 -0
  34. data/vendor/bundle/gems/rake-10.0.4/lib/rake/contrib/sshpublisher.rb +50 -0
  35. data/vendor/bundle/gems/rake-10.0.4/lib/rake/contrib/sys.rb +1 -0
  36. data/vendor/bundle/gems/rake-10.0.4/lib/rake/default_loader.rb +10 -0
  37. data/vendor/bundle/gems/rake-10.0.4/lib/rake/dsl_definition.rb +156 -0
  38. data/vendor/bundle/gems/rake-10.0.4/lib/rake/early_time.rb +18 -0
  39. data/vendor/bundle/gems/rake-10.0.4/lib/rake/ext/core.rb +27 -0
  40. data/vendor/bundle/gems/rake-10.0.4/lib/rake/ext/module.rb +0 -0
  41. data/vendor/bundle/gems/rake-10.0.4/lib/rake/ext/string.rb +168 -0
  42. data/vendor/bundle/gems/rake-10.0.4/lib/rake/ext/time.rb +15 -0
  43. data/vendor/bundle/gems/rake-10.0.4/lib/rake/file_creation_task.rb +24 -0
  44. data/vendor/bundle/gems/rake-10.0.4/lib/rake/file_list.rb +410 -0
  45. data/vendor/bundle/gems/rake-10.0.4/lib/rake/file_task.rb +47 -0
  46. data/vendor/bundle/gems/rake-10.0.4/lib/rake/file_utils.rb +114 -0
  47. data/vendor/bundle/gems/rake-10.0.4/lib/rake/file_utils_ext.rb +143 -0
  48. data/vendor/bundle/gems/rake-10.0.4/lib/rake/gempackagetask.rb +1 -0
  49. data/vendor/bundle/gems/rake-10.0.4/lib/rake/invocation_chain.rb +51 -0
  50. data/vendor/bundle/gems/rake-10.0.4/lib/rake/invocation_exception_mixin.rb +16 -0
  51. data/vendor/bundle/gems/rake-10.0.4/lib/rake/loaders/makefile.rb +40 -0
  52. data/vendor/bundle/gems/rake-10.0.4/lib/rake/multi_task.rb +13 -0
  53. data/vendor/bundle/gems/rake-10.0.4/lib/rake/name_space.rb +25 -0
  54. data/vendor/bundle/gems/rake-10.0.4/lib/rake/packagetask.rb +185 -0
  55. data/vendor/bundle/gems/rake-10.0.4/lib/rake/pathmap.rb +1 -0
  56. data/vendor/bundle/gems/rake-10.0.4/lib/rake/phony.rb +15 -0
  57. data/vendor/bundle/gems/rake-10.0.4/lib/rake/private_reader.rb +20 -0
  58. data/vendor/bundle/gems/rake-10.0.4/lib/rake/promise.rb +99 -0
  59. data/vendor/bundle/gems/rake-10.0.4/lib/rake/pseudo_status.rb +24 -0
  60. data/vendor/bundle/gems/rake-10.0.4/lib/rake/rake_module.rb +37 -0
  61. data/vendor/bundle/gems/rake-10.0.4/lib/rake/rake_test_loader.rb +22 -0
  62. data/vendor/bundle/gems/rake-10.0.4/lib/rake/rdoctask.rb +1 -0
  63. data/vendor/bundle/gems/rake-10.0.4/lib/rake/ruby182_test_unit_fix.rb +25 -0
  64. data/vendor/bundle/gems/rake-10.0.4/lib/rake/rule_recursion_overflow_error.rb +20 -0
  65. data/vendor/bundle/gems/rake-10.0.4/lib/rake/runtest.rb +22 -0
  66. data/vendor/bundle/gems/rake-10.0.4/lib/rake/task.rb +368 -0
  67. data/vendor/bundle/gems/rake-10.0.4/lib/rake/task_argument_error.rb +7 -0
  68. data/vendor/bundle/gems/rake-10.0.4/lib/rake/task_arguments.rb +78 -0
  69. data/vendor/bundle/gems/rake-10.0.4/lib/rake/task_manager.rb +296 -0
  70. data/vendor/bundle/gems/rake-10.0.4/lib/rake/tasklib.rb +22 -0
  71. data/vendor/bundle/gems/rake-10.0.4/lib/rake/testtask.rb +198 -0
  72. data/vendor/bundle/gems/rake-10.0.4/lib/rake/thread_history_display.rb +48 -0
  73. data/vendor/bundle/gems/rake-10.0.4/lib/rake/thread_pool.rb +155 -0
  74. data/vendor/bundle/gems/rake-10.0.4/lib/rake/trace_output.rb +22 -0
  75. data/vendor/bundle/gems/rake-10.0.4/lib/rake/version.rb +13 -0
  76. data/vendor/bundle/gems/rake-10.0.4/lib/rake/win32.rb +55 -0
  77. data/vendor/bundle/gems/rake-10.0.4/lib/rake.rb +71 -0
  78. data/vendor/bundle/gems/rake-10.0.4/test/file_creation.rb +34 -0
  79. data/vendor/bundle/gems/rake-10.0.4/test/helper.rb +562 -0
  80. data/vendor/bundle/gems/rake-10.0.4/test/test_private_reader.rb +42 -0
  81. data/vendor/bundle/gems/rake-10.0.4/test/test_rake.rb +40 -0
  82. data/vendor/bundle/gems/rake-10.0.4/test/test_rake_application.rb +515 -0
  83. data/vendor/bundle/gems/rake-10.0.4/test/test_rake_application_options.rb +455 -0
  84. data/vendor/bundle/gems/rake-10.0.4/test/test_rake_backtrace.rb +89 -0
  85. data/vendor/bundle/gems/rake-10.0.4/test/test_rake_clean.rb +14 -0
  86. data/vendor/bundle/gems/rake-10.0.4/test/test_rake_definitions.rb +80 -0
  87. data/vendor/bundle/gems/rake-10.0.4/test/test_rake_directory_task.rb +57 -0
  88. data/vendor/bundle/gems/rake-10.0.4/test/test_rake_dsl.rb +40 -0
  89. data/vendor/bundle/gems/rake-10.0.4/test/test_rake_early_time.rb +31 -0
  90. data/vendor/bundle/gems/rake-10.0.4/test/test_rake_extension.rb +59 -0
  91. data/vendor/bundle/gems/rake-10.0.4/test/test_rake_file_creation_task.rb +56 -0
  92. data/vendor/bundle/gems/rake-10.0.4/test/test_rake_file_list.rb +628 -0
  93. data/vendor/bundle/gems/rake-10.0.4/test/test_rake_file_list_path_map.rb +8 -0
  94. data/vendor/bundle/gems/rake-10.0.4/test/test_rake_file_task.rb +122 -0
  95. data/vendor/bundle/gems/rake-10.0.4/test/test_rake_file_utils.rb +305 -0
  96. data/vendor/bundle/gems/rake-10.0.4/test/test_rake_ftp_file.rb +59 -0
  97. data/vendor/bundle/gems/rake-10.0.4/test/test_rake_functional.rb +496 -0
  98. data/vendor/bundle/gems/rake-10.0.4/test/test_rake_invocation_chain.rb +52 -0
  99. data/vendor/bundle/gems/rake-10.0.4/test/test_rake_makefile_loader.rb +44 -0
  100. data/vendor/bundle/gems/rake-10.0.4/test/test_rake_multi_task.rb +59 -0
  101. data/vendor/bundle/gems/rake-10.0.4/test/test_rake_name_space.rb +43 -0
  102. data/vendor/bundle/gems/rake-10.0.4/test/test_rake_package_task.rb +79 -0
  103. data/vendor/bundle/gems/rake-10.0.4/test/test_rake_path_map.rb +157 -0
  104. data/vendor/bundle/gems/rake-10.0.4/test/test_rake_path_map_explode.rb +34 -0
  105. data/vendor/bundle/gems/rake-10.0.4/test/test_rake_path_map_partial.rb +18 -0
  106. data/vendor/bundle/gems/rake-10.0.4/test/test_rake_pseudo_status.rb +21 -0
  107. data/vendor/bundle/gems/rake-10.0.4/test/test_rake_rake_test_loader.rb +21 -0
  108. data/vendor/bundle/gems/rake-10.0.4/test/test_rake_reduce_compat.rb +30 -0
  109. data/vendor/bundle/gems/rake-10.0.4/test/test_rake_require.rb +40 -0
  110. data/vendor/bundle/gems/rake-10.0.4/test/test_rake_rules.rb +327 -0
  111. data/vendor/bundle/gems/rake-10.0.4/test/test_rake_task.rb +340 -0
  112. data/vendor/bundle/gems/rake-10.0.4/test/test_rake_task_argument_parsing.rb +103 -0
  113. data/vendor/bundle/gems/rake-10.0.4/test/test_rake_task_arguments.rb +88 -0
  114. data/vendor/bundle/gems/rake-10.0.4/test/test_rake_task_lib.rb +9 -0
  115. data/vendor/bundle/gems/rake-10.0.4/test/test_rake_task_manager.rb +157 -0
  116. data/vendor/bundle/gems/rake-10.0.4/test/test_rake_task_manager_argument_resolution.rb +19 -0
  117. data/vendor/bundle/gems/rake-10.0.4/test/test_rake_task_with_arguments.rb +171 -0
  118. data/vendor/bundle/gems/rake-10.0.4/test/test_rake_test_task.rb +120 -0
  119. data/vendor/bundle/gems/rake-10.0.4/test/test_rake_thread_pool.rb +122 -0
  120. data/vendor/bundle/gems/rake-10.0.4/test/test_rake_top_level_functions.rb +71 -0
  121. data/vendor/bundle/gems/rake-10.0.4/test/test_rake_win32.rb +72 -0
  122. data/vendor/bundle/gems/rake-10.0.4/test/test_thread_history_display.rb +91 -0
  123. data/vendor/bundle/gems/rake-10.0.4/test/test_trace_output.rb +50 -0
  124. data/vendor/bundle/specifications/capistrano_colors-0.5.5.gemspec +32 -0
  125. data/vendor/bundle/specifications/rake-10.0.4.gemspec +35 -0
  126. data/vergissberlin.gemspec +4 -2
  127. metadata +125 -2
@@ -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 { |k,v| "#{k}:#{v}" }.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,155 @@
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.
11
+ # The parameter is the size 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
+ # <tt>Thread#new</tt>) The return value is an object representing
29
+ # a future which has been created and added to the queue in the
30
+ # pool. Sending <tt>#value</tt> 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. Thread pool contains #{@threads.count} threads\n"
54
+ $stderr.print "Current Thread #{Thread.current} status = #{Thread.current.status}\n"
55
+ $stderr.puts e.backtrace.join("\n")
56
+ @threads.each do |t|
57
+ $stderr.print "Thread #{t} status = #{t.status}\n"
58
+ # 1.8 doesn't support Thread#backtrace
59
+ $stderr.puts t.backtrace.join("\n") if t.respond_to? :backtrace
60
+ end
61
+ raise e
62
+ end
63
+ end
64
+ end
65
+
66
+ # Enable the gathering of history events.
67
+ def gather_history #:nodoc:
68
+ @history_start_time = Time.now if @history_start_time.nil?
69
+ end
70
+
71
+ # Return a array of history events for the thread pool.
72
+ #
73
+ # History gathering must be enabled to be able to see the events
74
+ # (see #gather_history). Best to call this when the job is
75
+ # complete (i.e. after ThreadPool#join is called).
76
+ def history # :nodoc:
77
+ @history_mon.synchronize { @history.dup }.
78
+ sort_by { |i| i[:time] }.
79
+ each { |i| i[:time] -= @history_start_time }
80
+ end
81
+
82
+ # Return a hash of always collected statistics for the thread pool.
83
+ def statistics # :nodoc:
84
+ {
85
+ :total_threads_in_play => @total_threads_in_play,
86
+ :max_active_threads => @max_active_threads,
87
+ }
88
+ end
89
+
90
+ private
91
+
92
+ # processes one item on the queue. Returns true if there was an
93
+ # item to process, false if there was no item
94
+ def process_queue_item #:nodoc:
95
+ return false if @queue.empty?
96
+
97
+ # Even though we just asked if the queue was empty, it
98
+ # still could have had an item which by this statement
99
+ # is now gone. For this reason we pass true to Queue#deq
100
+ # because we will sleep indefinitely if it is empty.
101
+ promise = @queue.deq(true)
102
+ stat :dequeued, :item_id => promise.object_id
103
+ promise.work
104
+ return true
105
+
106
+ rescue ThreadError # this means the queue is empty
107
+ false
108
+ end
109
+
110
+ def start_thread # :nodoc:
111
+ @threads_mon.synchronize do
112
+ next unless @threads.count < @max_active_threads
113
+
114
+ t = Thread.new do
115
+ begin
116
+ while @threads.count <= @max_active_threads
117
+ break unless process_queue_item
118
+ end
119
+ ensure
120
+ @threads_mon.synchronize do
121
+ @threads.delete Thread.current
122
+ stat :ended, :thread_count => @threads.count
123
+ @join_cond.broadcast if @threads.empty?
124
+ end
125
+ end
126
+ end
127
+ @threads << t
128
+ stat :spawned, :new_thread => t.object_id, :thread_count => @threads.count
129
+ @total_threads_in_play = @threads.count if @threads.count > @total_threads_in_play
130
+ end
131
+ end
132
+
133
+ def stat(event, data=nil) # :nodoc:
134
+ return if @history_start_time.nil?
135
+ info = {
136
+ :event => event,
137
+ :data => data,
138
+ :time => Time.now,
139
+ :thread => Thread.current.object_id,
140
+ }
141
+ @history_mon.synchronize { @history << info }
142
+ end
143
+
144
+ # for testing only
145
+
146
+ def __queue__ # :nodoc:
147
+ @queue
148
+ end
149
+
150
+ def __threads__ # :nodoc:
151
+ @threads.dup
152
+ end
153
+ end
154
+
155
+ end
@@ -0,0 +1,22 @@
1
+ module Rake
2
+ module TraceOutput
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,13 @@
1
+ module Rake
2
+ VERSION = '10.0.4'
3
+
4
+ module Version # :nodoc: all
5
+ MAJOR, MINOR, BUILD, = Rake::VERSION.split '.'
6
+
7
+ NUMBERS = [
8
+ MAJOR,
9
+ MINOR,
10
+ BUILD,
11
+ ]
12
+ end
13
+ end
@@ -0,0 +1,55 @@
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
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, "Unable to determine home path environment variable." if
44
+ win32_shared_path.nil? or win32_shared_path.empty?
45
+ normalize(File.join(win32_shared_path, 'Rake'))
46
+ end
47
+
48
+ # Normalize a win32 path so that the slashes are all forward slashes.
49
+ def normalize(path)
50
+ path.gsub(/\\/, '/')
51
+ end
52
+
53
+ end
54
+ end
55
+ end
@@ -0,0 +1,71 @@
1
+ #--
2
+
3
+ # Copyright 2003-2010 by Jim Weirich (jim.weirich@gmail.com)
4
+ #
5
+ # Permission is hereby granted, free of charge, to any person obtaining a copy
6
+ # of this software and associated documentation files (the "Software"), to
7
+ # deal in the Software without restriction, including without limitation the
8
+ # rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
9
+ # sell copies of the Software, and to permit persons to whom the Software is
10
+ # furnished to do so, subject to the following conditions:
11
+ #
12
+ # The above copyright notice and this permission notice shall be included in
13
+ # all copies or substantial portions of the Software.
14
+ #
15
+ # THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16
+ # IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17
+ # FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18
+ # AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19
+ # LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
20
+ # FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
21
+ # IN THE SOFTWARE.
22
+ #++
23
+
24
+ require 'rake/version'
25
+
26
+ # :stopdoc:
27
+ RAKEVERSION = Rake::VERSION
28
+ # :startdoc:
29
+
30
+ require 'rbconfig'
31
+ require 'fileutils'
32
+ require 'singleton'
33
+ require 'monitor'
34
+ require 'optparse'
35
+ require 'ostruct'
36
+
37
+ require 'rake/ext/module'
38
+ require 'rake/ext/string'
39
+ require 'rake/ext/time'
40
+
41
+ require 'rake/win32'
42
+
43
+ require 'rake/task_argument_error'
44
+ require 'rake/rule_recursion_overflow_error'
45
+ require 'rake/rake_module'
46
+ require 'rake/trace_output'
47
+ require 'rake/pseudo_status'
48
+ require 'rake/task_arguments'
49
+ require 'rake/invocation_chain'
50
+ require 'rake/task'
51
+ require 'rake/file_task'
52
+ require 'rake/file_creation_task'
53
+ require 'rake/multi_task'
54
+ require 'rake/dsl_definition'
55
+ require 'rake/file_utils_ext'
56
+ require 'rake/file_list'
57
+ require 'rake/default_loader'
58
+ require 'rake/early_time'
59
+ require 'rake/name_space'
60
+ require 'rake/task_manager'
61
+ require 'rake/application'
62
+ require 'rake/backtrace'
63
+
64
+ $trace = false
65
+
66
+ # :stopdoc:
67
+ #
68
+ # Some top level Constants.
69
+
70
+ FileList = Rake::FileList
71
+ RakeFileUtils = Rake::FileUtilsExt
@@ -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,562 @@
1
+ require 'rubygems'
2
+ $:.unshift File.expand_path('../../lib', __FILE__)
3
+
4
+ begin
5
+ gem 'minitest'
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
+ begin
15
+ require_relative '../ruby/envutil'
16
+ rescue NoMethodError, LoadError
17
+ # for ruby trunk
18
+ end
19
+
20
+ class Rake::TestCase < MiniTest::Unit::TestCase
21
+ include FileCreation
22
+
23
+ include Rake::DSL
24
+
25
+ class TaskManager
26
+ include Rake::TaskManager
27
+ end
28
+
29
+ RUBY = defined?(EnvUtil) ? EnvUtil.rubybin : Gem.ruby
30
+
31
+ def setup
32
+ ARGV.clear
33
+
34
+ test_dir = File.basename File.dirname File.expand_path __FILE__
35
+
36
+ @rake_root = if test_dir == 'test' then
37
+ # rake repository
38
+ File.expand_path '../../', __FILE__
39
+ else
40
+ # ruby repository
41
+ File.expand_path '../../../', __FILE__
42
+ end
43
+
44
+ @rake_exec = File.join @rake_root, 'bin', 'rake'
45
+ @rake_lib = File.join @rake_root, 'lib'
46
+
47
+ @orig_PWD = Dir.pwd
48
+ @orig_APPDATA = ENV['APPDATA']
49
+ @orig_HOME = ENV['HOME']
50
+ @orig_HOMEDRIVE = ENV['HOMEDRIVE']
51
+ @orig_HOMEPATH = ENV['HOMEPATH']
52
+ @orig_RAKE_COLUMNS = ENV['RAKE_COLUMNS']
53
+ @orig_RAKE_SYSTEM = ENV['RAKE_SYSTEM']
54
+ @orig_RAKEOPT = ENV['RAKEOPT']
55
+ @orig_USERPROFILE = ENV['USERPROFILE']
56
+ ENV.delete 'RAKE_COLUMNS'
57
+ ENV.delete 'RAKE_SYSTEM'
58
+ ENV.delete 'RAKEOPT'
59
+
60
+ tmpdir = Dir.chdir Dir.tmpdir do Dir.pwd end
61
+ @tempdir = File.join tmpdir, "test_rake_#{$$}"
62
+
63
+ FileUtils.mkdir_p @tempdir
64
+
65
+ Dir.chdir @tempdir
66
+
67
+ Rake.application = Rake::Application.new
68
+ Rake::TaskManager.record_task_metadata = true
69
+ RakeFileUtils.verbose_flag = false
70
+ end
71
+
72
+ def teardown
73
+ Dir.chdir @orig_PWD
74
+ FileUtils.rm_rf @tempdir
75
+
76
+ if @orig_APPDATA then
77
+ ENV['APPDATA'] = @orig_APPDATA
78
+ else
79
+ ENV.delete 'APPDATA'
80
+ end
81
+
82
+ ENV['HOME'] = @orig_HOME
83
+ ENV['HOMEDRIVE'] = @orig_HOMEDRIVE
84
+ ENV['HOMEPATH'] = @orig_HOMEPATH
85
+ ENV['RAKE_COLUMNS'] = @orig_RAKE_COLUMNS
86
+ ENV['RAKE_SYSTEM'] = @orig_RAKE_SYSTEM
87
+ ENV['RAKEOPT'] = @orig_RAKEOPT
88
+ ENV['USERPROFILE'] = @orig_USERPROFILE
89
+ end
90
+
91
+ def ignore_deprecations
92
+ Rake.application.options.ignore_deprecate = true
93
+ yield
94
+ ensure
95
+ Rake.application.options.ignore_deprecate = false
96
+ end
97
+
98
+ def rake_system_dir
99
+ @system_dir = 'system'
100
+
101
+ FileUtils.mkdir_p @system_dir
102
+
103
+ open File.join(@system_dir, 'sys1.rake'), 'w' do |io|
104
+ io << <<-SYS
105
+ task "sys1" do
106
+ puts "SYS1"
107
+ end
108
+ SYS
109
+ end
110
+
111
+ ENV['RAKE_SYSTEM'] = @system_dir
112
+ end
113
+
114
+ def rakefile contents
115
+ open 'Rakefile', 'w' do |io|
116
+ io << contents
117
+ end
118
+ end
119
+
120
+ def rakefile_access
121
+ rakefile <<-ACCESS
122
+ TOP_LEVEL_CONSTANT = 0
123
+
124
+ def a_top_level_function
125
+ end
126
+
127
+ task :default => [:work, :obj, :const]
128
+
129
+ task :work do
130
+ begin
131
+ a_top_level_function
132
+ puts "GOOD:M Top level methods can be called in tasks"
133
+ rescue NameError => ex
134
+ puts "BAD:M Top level methods can not be called in tasks"
135
+ end
136
+ end
137
+
138
+ # TODO: remove `disabled_' when DeprecatedObjectDSL removed
139
+ task :obj
140
+ task :disabled_obj do
141
+ begin
142
+ Object.new.instance_eval { task :xyzzy }
143
+ puts "BAD:D Rake DSL are polluting objects"
144
+ rescue StandardError => ex
145
+ puts "GOOD:D Rake DSL are not polluting objects"
146
+ end
147
+ end
148
+
149
+ task :const do
150
+ begin
151
+ TOP_LEVEL_CONSTANT
152
+ puts "GOOD:C Top level constants are available in tasks"
153
+ rescue StandardError => ex
154
+ puts "BAD:C Top level constants are NOT available in tasks"
155
+ end
156
+ end
157
+ ACCESS
158
+ end
159
+
160
+ def rakefile_chains
161
+ rakefile <<-DEFAULT
162
+ task :default => "play.app"
163
+
164
+ file "play.scpt" => "base" do |t|
165
+ cp t.prerequisites.first, t.name
166
+ end
167
+
168
+ rule ".app" => ".scpt" do |t|
169
+ cp t.source, t.name
170
+ end
171
+
172
+ file 'base' do
173
+ touch 'base'
174
+ end
175
+ DEFAULT
176
+ end
177
+
178
+ def rakefile_comments
179
+ rakefile <<-COMMENTS
180
+ # comment for t1
181
+ task :t1 do
182
+ end
183
+
184
+ # no comment or task because there's a blank line
185
+
186
+ task :t2 do
187
+ end
188
+
189
+ desc "override comment for t3"
190
+ # this is not the description
191
+ multitask :t3 do
192
+ end
193
+
194
+ # this is not the description
195
+ desc "override comment for t4"
196
+ file :t4 do
197
+ end
198
+ COMMENTS
199
+ end
200
+
201
+ def rakefile_default
202
+ rakefile <<-DEFAULT
203
+ if ENV['TESTTOPSCOPE']
204
+ puts "TOPSCOPE"
205
+ end
206
+
207
+ task :default do
208
+ puts "DEFAULT"
209
+ end
210
+
211
+ task :other => [:default] do
212
+ puts "OTHER"
213
+ end
214
+
215
+ task :task_scope do
216
+ if ENV['TESTTASKSCOPE']
217
+ puts "TASKSCOPE"
218
+ end
219
+ end
220
+ DEFAULT
221
+ end
222
+
223
+ def rakefile_dryrun
224
+ rakefile <<-DRYRUN
225
+ task :default => ["temp_main"]
226
+
227
+ file "temp_main" => [:all_apps] do touch "temp_main" end
228
+
229
+ task :all_apps => [:one, :two]
230
+ task :one => ["temp_one"]
231
+ task :two => ["temp_two"]
232
+
233
+ file "temp_one" do |t|
234
+ touch "temp_one"
235
+ end
236
+ file "temp_two" do |t|
237
+ touch "temp_two"
238
+ end
239
+
240
+ task :clean do
241
+ ["temp_one", "temp_two", "temp_main"].each do |file|
242
+ rm_f file
243
+ end
244
+ end
245
+ DRYRUN
246
+
247
+ FileUtils.touch 'temp_main'
248
+ FileUtils.touch 'temp_two'
249
+ end
250
+
251
+ def rakefile_extra
252
+ rakefile 'task :default'
253
+
254
+ FileUtils.mkdir_p 'rakelib'
255
+
256
+ open File.join('rakelib', 'extra.rake'), 'w' do |io|
257
+ io << <<-EXTRA_RAKE
258
+ # Added for testing
259
+
260
+ namespace :extra do
261
+ desc "An Extra Task"
262
+ task :extra do
263
+ puts "Read all about it"
264
+ end
265
+ end
266
+ EXTRA_RAKE
267
+ end
268
+ end
269
+
270
+ def rakefile_file_creation
271
+ rakefile <<-'FILE_CREATION'
272
+ N = 2
273
+
274
+ task :default => :run
275
+
276
+ BUILD_DIR = 'build'
277
+ task :clean do
278
+ rm_rf 'build'
279
+ rm_rf 'src'
280
+ end
281
+
282
+ task :run
283
+
284
+ TARGET_DIR = 'build/copies'
285
+
286
+ FileList['src/*'].each do |src|
287
+ directory TARGET_DIR
288
+ target = File.join TARGET_DIR, File.basename(src)
289
+ file target => [src, TARGET_DIR] do
290
+ cp src, target
291
+ # sleep 3 if src !~ /foo#{N-1}$/ # I'm commenting out this sleep, it doesn't seem to do anything.
292
+ end
293
+ task :run => target
294
+ end
295
+
296
+ task :prep => :clean do
297
+ mkdir_p 'src'
298
+ N.times do |n|
299
+ touch "src/foo#{n}"
300
+ end
301
+ end
302
+ FILE_CREATION
303
+ end
304
+
305
+ def rakefile_imports
306
+ rakefile <<-IMPORTS
307
+ require 'rake/loaders/makefile'
308
+
309
+ task :default
310
+
311
+ task :other do
312
+ puts "OTHER"
313
+ end
314
+
315
+ file "dynamic_deps" do |t|
316
+ open(t.name, "w") do |f| f.puts "puts 'DYNAMIC'" end
317
+ end
318
+
319
+ import "dynamic_deps"
320
+ import "static_deps"
321
+ import "static_deps"
322
+ import "deps.mf"
323
+ puts "FIRST"
324
+ IMPORTS
325
+
326
+ open 'deps.mf', 'w' do |io|
327
+ io << <<-DEPS
328
+ default: other
329
+ DEPS
330
+ end
331
+
332
+ open "static_deps", "w" do |f|
333
+ f.puts 'puts "STATIC"'
334
+ end
335
+ end
336
+
337
+ def rakefile_multidesc
338
+ rakefile <<-MULTIDESC
339
+ task :b
340
+
341
+ desc "A"
342
+ task :a
343
+
344
+ desc "B"
345
+ task :b
346
+
347
+ desc "A2"
348
+ task :a
349
+
350
+ task :c
351
+
352
+ desc "xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx"
353
+ task :d
354
+ MULTIDESC
355
+ end
356
+
357
+ def rakefile_namespace
358
+ rakefile <<-NAMESPACE
359
+ desc "copy"
360
+ task :copy do
361
+ puts "COPY"
362
+ end
363
+
364
+ namespace "nest" do
365
+ desc "nest copy"
366
+ task :copy do
367
+ puts "NEST COPY"
368
+ end
369
+ task :xx => :copy
370
+ end
371
+
372
+ anon_ns = namespace do
373
+ desc "anonymous copy task"
374
+ task :copy do
375
+ puts "ANON COPY"
376
+ end
377
+ end
378
+
379
+ desc "Top level task to run the anonymous version of copy"
380
+ task :anon => anon_ns[:copy]
381
+
382
+ namespace "very" do
383
+ namespace "nested" do
384
+ task "run" => "rake:copy"
385
+ end
386
+ end
387
+
388
+ namespace "a" do
389
+ desc "Run task in the 'a' namespace"
390
+ task "run" do
391
+ puts "IN A"
392
+ end
393
+ end
394
+
395
+ namespace "b" do
396
+ desc "Run task in the 'b' namespace"
397
+ task "run" => "a:run" do
398
+ puts "IN B"
399
+ end
400
+ end
401
+
402
+ namespace "file1" do
403
+ file "xyz.rb" do
404
+ puts "XYZ1"
405
+ end
406
+ end
407
+
408
+ namespace "file2" do
409
+ file "xyz.rb" do
410
+ puts "XYZ2"
411
+ end
412
+ end
413
+
414
+ namespace "scopedep" do
415
+ task :prepare do
416
+ touch "scopedep.rb"
417
+ puts "PREPARE"
418
+ end
419
+ file "scopedep.rb" => [:prepare] do
420
+ puts "SCOPEDEP"
421
+ end
422
+ end
423
+ NAMESPACE
424
+ end
425
+
426
+ def rakefile_nosearch
427
+ FileUtils.touch 'dummy'
428
+ end
429
+
430
+ def rakefile_rakelib
431
+ FileUtils.mkdir_p 'rakelib'
432
+
433
+ Dir.chdir 'rakelib' do
434
+ open 'test1.rb', 'w' do |io|
435
+ io << <<-TEST1
436
+ task :default do
437
+ puts "TEST1"
438
+ end
439
+ TEST1
440
+ end
441
+
442
+ open 'test2.rake', 'w' do |io|
443
+ io << <<-TEST1
444
+ task :default do
445
+ puts "TEST2"
446
+ end
447
+ TEST1
448
+ end
449
+ end
450
+ end
451
+
452
+ def rakefile_rbext
453
+ open 'rakefile.rb', 'w' do |io|
454
+ io << 'task :default do puts "OK" end'
455
+ end
456
+ end
457
+
458
+ def rakefile_unittest
459
+ rakefile '# Empty Rakefile for Unit Test'
460
+
461
+ readme = File.join 'subdir', 'README'
462
+ FileUtils.mkdir_p File.dirname readme
463
+
464
+ FileUtils.touch readme
465
+ end
466
+
467
+ def rakefile_verbose
468
+ rakefile <<-VERBOSE
469
+ task :standalone_verbose_true do
470
+ verbose true
471
+ sh "#{RUBY} -e '0'"
472
+ end
473
+
474
+ task :standalone_verbose_false do
475
+ verbose false
476
+ sh "#{RUBY} -e '0'"
477
+ end
478
+
479
+ task :inline_verbose_default do
480
+ sh "#{RUBY} -e '0'"
481
+ end
482
+
483
+ task :inline_verbose_false do
484
+ sh "#{RUBY} -e '0'", :verbose => false
485
+ end
486
+
487
+ task :inline_verbose_true do
488
+ sh "#{RUBY} -e '0'", :verbose => true
489
+ end
490
+
491
+ task :block_verbose_true do
492
+ verbose(true) do
493
+ sh "#{RUBY} -e '0'"
494
+ end
495
+ end
496
+
497
+ task :block_verbose_false do
498
+ verbose(false) do
499
+ sh "#{RUBY} -e '0'"
500
+ end
501
+ end
502
+ VERBOSE
503
+ end
504
+
505
+ def rakefile_test_signal
506
+ rakefile <<-TEST_SIGNAL
507
+ require 'rake/testtask'
508
+
509
+ Rake::TestTask.new(:a) do |t|
510
+ t.test_files = ['a_test.rb']
511
+ end
512
+
513
+ Rake::TestTask.new(:b) do |t|
514
+ t.test_files = ['b_test.rb']
515
+ end
516
+
517
+ task :test do
518
+ Rake::Task[:a].invoke
519
+ Rake::Task[:b].invoke
520
+ end
521
+
522
+ task :default => :test
523
+ TEST_SIGNAL
524
+ open 'a_test.rb', 'w' do |io|
525
+ io << 'puts "ATEST"' << "\n"
526
+ io << '$stdout.flush' << "\n"
527
+ io << 'Process.kill("TERM", $$)' << "\n"
528
+ end
529
+ open 'b_test.rb', 'w' do |io|
530
+ io << 'puts "BTEST"' << "\n"
531
+ io << '$stdout.flush' << "\n"
532
+ end
533
+ end
534
+
535
+ def rakefile_failing_test_task
536
+ rakefile <<-TEST_TASK
537
+ require 'rake/testtask'
538
+
539
+ task :default => :test
540
+ Rake::TestTask.new(:test) do |t|
541
+ t.test_files = ['a_test.rb']
542
+ end
543
+ TEST_TASK
544
+ open 'a_test.rb', 'w' do |io|
545
+ io << "require 'minitest/autorun'\n"
546
+ io << "class ExitTaskTest < MiniTest::Unit::TestCase\n"
547
+ io << " def test_exit\n"
548
+ io << " assert false, 'this should fail'\n"
549
+ io << " end\n"
550
+ io << "end\n"
551
+ end
552
+ end
553
+
554
+ def rakefile_stand_alone_filelist
555
+ open 'stand_alone_filelist.rb', 'w' do |io|
556
+ io << "require 'rake/file_list'\n"
557
+ io << "FL = Rake::FileList['*.rb']\n"
558
+ io << "puts FL\n"
559
+ end
560
+ end
561
+
562
+ end