necktie 0.2.1 → 0.3.0
Sign up to get free protection for your applications and to get access to all the features.
- data/README.rdoc +174 -0
- data/bin/necktie +2 -1
- data/lib/necktie/files.rb +29 -0
- data/lib/necktie/rake.rb +127 -0
- data/lib/necktie/services.rb +11 -7
- data/lib/necktie.rb +4 -54
- data/necktie.gemspec +3 -3
- data/vendor/rake/CHANGES +477 -0
- data/vendor/rake/MIT-LICENSE +21 -0
- data/vendor/rake/README.rdoc +194 -0
- data/vendor/rake/Rakefile +421 -0
- data/vendor/rake/TODO +20 -0
- data/vendor/rake/bin/rake +31 -0
- data/vendor/rake/doc/command_line_usage.rdoc +102 -0
- data/vendor/rake/doc/example/Rakefile1 +38 -0
- data/vendor/rake/doc/example/Rakefile2 +35 -0
- data/vendor/rake/doc/example/a.c +6 -0
- data/vendor/rake/doc/example/b.c +6 -0
- data/vendor/rake/doc/example/main.c +11 -0
- data/vendor/rake/doc/glossary.rdoc +51 -0
- data/vendor/rake/doc/jamis.rb +591 -0
- data/vendor/rake/doc/proto_rake.rdoc +127 -0
- data/vendor/rake/doc/rake.1.gz +0 -0
- data/vendor/rake/doc/rakefile.rdoc +566 -0
- data/vendor/rake/doc/rational.rdoc +151 -0
- data/vendor/rake/doc/release_notes/rake-0.4.14.rdoc +23 -0
- data/vendor/rake/doc/release_notes/rake-0.4.15.rdoc +35 -0
- data/vendor/rake/doc/release_notes/rake-0.5.0.rdoc +53 -0
- data/vendor/rake/doc/release_notes/rake-0.5.3.rdoc +78 -0
- data/vendor/rake/doc/release_notes/rake-0.5.4.rdoc +46 -0
- data/vendor/rake/doc/release_notes/rake-0.6.0.rdoc +141 -0
- data/vendor/rake/doc/release_notes/rake-0.7.0.rdoc +119 -0
- data/vendor/rake/doc/release_notes/rake-0.7.1.rdoc +59 -0
- data/vendor/rake/doc/release_notes/rake-0.7.2.rdoc +121 -0
- data/vendor/rake/doc/release_notes/rake-0.7.3.rdoc +47 -0
- data/vendor/rake/doc/release_notes/rake-0.8.0.rdoc +114 -0
- data/vendor/rake/doc/release_notes/rake-0.8.2.rdoc +165 -0
- data/vendor/rake/doc/release_notes/rake-0.8.3.rdoc +112 -0
- data/vendor/rake/doc/release_notes/rake-0.8.4.rdoc +147 -0
- data/vendor/rake/doc/release_notes/rake-0.8.5.rdoc +53 -0
- data/vendor/rake/doc/release_notes/rake-0.8.6.rdoc +55 -0
- data/vendor/rake/doc/release_notes/rake-0.8.7.rdoc +55 -0
- data/vendor/rake/install.rb +88 -0
- data/vendor/rake/lib/rake/alt_system.rb +108 -0
- data/vendor/rake/lib/rake/application.rb +579 -0
- data/vendor/rake/lib/rake/classic_namespace.rb +9 -0
- data/vendor/rake/lib/rake/clean.rb +35 -0
- data/vendor/rake/lib/rake/cloneable.rb +25 -0
- data/vendor/rake/lib/rake/contrib/compositepublisher.rb +24 -0
- data/vendor/rake/lib/rake/contrib/ftptools.rb +153 -0
- data/vendor/rake/lib/rake/contrib/publisher.rb +75 -0
- data/vendor/rake/lib/rake/contrib/rubyforgepublisher.rb +18 -0
- data/vendor/rake/lib/rake/contrib/sshpublisher.rb +47 -0
- data/vendor/rake/lib/rake/contrib/sys.rb +209 -0
- data/vendor/rake/lib/rake/default_loader.rb +10 -0
- data/vendor/rake/lib/rake/dsl.rb +136 -0
- data/vendor/rake/lib/rake/early_time.rb +18 -0
- data/vendor/rake/lib/rake/environment.rb +40 -0
- data/vendor/rake/lib/rake/ext/module.rb +60 -0
- data/vendor/rake/lib/rake/ext/string.rb +165 -0
- data/vendor/rake/lib/rake/ext/time.rb +14 -0
- data/vendor/rake/lib/rake/file_creation_task.rb +24 -0
- data/vendor/rake/lib/rake/file_list.rb +395 -0
- data/vendor/rake/lib/rake/file_task.rb +47 -0
- data/vendor/rake/lib/rake/file_utils.rb +108 -0
- data/vendor/rake/lib/rake/gempackagetask.rb +97 -0
- data/vendor/rake/lib/rake/invocation_chain.rb +51 -0
- data/vendor/rake/lib/rake/invocation_exception_mixin.rb +16 -0
- data/vendor/rake/lib/rake/lib/project.rake +24 -0
- data/vendor/rake/lib/rake/loaders/makefile.rb +44 -0
- data/vendor/rake/lib/rake/multi_task.rb +16 -0
- data/vendor/rake/lib/rake/name_space.rb +25 -0
- data/vendor/rake/lib/rake/packagetask.rb +184 -0
- data/vendor/rake/lib/rake/psuedo_status.rb +24 -0
- data/vendor/rake/lib/rake/rake_file_utils.rb +133 -0
- data/vendor/rake/lib/rake/rake_module.rb +25 -0
- data/vendor/rake/lib/rake/rake_test_loader.rb +15 -0
- data/vendor/rake/lib/rake/rdoctask.rb +209 -0
- data/vendor/rake/lib/rake/ruby182_test_unit_fix.rb +25 -0
- data/vendor/rake/lib/rake/rule_recursion_overflow_error.rb +20 -0
- data/vendor/rake/lib/rake/runtest.rb +23 -0
- data/vendor/rake/lib/rake/task.rb +318 -0
- data/vendor/rake/lib/rake/task_argument_error.rb +7 -0
- data/vendor/rake/lib/rake/task_arguments.rb +78 -0
- data/vendor/rake/lib/rake/task_manager.rb +328 -0
- data/vendor/rake/lib/rake/tasklib.rb +24 -0
- data/vendor/rake/lib/rake/testtask.rb +175 -0
- data/vendor/rake/lib/rake/win32.rb +55 -0
- data/vendor/rake/lib/rake.rb +72 -0
- data/vendor/rake/rake.blurb +19 -0
- data/vendor/rake/rake.gemspec +214 -0
- data/vendor/rake/rakelib/extra.rake +8 -0
- data/vendor/rake/rakelib/publish.rake +22 -0
- data/vendor/rake/rakelib/rbx.rake +82 -0
- data/vendor/rake/rakelib/ruby19.rake +88 -0
- data/vendor/rake/rakelib/tags.rake +18 -0
- data/vendor/rake/test/capture_stdout.rb +26 -0
- data/vendor/rake/test/check_expansion.rb +5 -0
- data/vendor/rake/test/check_no_expansion.rb +5 -0
- data/vendor/rake/test/contrib/test_sys.rb +47 -0
- data/vendor/rake/test/data/chains/Rakefile +15 -0
- data/vendor/rake/test/data/comments/Rakefile +18 -0
- data/vendor/rake/test/data/default/Rakefile +19 -0
- data/vendor/rake/test/data/dryrun/Rakefile +22 -0
- data/vendor/rake/test/data/file_creation_task/Rakefile +33 -0
- data/vendor/rake/test/data/imports/Rakefile +19 -0
- data/vendor/rake/test/data/imports/deps.mf +1 -0
- data/vendor/rake/test/data/multidesc/Rakefile +17 -0
- data/vendor/rake/test/data/namespace/Rakefile +66 -0
- data/vendor/rake/test/data/nosearch/dummy +1 -0
- data/vendor/rake/test/data/rakelib/test1.rb +5 -0
- data/vendor/rake/test/data/rakelib/test2.rake +3 -0
- data/vendor/rake/test/data/rbext/rakefile.rb +3 -0
- data/vendor/rake/test/data/sample.mf +14 -0
- data/vendor/rake/test/data/statusreturn/Rakefile +8 -0
- data/vendor/rake/test/data/sys/sys1.rake +3 -0
- data/vendor/rake/test/data/unittest/Rakefile +1 -0
- data/vendor/rake/test/data/unittest/subdir/README +0 -0
- data/vendor/rake/test/data/verbose/Rakefile +34 -0
- data/vendor/rake/test/filecreation.rb +32 -0
- data/vendor/rake/test/functional/functional_test.rb +15 -0
- data/vendor/rake/test/functional/session_based_tests.rb +442 -0
- data/vendor/rake/test/in_environment.rb +32 -0
- data/vendor/rake/test/lib/application_test.rb +769 -0
- data/vendor/rake/test/lib/clean_test.rb +15 -0
- data/vendor/rake/test/lib/definitions_test.rb +85 -0
- data/vendor/rake/test/lib/dsl_test.rb +41 -0
- data/vendor/rake/test/lib/earlytime_test.rb +35 -0
- data/vendor/rake/test/lib/environment_test.rb +18 -0
- data/vendor/rake/test/lib/extension_test.rb +63 -0
- data/vendor/rake/test/lib/file_creation_task_test.rb +62 -0
- data/vendor/rake/test/lib/file_task_test.rb +143 -0
- data/vendor/rake/test/lib/filelist_test.rb +623 -0
- data/vendor/rake/test/lib/fileutils_test.rb +251 -0
- data/vendor/rake/test/lib/ftp_test.rb +59 -0
- data/vendor/rake/test/lib/invocation_chain_test.rb +81 -0
- data/vendor/rake/test/lib/makefile_loader_test.rb +26 -0
- data/vendor/rake/test/lib/multitask_test.rb +53 -0
- data/vendor/rake/test/lib/namespace_test.rb +55 -0
- data/vendor/rake/test/lib/package_task_test.rb +118 -0
- data/vendor/rake/test/lib/pathmap_test.rb +210 -0
- data/vendor/rake/test/lib/pseudo_status_test.rb +26 -0
- data/vendor/rake/test/lib/rake_test.rb +41 -0
- data/vendor/rake/test/lib/rdoc_task_test.rb +88 -0
- data/vendor/rake/test/lib/require_test.rb +35 -0
- data/vendor/rake/test/lib/rules_test.rb +349 -0
- data/vendor/rake/test/lib/task_arguments_test.rb +89 -0
- data/vendor/rake/test/lib/task_manager_test.rb +173 -0
- data/vendor/rake/test/lib/task_test.rb +376 -0
- data/vendor/rake/test/lib/tasklib_test.rb +12 -0
- data/vendor/rake/test/lib/test_task_test.rb +77 -0
- data/vendor/rake/test/lib/testtask_test.rb +49 -0
- data/vendor/rake/test/lib/top_level_functions_test.rb +86 -0
- data/vendor/rake/test/lib/win32_test.rb +72 -0
- data/vendor/rake/test/rake_test_setup.rb +24 -0
- data/vendor/rake/test/reqfile.rb +3 -0
- data/vendor/rake/test/reqfile2.rb +3 -0
- data/vendor/rake/test/reqfile3.rake +3 -0
- data/vendor/rake/test/shellcommand.rb +3 -0
- data/vendor/rake/test/test_helper.rb +13 -0
- metadata +212 -56
- /data/{rush → vendor/rush}/README.rdoc +0 -0
- /data/{rush → vendor/rush}/Rakefile +0 -0
- /data/{rush → vendor/rush}/VERSION +0 -0
- /data/{rush → vendor/rush}/bin/rush +0 -0
- /data/{rush → vendor/rush}/bin/rushd +0 -0
- /data/{rush → vendor/rush}/lib/rush/access.rb +0 -0
- /data/{rush → vendor/rush}/lib/rush/array_ext.rb +0 -0
- /data/{rush → vendor/rush}/lib/rush/box.rb +0 -0
- /data/{rush → vendor/rush}/lib/rush/commands.rb +0 -0
- /data/{rush → vendor/rush}/lib/rush/config.rb +0 -0
- /data/{rush → vendor/rush}/lib/rush/dir.rb +0 -0
- /data/{rush → vendor/rush}/lib/rush/embeddable_shell.rb +0 -0
- /data/{rush → vendor/rush}/lib/rush/entry.rb +0 -0
- /data/{rush → vendor/rush}/lib/rush/exceptions.rb +0 -0
- /data/{rush → vendor/rush}/lib/rush/file.rb +0 -0
- /data/{rush → vendor/rush}/lib/rush/find_by.rb +0 -0
- /data/{rush → vendor/rush}/lib/rush/fixnum_ext.rb +0 -0
- /data/{rush → vendor/rush}/lib/rush/head_tail.rb +0 -0
- /data/{rush → vendor/rush}/lib/rush/local.rb +0 -0
- /data/{rush → vendor/rush}/lib/rush/process.rb +0 -0
- /data/{rush → vendor/rush}/lib/rush/process_set.rb +0 -0
- /data/{rush → vendor/rush}/lib/rush/remote.rb +0 -0
- /data/{rush → vendor/rush}/lib/rush/search_results.rb +0 -0
- /data/{rush → vendor/rush}/lib/rush/server.rb +0 -0
- /data/{rush → vendor/rush}/lib/rush/shell.rb +0 -0
- /data/{rush → vendor/rush}/lib/rush/ssh_tunnel.rb +0 -0
- /data/{rush → vendor/rush}/lib/rush/string_ext.rb +0 -0
- /data/{rush → vendor/rush}/lib/rush.rb +0 -0
- /data/{rush → vendor/rush}/rush.gemspec +0 -0
- /data/{rush → vendor/rush}/spec/access_spec.rb +0 -0
- /data/{rush → vendor/rush}/spec/array_ext_spec.rb +0 -0
- /data/{rush → vendor/rush}/spec/base.rb +0 -0
- /data/{rush → vendor/rush}/spec/box_spec.rb +0 -0
- /data/{rush → vendor/rush}/spec/commands_spec.rb +0 -0
- /data/{rush → vendor/rush}/spec/config_spec.rb +0 -0
- /data/{rush → vendor/rush}/spec/dir_spec.rb +0 -0
- /data/{rush → vendor/rush}/spec/embeddable_shell_spec.rb +0 -0
- /data/{rush → vendor/rush}/spec/entry_spec.rb +0 -0
- /data/{rush → vendor/rush}/spec/file_spec.rb +0 -0
- /data/{rush → vendor/rush}/spec/find_by_spec.rb +0 -0
- /data/{rush → vendor/rush}/spec/fixnum_ext_spec.rb +0 -0
- /data/{rush → vendor/rush}/spec/local_spec.rb +0 -0
- /data/{rush → vendor/rush}/spec/process_set_spec.rb +0 -0
- /data/{rush → vendor/rush}/spec/process_spec.rb +0 -0
- /data/{rush → vendor/rush}/spec/remote_spec.rb +0 -0
- /data/{rush → vendor/rush}/spec/rush_spec.rb +0 -0
- /data/{rush → vendor/rush}/spec/search_results_spec.rb +0 -0
- /data/{rush → vendor/rush}/spec/shell_spec.rb +0 -0
- /data/{rush → vendor/rush}/spec/ssh_tunnel_spec.rb +0 -0
- /data/{rush → vendor/rush}/spec/string_ext_spec.rb +0 -0
- /data/{session → vendor/session}/lib/session-2.4.0.rb +0 -0
- /data/{session → vendor/session}/lib/session.rb +0 -0
- /data/{session → vendor/session}/test/session.rb +0 -0
@@ -0,0 +1,15 @@
|
|
1
|
+
#!/usr/bin/env ruby
|
2
|
+
|
3
|
+
require 'test/unit'
|
4
|
+
require 'rake'
|
5
|
+
require 'rake/clean'
|
6
|
+
|
7
|
+
class TestClean < Test::Unit::TestCase
|
8
|
+
include Rake
|
9
|
+
def test_clean
|
10
|
+
assert Task['clean'], "Should define clean"
|
11
|
+
assert Task['clobber'], "Should define clobber"
|
12
|
+
assert Task['clobber'].prerequisites.include?("clean"),
|
13
|
+
"Clobber should require clean"
|
14
|
+
end
|
15
|
+
end
|
@@ -0,0 +1,85 @@
|
|
1
|
+
#!/usr/bin/env ruby
|
2
|
+
|
3
|
+
require 'test/unit'
|
4
|
+
require 'fileutils'
|
5
|
+
require 'rake'
|
6
|
+
require 'test/filecreation'
|
7
|
+
require 'test/rake_test_setup'
|
8
|
+
|
9
|
+
######################################################################
|
10
|
+
class TestDefinitions < Test::Unit::TestCase
|
11
|
+
include Rake
|
12
|
+
include TestMethods
|
13
|
+
|
14
|
+
EXISTINGFILE = "testdata/existing"
|
15
|
+
|
16
|
+
def setup
|
17
|
+
Task.clear
|
18
|
+
end
|
19
|
+
|
20
|
+
def test_task
|
21
|
+
done = false
|
22
|
+
task :one => [:two] do done = true end
|
23
|
+
task :two
|
24
|
+
task :three => [:one, :two]
|
25
|
+
check_tasks(:one, :two, :three)
|
26
|
+
assert done, "Should be done"
|
27
|
+
end
|
28
|
+
|
29
|
+
def test_file_task
|
30
|
+
done = false
|
31
|
+
file "testdata/one" => "testdata/two" do done = true end
|
32
|
+
file "testdata/two"
|
33
|
+
file "testdata/three" => ["testdata/one", "testdata/two"]
|
34
|
+
check_tasks("testdata/one", "testdata/two", "testdata/three")
|
35
|
+
assert done, "Should be done"
|
36
|
+
end
|
37
|
+
|
38
|
+
def check_tasks(n1, n2, n3)
|
39
|
+
t = Task[n1]
|
40
|
+
assert Task === t, "Should be a Task"
|
41
|
+
assert_equal n1.to_s, t.name
|
42
|
+
assert_equal [n2.to_s], t.prerequisites.collect{|n| n.to_s}
|
43
|
+
t.invoke
|
44
|
+
t2 = Task[n2]
|
45
|
+
assert_equal FileList[], t2.prerequisites
|
46
|
+
t3 = Task[n3]
|
47
|
+
assert_equal [n1.to_s, n2.to_s], t3.prerequisites.collect{|n|n.to_s}
|
48
|
+
end
|
49
|
+
|
50
|
+
def test_incremental_definitions
|
51
|
+
runs = []
|
52
|
+
task :t1 => [:t2] do runs << "A"; 4321 end
|
53
|
+
task :t1 => [:t3] do runs << "B"; 1234 end
|
54
|
+
task :t1 => [:t3]
|
55
|
+
task :t2
|
56
|
+
task :t3
|
57
|
+
Task[:t1].invoke
|
58
|
+
assert_equal ["A", "B"], runs
|
59
|
+
assert_equal ["t2", "t3"], Task[:t1].prerequisites
|
60
|
+
end
|
61
|
+
|
62
|
+
def test_missing_dependencies
|
63
|
+
task :x => ["testdata/missing"]
|
64
|
+
assert_exception(RuntimeError) { Task[:x].invoke }
|
65
|
+
end
|
66
|
+
|
67
|
+
def test_implicit_file_dependencies
|
68
|
+
runs = []
|
69
|
+
create_existing_file
|
70
|
+
task :y => [EXISTINGFILE] do |t| runs << t.name end
|
71
|
+
Task[:y].invoke
|
72
|
+
assert_equal runs, ['y']
|
73
|
+
end
|
74
|
+
|
75
|
+
private # ----------------------------------------------------------
|
76
|
+
|
77
|
+
def create_existing_file
|
78
|
+
Dir.mkdir File.dirname(EXISTINGFILE) unless
|
79
|
+
File.exist?(File.dirname(EXISTINGFILE))
|
80
|
+
open(EXISTINGFILE, "w") do |f| f.puts "HI" end unless
|
81
|
+
File.exist?(EXISTINGFILE)
|
82
|
+
end
|
83
|
+
|
84
|
+
end
|
85
|
+
|
@@ -0,0 +1,41 @@
|
|
1
|
+
#!/usr/bin/env ruby
|
2
|
+
|
3
|
+
begin
|
4
|
+
require 'rubygems'
|
5
|
+
rescue LoadError
|
6
|
+
# got no gems
|
7
|
+
end
|
8
|
+
|
9
|
+
require 'test/unit'
|
10
|
+
require 'flexmock/test_unit'
|
11
|
+
require 'rake'
|
12
|
+
require 'test/rake_test_setup'
|
13
|
+
|
14
|
+
class DslTest < Test::Unit::TestCase
|
15
|
+
|
16
|
+
def test_namespace_command
|
17
|
+
namespace "n" do
|
18
|
+
task "t"
|
19
|
+
end
|
20
|
+
assert_not_nil Rake::Task["n:t"]
|
21
|
+
end
|
22
|
+
|
23
|
+
def test_namespace_command_with_bad_name
|
24
|
+
ex = assert_raise(ArgumentError) do
|
25
|
+
namespace 1 do end
|
26
|
+
end
|
27
|
+
assert_match(/string/i, ex.message)
|
28
|
+
assert_match(/symbol/i, ex.message)
|
29
|
+
end
|
30
|
+
|
31
|
+
def test_namespace_command_with_a_string_like_object
|
32
|
+
name = Object.new
|
33
|
+
def name.to_str
|
34
|
+
"bob"
|
35
|
+
end
|
36
|
+
namespace name do
|
37
|
+
task "t"
|
38
|
+
end
|
39
|
+
assert_not_nil Rake::Task["bob:t"]
|
40
|
+
end
|
41
|
+
end
|
@@ -0,0 +1,35 @@
|
|
1
|
+
#!/usr/bin/env ruby
|
2
|
+
|
3
|
+
require 'test/unit'
|
4
|
+
require 'rake'
|
5
|
+
|
6
|
+
class TestEarlyTime < Test::Unit::TestCase
|
7
|
+
def test_create
|
8
|
+
early = Rake::EarlyTime.instance
|
9
|
+
time = Time.mktime(1970, 1, 1, 0, 0, 0)
|
10
|
+
assert early <= Time.now
|
11
|
+
assert early < Time.now
|
12
|
+
assert early != Time.now
|
13
|
+
assert Time.now > early
|
14
|
+
assert Time.now >= early
|
15
|
+
assert Time.now != early
|
16
|
+
end
|
17
|
+
|
18
|
+
def test_equality
|
19
|
+
early = Rake::EarlyTime.instance
|
20
|
+
assert_equal early, early, "two early times should be equal"
|
21
|
+
end
|
22
|
+
|
23
|
+
def test_original_time_compare_is_not_messed_up
|
24
|
+
t1 = Time.mktime(1970, 1, 1, 0, 0, 0)
|
25
|
+
t2 = Time.now
|
26
|
+
assert t1 < t2
|
27
|
+
assert t2 > t1
|
28
|
+
assert t1 == t1
|
29
|
+
assert t2 == t2
|
30
|
+
end
|
31
|
+
|
32
|
+
def test_to_s
|
33
|
+
assert_equal "<EARLY TIME>", Rake::EARLY.to_s
|
34
|
+
end
|
35
|
+
end
|
@@ -0,0 +1,18 @@
|
|
1
|
+
#!/usr/bin/env ruby
|
2
|
+
|
3
|
+
require 'test/test_helper'
|
4
|
+
require 'rake/environment'
|
5
|
+
|
6
|
+
class TestEnvironment < Test::Unit::TestCase
|
7
|
+
def test_load_string
|
8
|
+
Rake::Task.clear
|
9
|
+
Rake::Environment.load_string("task :xyz")
|
10
|
+
assert Rake::Task[:xyz], "should have a task named xyz"
|
11
|
+
end
|
12
|
+
|
13
|
+
def test_load_rakefile
|
14
|
+
Rake::Task.clear
|
15
|
+
Rake::Environment.load_rakefile("test/data/default/Rakefile")
|
16
|
+
assert Rake::Task[:default], "Should have a default task"
|
17
|
+
end
|
18
|
+
end
|
@@ -0,0 +1,63 @@
|
|
1
|
+
#!/usr/bin/env ruby
|
2
|
+
|
3
|
+
require 'test/unit'
|
4
|
+
require 'rake'
|
5
|
+
require 'stringio'
|
6
|
+
|
7
|
+
######################################################################
|
8
|
+
class TestExtension < Test::Unit::TestCase
|
9
|
+
|
10
|
+
module Redirect
|
11
|
+
def error_redirect
|
12
|
+
old_err = $stderr
|
13
|
+
result = StringIO.new
|
14
|
+
$stderr = result
|
15
|
+
yield
|
16
|
+
result
|
17
|
+
ensure
|
18
|
+
$stderr = old_err
|
19
|
+
end
|
20
|
+
end
|
21
|
+
|
22
|
+
class Sample
|
23
|
+
extend Redirect
|
24
|
+
|
25
|
+
def duplicate_method
|
26
|
+
:original
|
27
|
+
end
|
28
|
+
|
29
|
+
OK_ERRS = error_redirect do
|
30
|
+
rake_extension("a") do
|
31
|
+
def ok_method
|
32
|
+
end
|
33
|
+
end
|
34
|
+
end
|
35
|
+
|
36
|
+
|
37
|
+
DUP_ERRS = error_redirect do
|
38
|
+
rake_extension("duplicate_method") do
|
39
|
+
def duplicate_method
|
40
|
+
:override
|
41
|
+
end
|
42
|
+
end
|
43
|
+
end
|
44
|
+
end
|
45
|
+
|
46
|
+
def test_methods_actually_exist
|
47
|
+
sample = Sample.new
|
48
|
+
sample.ok_method
|
49
|
+
sample.duplicate_method
|
50
|
+
end
|
51
|
+
|
52
|
+
def test_no_warning_when_defining_ok_method
|
53
|
+
assert_equal "", Sample::OK_ERRS.string
|
54
|
+
end
|
55
|
+
|
56
|
+
def test_extension_complains_when_a_method_that_is_present
|
57
|
+
assert_match(/warning:/i, Sample::DUP_ERRS.string)
|
58
|
+
assert_match(/already exists/i, Sample::DUP_ERRS.string)
|
59
|
+
assert_match(/duplicate_method/i, Sample::DUP_ERRS.string)
|
60
|
+
assert_equal :original, Sample.new.duplicate_method
|
61
|
+
end
|
62
|
+
|
63
|
+
end
|
@@ -0,0 +1,62 @@
|
|
1
|
+
#!/usr/bin/env ruby
|
2
|
+
|
3
|
+
require 'test/unit'
|
4
|
+
require 'fileutils'
|
5
|
+
require 'rake'
|
6
|
+
require 'test/filecreation'
|
7
|
+
|
8
|
+
######################################################################
|
9
|
+
class TestFileCreationTask < Test::Unit::TestCase
|
10
|
+
include Rake
|
11
|
+
include FileCreation
|
12
|
+
|
13
|
+
DUMMY_DIR = 'testdata/dummy_dir'
|
14
|
+
|
15
|
+
def setup
|
16
|
+
Task.clear
|
17
|
+
end
|
18
|
+
|
19
|
+
def teardown
|
20
|
+
FileUtils.rm_rf DUMMY_DIR
|
21
|
+
end
|
22
|
+
|
23
|
+
def test_file_needed
|
24
|
+
create_dir DUMMY_DIR
|
25
|
+
fc_task = Task[DUMMY_DIR]
|
26
|
+
assert_equal DUMMY_DIR, fc_task.name
|
27
|
+
FileUtils.rm_rf fc_task.name
|
28
|
+
assert fc_task.needed?, "file should be needed"
|
29
|
+
FileUtils.mkdir fc_task.name
|
30
|
+
assert_equal nil, fc_task.prerequisites.collect{|n| Task[n].timestamp}.max
|
31
|
+
assert ! fc_task.needed?, "file should not be needed"
|
32
|
+
end
|
33
|
+
|
34
|
+
def test_directory
|
35
|
+
directory DUMMY_DIR
|
36
|
+
fc_task = Task[DUMMY_DIR]
|
37
|
+
assert_equal DUMMY_DIR, fc_task.name
|
38
|
+
assert FileCreationTask === fc_task
|
39
|
+
end
|
40
|
+
|
41
|
+
def test_no_retriggers_on_filecreate_task
|
42
|
+
create_timed_files(OLDFILE, NEWFILE)
|
43
|
+
t1 = Rake.application.intern(FileCreationTask, OLDFILE).enhance([NEWFILE])
|
44
|
+
t2 = Rake.application.intern(FileCreationTask, NEWFILE)
|
45
|
+
assert ! t2.needed?, "Should not need to build new file"
|
46
|
+
assert ! t1.needed?, "Should not need to rebuild old file because of new"
|
47
|
+
end
|
48
|
+
|
49
|
+
def test_no_retriggers_on_file_task
|
50
|
+
create_timed_files(OLDFILE, NEWFILE)
|
51
|
+
t1 = Rake.application.intern(FileCreationTask, OLDFILE).enhance([NEWFILE])
|
52
|
+
t2 = Rake.application.intern(FileCreationTask, NEWFILE)
|
53
|
+
assert ! t2.needed?, "Should not need to build new file"
|
54
|
+
assert ! t1.needed?, "Should not need to rebuild old file because of new"
|
55
|
+
end
|
56
|
+
|
57
|
+
def test_very_early_timestamp
|
58
|
+
t1 = Rake.application.intern(FileCreationTask, OLDFILE)
|
59
|
+
assert t1.timestamp < Time.now
|
60
|
+
assert t1.timestamp < Time.now - 1000000
|
61
|
+
end
|
62
|
+
end
|
@@ -0,0 +1,143 @@
|
|
1
|
+
#!/usr/bin/env ruby
|
2
|
+
|
3
|
+
require 'test/unit'
|
4
|
+
require 'fileutils'
|
5
|
+
require 'rake'
|
6
|
+
require 'test/filecreation'
|
7
|
+
require 'test/rake_test_setup'
|
8
|
+
|
9
|
+
######################################################################
|
10
|
+
class TestFileTask < Test::Unit::TestCase
|
11
|
+
include Rake
|
12
|
+
include FileCreation
|
13
|
+
include TestMethods
|
14
|
+
|
15
|
+
def setup
|
16
|
+
Task.clear
|
17
|
+
@runs = Array.new
|
18
|
+
FileUtils.rm_f NEWFILE
|
19
|
+
FileUtils.rm_f OLDFILE
|
20
|
+
end
|
21
|
+
|
22
|
+
def test_file_need
|
23
|
+
name = "testdata/dummy"
|
24
|
+
file name
|
25
|
+
ftask = Task[name]
|
26
|
+
assert_equal name.to_s, ftask.name
|
27
|
+
File.delete(ftask.name) rescue nil
|
28
|
+
assert ftask.needed?, "file should be needed"
|
29
|
+
open(ftask.name, "w") { |f| f.puts "HI" }
|
30
|
+
assert_equal nil, ftask.prerequisites.collect{|n| Task[n].timestamp}.max
|
31
|
+
assert ! ftask.needed?, "file should not be needed"
|
32
|
+
File.delete(ftask.name) rescue nil
|
33
|
+
end
|
34
|
+
|
35
|
+
def test_file_times_new_depends_on_old
|
36
|
+
create_timed_files(OLDFILE, NEWFILE)
|
37
|
+
|
38
|
+
t1 = Rake.application.intern(FileTask, NEWFILE).enhance([OLDFILE])
|
39
|
+
t2 = Rake.application.intern(FileTask, OLDFILE)
|
40
|
+
assert ! t2.needed?, "Should not need to build old file"
|
41
|
+
assert ! t1.needed?, "Should not need to rebuild new file because of old"
|
42
|
+
end
|
43
|
+
|
44
|
+
def test_file_times_old_depends_on_new
|
45
|
+
create_timed_files(OLDFILE, NEWFILE)
|
46
|
+
|
47
|
+
t1 = Rake.application.intern(FileTask,OLDFILE).enhance([NEWFILE])
|
48
|
+
t2 = Rake.application.intern(FileTask, NEWFILE)
|
49
|
+
assert ! t2.needed?, "Should not need to build new file"
|
50
|
+
preq_stamp = t1.prerequisites.collect{|t| Task[t].timestamp}.max
|
51
|
+
assert_equal t2.timestamp, preq_stamp
|
52
|
+
assert t1.timestamp < preq_stamp, "T1 should be older"
|
53
|
+
assert t1.needed?, "Should need to rebuild old file because of new"
|
54
|
+
end
|
55
|
+
|
56
|
+
def test_file_depends_on_task_depend_on_file
|
57
|
+
create_timed_files(OLDFILE, NEWFILE)
|
58
|
+
|
59
|
+
file NEWFILE => [:obj] do |t| @runs << t.name end
|
60
|
+
task :obj => [OLDFILE] do |t| @runs << t.name end
|
61
|
+
file OLDFILE do |t| @runs << t.name end
|
62
|
+
|
63
|
+
Task[:obj].invoke
|
64
|
+
Task[NEWFILE].invoke
|
65
|
+
assert ! @runs.include?(NEWFILE)
|
66
|
+
end
|
67
|
+
|
68
|
+
def test_existing_file_depends_on_non_existing_file
|
69
|
+
create_file(OLDFILE)
|
70
|
+
delete_file(NEWFILE)
|
71
|
+
file NEWFILE
|
72
|
+
file OLDFILE => NEWFILE
|
73
|
+
assert_nothing_raised do Task[OLDFILE].invoke end
|
74
|
+
end
|
75
|
+
|
76
|
+
# I have currently disabled this test. I'm not convinced that
|
77
|
+
# deleting the file target on failure is always the proper thing to
|
78
|
+
# do. I'm willing to hear input on this topic.
|
79
|
+
def ztest_file_deletes_on_failure
|
80
|
+
task :obj
|
81
|
+
file NEWFILE => [:obj] do |t|
|
82
|
+
FileUtils.touch NEWFILE
|
83
|
+
fail "Ooops"
|
84
|
+
end
|
85
|
+
assert Task[NEWFILE]
|
86
|
+
begin
|
87
|
+
Task[NEWFILE].invoke
|
88
|
+
rescue Exception
|
89
|
+
end
|
90
|
+
assert( ! File.exist?(NEWFILE), "NEWFILE should be deleted")
|
91
|
+
end
|
92
|
+
|
93
|
+
end
|
94
|
+
|
95
|
+
######################################################################
|
96
|
+
class TestDirectoryTask < Test::Unit::TestCase
|
97
|
+
include Rake
|
98
|
+
|
99
|
+
def setup
|
100
|
+
rm_rf "testdata", :verbose=>false
|
101
|
+
end
|
102
|
+
|
103
|
+
def teardown
|
104
|
+
rm_rf "testdata", :verbose=>false
|
105
|
+
end
|
106
|
+
|
107
|
+
def test_directory
|
108
|
+
desc "DESC"
|
109
|
+
directory "testdata/a/b/c"
|
110
|
+
assert_equal FileCreationTask, Task["testdata"].class
|
111
|
+
assert_equal FileCreationTask, Task["testdata/a"].class
|
112
|
+
assert_equal FileCreationTask, Task["testdata/a/b/c"].class
|
113
|
+
assert_nil Task["testdata"].comment
|
114
|
+
assert_equal "DESC", Task["testdata/a/b/c"].comment
|
115
|
+
assert_nil Task["testdata/a/b"].comment
|
116
|
+
verbose(false) {
|
117
|
+
Task['testdata/a/b'].invoke
|
118
|
+
}
|
119
|
+
assert File.exist?("testdata/a/b")
|
120
|
+
assert ! File.exist?("testdata/a/b/c")
|
121
|
+
end
|
122
|
+
|
123
|
+
if Rake::Win32.windows?
|
124
|
+
def test_directory_win32
|
125
|
+
desc "WIN32 DESC"
|
126
|
+
FileUtils.mkdir_p("testdata")
|
127
|
+
Dir.chdir("testdata") do
|
128
|
+
directory 'c:/testdata/a/b/c'
|
129
|
+
assert_equal FileCreationTask, Task['c:/testdata'].class
|
130
|
+
assert_equal FileCreationTask, Task['c:/testdata/a'].class
|
131
|
+
assert_equal FileCreationTask, Task['c:/testdata/a/b/c'].class
|
132
|
+
assert_nil Task['c:/testdata'].comment
|
133
|
+
assert_equal "WIN32 DESC", Task['c:/testdata/a/b/c'].comment
|
134
|
+
assert_nil Task['c:/testdata/a/b'].comment
|
135
|
+
verbose(false) {
|
136
|
+
Task['c:/testdata/a/b'].invoke
|
137
|
+
}
|
138
|
+
assert File.exist?('c:/testdata/a/b')
|
139
|
+
assert ! File.exist?('c:/testdata/a/b/c')
|
140
|
+
end
|
141
|
+
end
|
142
|
+
end
|
143
|
+
end
|