assaf-buildr 1.3.3

Sign up to get free protection for your applications and to get access to all the features.
Files changed (163) hide show
  1. data/CHANGELOG +887 -0
  2. data/DISCLAIMER +7 -0
  3. data/LICENSE +176 -0
  4. data/NOTICE +26 -0
  5. data/README.rdoc +146 -0
  6. data/Rakefile +62 -0
  7. data/_buildr +38 -0
  8. data/addon/buildr/antlr.rb +65 -0
  9. data/addon/buildr/cobertura.rb +236 -0
  10. data/addon/buildr/emma.rb +238 -0
  11. data/addon/buildr/hibernate.rb +142 -0
  12. data/addon/buildr/javacc.rb +85 -0
  13. data/addon/buildr/jdepend.rb +60 -0
  14. data/addon/buildr/jetty.rb +248 -0
  15. data/addon/buildr/jibx.rb +86 -0
  16. data/addon/buildr/nailgun.rb +817 -0
  17. data/addon/buildr/openjpa.rb +90 -0
  18. data/addon/buildr/org/apache/buildr/BuildrNail$Main.class +0 -0
  19. data/addon/buildr/org/apache/buildr/BuildrNail.class +0 -0
  20. data/addon/buildr/org/apache/buildr/BuildrNail.java +41 -0
  21. data/addon/buildr/org/apache/buildr/JettyWrapper$1.class +0 -0
  22. data/addon/buildr/org/apache/buildr/JettyWrapper$BuildrHandler.class +0 -0
  23. data/addon/buildr/org/apache/buildr/JettyWrapper.class +0 -0
  24. data/addon/buildr/org/apache/buildr/JettyWrapper.java +144 -0
  25. data/addon/buildr/xmlbeans.rb +93 -0
  26. data/bin/buildr +28 -0
  27. data/buildr.buildfile +53 -0
  28. data/buildr.gemspec +58 -0
  29. data/doc/css/default.css +228 -0
  30. data/doc/css/print.css +100 -0
  31. data/doc/css/syntax.css +52 -0
  32. data/doc/images/apache-incubator-logo.png +0 -0
  33. data/doc/images/buildr-hires.png +0 -0
  34. data/doc/images/buildr.png +0 -0
  35. data/doc/images/favicon.png +0 -0
  36. data/doc/images/growl-icon.tiff +0 -0
  37. data/doc/images/note.png +0 -0
  38. data/doc/images/project-structure.png +0 -0
  39. data/doc/images/tip.png +0 -0
  40. data/doc/images/zbuildr.tif +0 -0
  41. data/doc/pages/artifacts.textile +207 -0
  42. data/doc/pages/building.textile +240 -0
  43. data/doc/pages/contributing.textile +208 -0
  44. data/doc/pages/download.textile +62 -0
  45. data/doc/pages/extending.textile +175 -0
  46. data/doc/pages/getting_started.textile +273 -0
  47. data/doc/pages/index.textile +42 -0
  48. data/doc/pages/languages.textile +407 -0
  49. data/doc/pages/mailing_lists.textile +17 -0
  50. data/doc/pages/more_stuff.textile +286 -0
  51. data/doc/pages/packaging.textile +427 -0
  52. data/doc/pages/projects.textile +274 -0
  53. data/doc/pages/recipes.textile +103 -0
  54. data/doc/pages/settings_profiles.textile +274 -0
  55. data/doc/pages/testing.textile +212 -0
  56. data/doc/pages/troubleshooting.textile +103 -0
  57. data/doc/pages/whats_new.textile +323 -0
  58. data/doc/print.haml +51 -0
  59. data/doc/print.toc.yaml +29 -0
  60. data/doc/scripts/buildr-git.rb +412 -0
  61. data/doc/scripts/install-jruby.sh +44 -0
  62. data/doc/scripts/install-linux.sh +64 -0
  63. data/doc/scripts/install-osx.sh +52 -0
  64. data/doc/site.haml +56 -0
  65. data/doc/site.toc.yaml +47 -0
  66. data/etc/KEYS +151 -0
  67. data/etc/git-svn-authors +16 -0
  68. data/lib/buildr.rb +35 -0
  69. data/lib/buildr/core.rb +27 -0
  70. data/lib/buildr/core/application.rb +489 -0
  71. data/lib/buildr/core/application_cli.rb +139 -0
  72. data/lib/buildr/core/build.rb +311 -0
  73. data/lib/buildr/core/checks.rb +382 -0
  74. data/lib/buildr/core/common.rb +154 -0
  75. data/lib/buildr/core/compile.rb +596 -0
  76. data/lib/buildr/core/environment.rb +120 -0
  77. data/lib/buildr/core/filter.rb +362 -0
  78. data/lib/buildr/core/generate.rb +195 -0
  79. data/lib/buildr/core/help.rb +118 -0
  80. data/lib/buildr/core/progressbar.rb +156 -0
  81. data/lib/buildr/core/project.rb +892 -0
  82. data/lib/buildr/core/test.rb +715 -0
  83. data/lib/buildr/core/transports.rb +558 -0
  84. data/lib/buildr/core/util.rb +289 -0
  85. data/lib/buildr/groovy.rb +18 -0
  86. data/lib/buildr/groovy/bdd.rb +105 -0
  87. data/lib/buildr/groovy/compiler.rb +138 -0
  88. data/lib/buildr/ide.rb +19 -0
  89. data/lib/buildr/ide/eclipse.rb +212 -0
  90. data/lib/buildr/ide/idea.ipr.template +300 -0
  91. data/lib/buildr/ide/idea.rb +189 -0
  92. data/lib/buildr/ide/idea7x.ipr.template +290 -0
  93. data/lib/buildr/ide/idea7x.rb +210 -0
  94. data/lib/buildr/java.rb +23 -0
  95. data/lib/buildr/java/ant.rb +92 -0
  96. data/lib/buildr/java/bdd.rb +449 -0
  97. data/lib/buildr/java/commands.rb +211 -0
  98. data/lib/buildr/java/compiler.rb +348 -0
  99. data/lib/buildr/java/deprecated.rb +141 -0
  100. data/lib/buildr/java/jruby.rb +117 -0
  101. data/lib/buildr/java/jtestr_runner.rb.erb +116 -0
  102. data/lib/buildr/java/org/apache/buildr/JavaTestFilter.class +0 -0
  103. data/lib/buildr/java/org/apache/buildr/JavaTestFilter.java +119 -0
  104. data/lib/buildr/java/packaging.rb +713 -0
  105. data/lib/buildr/java/pom.rb +178 -0
  106. data/lib/buildr/java/rjb.rb +155 -0
  107. data/lib/buildr/java/test_result.rb +308 -0
  108. data/lib/buildr/java/tests.rb +324 -0
  109. data/lib/buildr/java/version_requirement.rb +172 -0
  110. data/lib/buildr/packaging.rb +21 -0
  111. data/lib/buildr/packaging/artifact.rb +730 -0
  112. data/lib/buildr/packaging/artifact_namespace.rb +972 -0
  113. data/lib/buildr/packaging/artifact_search.rb +140 -0
  114. data/lib/buildr/packaging/gems.rb +102 -0
  115. data/lib/buildr/packaging/package.rb +233 -0
  116. data/lib/buildr/packaging/tar.rb +104 -0
  117. data/lib/buildr/packaging/zip.rb +722 -0
  118. data/lib/buildr/resources/buildr.icns +0 -0
  119. data/lib/buildr/scala.rb +19 -0
  120. data/lib/buildr/scala/compiler.rb +109 -0
  121. data/lib/buildr/scala/tests.rb +203 -0
  122. data/rakelib/apache.rake +191 -0
  123. data/rakelib/changelog.rake +57 -0
  124. data/rakelib/doc.rake +103 -0
  125. data/rakelib/package.rake +73 -0
  126. data/rakelib/release.rake +65 -0
  127. data/rakelib/rspec.rake +83 -0
  128. data/rakelib/rubyforge.rake +53 -0
  129. data/rakelib/scm.rake +49 -0
  130. data/rakelib/setup.rake +86 -0
  131. data/rakelib/stage.rake +48 -0
  132. data/spec/addon/cobertura_spec.rb +77 -0
  133. data/spec/addon/emma_spec.rb +120 -0
  134. data/spec/addon/test_coverage_spec.rb +255 -0
  135. data/spec/core/application_spec.rb +412 -0
  136. data/spec/core/artifact_namespace_spec.rb +646 -0
  137. data/spec/core/build_spec.rb +415 -0
  138. data/spec/core/checks_spec.rb +537 -0
  139. data/spec/core/common_spec.rb +664 -0
  140. data/spec/core/compile_spec.rb +566 -0
  141. data/spec/core/generate_spec.rb +33 -0
  142. data/spec/core/project_spec.rb +754 -0
  143. data/spec/core/test_spec.rb +1091 -0
  144. data/spec/core/transport_spec.rb +500 -0
  145. data/spec/groovy/bdd_spec.rb +80 -0
  146. data/spec/groovy/compiler_spec.rb +239 -0
  147. data/spec/ide/eclipse_spec.rb +243 -0
  148. data/spec/java/ant.rb +28 -0
  149. data/spec/java/bdd_spec.rb +358 -0
  150. data/spec/java/compiler_spec.rb +446 -0
  151. data/spec/java/java_spec.rb +88 -0
  152. data/spec/java/packaging_spec.rb +1103 -0
  153. data/spec/java/tests_spec.rb +466 -0
  154. data/spec/packaging/archive_spec.rb +503 -0
  155. data/spec/packaging/artifact_spec.rb +754 -0
  156. data/spec/packaging/packaging_helper.rb +63 -0
  157. data/spec/packaging/packaging_spec.rb +589 -0
  158. data/spec/sandbox.rb +137 -0
  159. data/spec/scala/compiler_spec.rb +228 -0
  160. data/spec/scala/tests_spec.rb +215 -0
  161. data/spec/spec_helpers.rb +304 -0
  162. data/spec/version_requirement_spec.rb +123 -0
  163. metadata +369 -0
@@ -0,0 +1,415 @@
1
+ # Licensed to the Apache Software Foundation (ASF) under one or more
2
+ # contributor license agreements. See the NOTICE file distributed with this
3
+ # work for additional information regarding copyright ownership. The ASF
4
+ # licenses this file to you under the Apache License, Version 2.0 (the
5
+ # "License"); you may not use this file except in compliance with the License.
6
+ # You may obtain a copy of the License at
7
+ #
8
+ # http://www.apache.org/licenses/LICENSE-2.0
9
+ #
10
+ # Unless required by applicable law or agreed to in writing, software
11
+ # distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
12
+ # WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
13
+ # License for the specific language governing permissions and limitations under
14
+ # the License.
15
+
16
+
17
+ require File.join(File.dirname(__FILE__), '../spec_helpers')
18
+
19
+
20
+ describe 'local task', :shared=>true do
21
+ it "should execute task for project in current directory" do
22
+ define 'foobar'
23
+ lambda { @task.invoke }.should run_task("foobar:#{@task.name}")
24
+ end
25
+
26
+ it "should not execute task for projects in other directory" do
27
+ define 'foobar', :base_dir=>'elsewhere'
28
+ lambda { task('build').invoke }.should_not run_task('foobar:build')
29
+ end
30
+ end
31
+
32
+
33
+ describe 'build task' do
34
+ it_should_behave_like 'local task'
35
+ before(:each) { @task = task('build') }
36
+ end
37
+
38
+ describe 'clean task' do
39
+ it_should_behave_like 'local task'
40
+ before(:each) { @task = task('clean') }
41
+ end
42
+
43
+ describe 'package task' do
44
+ it_should_behave_like 'local task'
45
+ before(:each) { @task = task('package') }
46
+
47
+ it 'should execute build task as prerequisite' do
48
+ lambda { @task.invoke }.should run_task('build')
49
+ end
50
+ end
51
+
52
+ describe 'install task' do
53
+ it_should_behave_like 'local task'
54
+ before(:each) { @task = task('install') }
55
+
56
+ it 'should execute package task as prerequisite' do
57
+ lambda { @task.invoke }.should run_task('package')
58
+ end
59
+ end
60
+
61
+ describe 'uninstall task' do
62
+ it_should_behave_like 'local task'
63
+ before(:each) { @task = task('uninstall') }
64
+ end
65
+
66
+ describe 'upload task' do
67
+ it_should_behave_like 'local task'
68
+ before(:each) { @task = task('upload') }
69
+
70
+ it 'should execute package task as prerequisite' do
71
+ lambda { @task.invoke }.should run_task('package')
72
+ end
73
+ end
74
+
75
+
76
+ describe Project, '#build' do
77
+ it 'should return the project\'s build task' do
78
+ define('foo').build.should eql(task('foo:build'))
79
+ end
80
+
81
+ it 'should enhance the project\'s build task' do
82
+ task 'prereq'
83
+ task 'action'
84
+ define 'foo' do
85
+ build 'prereq' do
86
+ task('action').invoke
87
+ end
88
+ end
89
+ lambda { project('foo').build.invoke }.should run_tasks('prereq', 'action')
90
+ end
91
+
92
+ it 'should execute build task for sub-project' do
93
+ define 'foo' do
94
+ define 'bar'
95
+ end
96
+ lambda { task('foo:build').invoke }.should run_task('foo:bar:build')
97
+ end
98
+
99
+ it 'should not execute build task of other projects' do
100
+ define 'foo'
101
+ define 'bar'
102
+ lambda { task('foo:build').invoke }.should_not run_task('bar:build')
103
+ end
104
+ end
105
+
106
+
107
+ describe Project, '#clean' do
108
+ it 'should return the project\'s clean task' do
109
+ define('foo').clean.should eql(task('foo:clean'))
110
+ end
111
+
112
+ it 'should enhance the project\'s clean task' do
113
+ task 'prereq'
114
+ task 'action'
115
+ define 'foo' do
116
+ clean 'prereq' do
117
+ task('action').invoke
118
+ end
119
+ end
120
+ lambda { project('foo').clean.invoke }.should run_tasks('prereq', 'action')
121
+ end
122
+
123
+ it 'should remove target directory' do
124
+ define 'foo' do
125
+ self.layout[:target] = 'targeted'
126
+ end
127
+ mkpath 'targeted'
128
+ lambda { project('foo').clean.invoke }.should change { File.exist?('targeted') }.from(true).to(false)
129
+ end
130
+
131
+ it 'should remove reports directory' do
132
+ define 'foo' do
133
+ self.layout[:reports] = 'reported'
134
+ end
135
+ mkpath 'reported'
136
+ lambda { project('foo').clean.invoke }.should change { File.exist?('reported') }.from(true).to(false)
137
+ end
138
+
139
+ it 'should execute clean task for sub-project' do
140
+ define 'foo' do
141
+ define 'bar'
142
+ end
143
+ lambda { task('foo:clean').invoke }.should run_task('foo:bar:clean')
144
+ end
145
+
146
+ it 'should not execute clean task of other projects' do
147
+ define 'foo'
148
+ define 'bar'
149
+ lambda { task('foo:clean').invoke }.should_not run_task('bar:clean')
150
+ end
151
+ end
152
+
153
+
154
+ describe Project, '#target' do
155
+ before :each do
156
+ @project = define('foo', :layout=>Layout.new)
157
+ end
158
+
159
+ it 'should default to target' do
160
+ @project.target.should eql('target')
161
+ end
162
+
163
+ it 'should set layout :target' do
164
+ @project.target = 'bar'
165
+ @project.layout.expand(:target).should point_to_path('bar')
166
+ end
167
+
168
+ it 'should come from layout :target' do
169
+ @project.layout[:target] = 'baz'
170
+ @project.target.should eql('baz')
171
+ end
172
+ end
173
+
174
+
175
+ describe Project, '#reports' do
176
+ before :each do
177
+ @project = define('foo', :layout=>Layout.new)
178
+ end
179
+
180
+ it 'should default to reports' do
181
+ @project.reports.should eql('reports')
182
+ end
183
+
184
+ it 'should set layout :reports' do
185
+ @project.reports = 'bar'
186
+ @project.layout.expand(:reports).should point_to_path('bar')
187
+ end
188
+
189
+ it 'should come from layout :reports' do
190
+ @project.layout[:reports] = 'baz'
191
+ @project.reports.should eql('baz')
192
+ end
193
+ end
194
+
195
+
196
+ describe Buildr::Release do
197
+
198
+ describe '#make' do
199
+ before do
200
+ write 'buildfile', "VERSION_NUMBER = '1.0.0-SNAPSHOT'"
201
+ # Prevent a real call to a spawned buildr process.
202
+ Release.stub!(:buildr)
203
+ Svn.stub!(:repo_url).and_return('http://my.repo.org/foo/trunk')
204
+ Svn.stub!(:uncommitted_files).and_return('')
205
+ Svn.stub!(:remove)
206
+ Svn.stub!(:copy)
207
+ Svn.stub!(:commit)
208
+ end
209
+
210
+ it 'should tag a release with the release version' do
211
+ Svn.should_receive(:copy).with(Dir.pwd, 'http://my.repo.org/foo/tags/1.0.0', 'Release 1.0.0').and_return {
212
+ file('buildfile').should contain('VERSION_NUMBER = "1.0.0"')
213
+ }
214
+ Release.make
215
+ end
216
+
217
+ it 'should update the buildfile with the next version number' do
218
+ Release.make
219
+ file('buildfile').should contain('VERSION_NUMBER = "1.0.1-SNAPSHOT"')
220
+ end
221
+
222
+ it 'should commit the updated buildfile' do
223
+ Svn.should_receive(:commit).with(File.expand_path('buildfile'), 'Changed version number to 1.0.1-SNAPSHOT').and_return {
224
+ file('buildfile').should contain('VERSION_NUMBER = "1.0.1-SNAPSHOT"')
225
+ }
226
+ Release.make
227
+ end
228
+ end
229
+
230
+
231
+ describe '#check' do
232
+ before do
233
+ Svn.stub!(:uncommitted_files).and_return('')
234
+ end
235
+
236
+ it 'should accept to release from the trunk' do
237
+ Svn.stub!(:repo_url).and_return('http://my.repo.org/foo/trunk')
238
+ lambda { Release.check }.should_not raise_error
239
+ end
240
+
241
+ it 'should accept to release from a branch' do
242
+ Svn.stub!(:repo_url).and_return('http://my.repo.org/foo/branches/1.0')
243
+ lambda { Release.check }.should_not raise_error
244
+ end
245
+
246
+ it 'should reject releasing from a tag' do
247
+ Svn.stub!(:repo_url).and_return('http://my.repo.org/foo/tags/1.0.0')
248
+ lambda { Release.check }.should raise_error(RuntimeError, "SVN URL must contain 'trunk' or 'branches/...'")
249
+ end
250
+
251
+ it 'should reject a non standard repository layout' do
252
+ Svn.stub!(:repo_url).and_return('http://my.repo.org/foo/bar')
253
+ lambda { Release.check }.should raise_error(RuntimeError, "SVN URL must contain 'trunk' or 'branches/...'")
254
+ end
255
+
256
+ it 'should reject an uncommitted file' do
257
+ Svn.stub!(:repo_url).and_return('http://my.repo.org/foo/trunk')
258
+ Svn.stub!(:uncommitted_files).and_return('M foo.rb')
259
+ lambda { Release.check }.should raise_error(RuntimeError,
260
+ "Uncommitted SVN files violate the First Principle Of Release!\n" +
261
+ "M foo.rb")
262
+ end
263
+ end
264
+
265
+
266
+ describe '#extract_version' do
267
+ it 'should extract VERSION_NUMBER with single quotes' do
268
+ write 'buildfile', "VERSION_NUMBER = '1.0.0-SNAPSHOT'"
269
+ Release.extract_version.should == '1.0.0-SNAPSHOT'
270
+ end
271
+
272
+ it 'should extract VERSION_NUMBER with double quotes' do
273
+ write 'buildfile', %{VERSION_NUMBER = "1.0.1-SNAPSHOT"}
274
+ Release.extract_version.should == '1.0.1-SNAPSHOT'
275
+ end
276
+
277
+ it 'should extract VERSION_NUMBER without any spaces' do
278
+ write 'buildfile', "VERSION_NUMBER='1.0.2-SNAPSHOT'"
279
+ Release.extract_version.should == '1.0.2-SNAPSHOT'
280
+ end
281
+
282
+ it 'should extract THIS_VERSION as an alternative to VERSION_NUMBER' do
283
+ write 'buildfile', "THIS_VERSION = '1.0.3-SNAPSHOT'"
284
+ Release.extract_version.should == '1.0.3-SNAPSHOT'
285
+ end
286
+
287
+ it 'should complain if no current version number' do
288
+ write 'buildfile', 'define foo'
289
+ lambda { Release.extract_version }.should raise_error('Looking for THIS_VERSION = "..." in your Buildfile, none found')
290
+ end
291
+ end
292
+
293
+
294
+ # Reference: http://svnbook.red-bean.com/en/1.4/svn.reposadmin.planning.html#svn.reposadmin.projects.chooselayout
295
+ describe '#tag url' do
296
+ it 'should accept to tag foo/trunk' do
297
+ Release.tag_url('http://my.repo.org/foo/trunk', '1.0.0').should == 'http://my.repo.org/foo/tags/1.0.0'
298
+ end
299
+
300
+ it 'should accept to tag foo/branches/1.0' do
301
+ Release.tag_url('http://my.repo.org/foo/branches/1.0', '1.0.1').should == 'http://my.repo.org/foo/tags/1.0.1'
302
+ end
303
+
304
+ it 'should accept to tag trunk/foo' do
305
+ Release.tag_url('http://my.repo.org/trunk/foo', '1.0.0').should == 'http://my.repo.org/tags/foo/1.0.0'
306
+ end
307
+
308
+ it 'should accept to tag branches/foo/1.0' do
309
+ Release.tag_url('http://my.repo.org/branches/foo/1.0', '1.0.0').should == 'http://my.repo.org/tags/foo/1.0.0'
310
+ end
311
+
312
+ it 'should use tag specified by tag_name' do
313
+ Release.tag_name = 'first'
314
+ Release.tag_url('http://my.repo.org/foo/trunk', '1.0.0').should == 'http://my.repo.org/foo/tags/first'
315
+ end
316
+
317
+ it 'should use tag returned by tag_name if tag_name is a proc' do
318
+ Release.tag_name = lambda { |version| "buildr-#{version}" }
319
+ Release.tag_url('http://my.repo.org/foo/trunk', '1.0.0').should == 'http://my.repo.org/foo/tags/buildr-1.0.0'
320
+ end
321
+
322
+ after { Release.tag_name = nil }
323
+ end
324
+
325
+
326
+ describe '#with_release_candidate_version' do
327
+ before do
328
+ Buildr.application.stub!(:buildfile).and_return(file('buildfile'))
329
+ write 'buildfile', "THIS_VERSION = '1.1.0-SNAPSHOT'"
330
+ end
331
+
332
+ it 'should yield the name of the release candidate buildfile' do
333
+ Release.send :with_release_candidate_version do |new_filename|
334
+ File.read(new_filename).should == %{THIS_VERSION = "1.1.0"}
335
+ end
336
+ end
337
+
338
+ it 'should yield a name different from the original buildfile' do
339
+ Release.send :with_release_candidate_version do |new_filename|
340
+ new_filename.should_not point_to_path('buildfile')
341
+ end
342
+ end
343
+ end
344
+
345
+
346
+ describe '#tag_release' do
347
+ before do
348
+ write 'buildfile', "THIS_VERSION = '1.0.1'"
349
+ Svn.stub!(:repo_url).and_return('http://my.repo.org/foo/trunk')
350
+ Svn.stub!(:copy)
351
+ Svn.stub!(:remove)
352
+ end
353
+
354
+ it 'should tag the working copy' do
355
+ Svn.should_receive(:copy).with(Dir.pwd, 'http://my.repo.org/foo/tags/1.0.1', 'Release 1.0.1')
356
+ Release.send :tag_release
357
+ end
358
+
359
+ it 'should remove the tag if it already exists' do
360
+ Svn.should_receive(:remove).with('http://my.repo.org/foo/tags/1.0.1', 'Removing old copy')
361
+ Release.send :tag_release
362
+ end
363
+
364
+ it 'should accept that the tag does not exist' do
365
+ Svn.stub!(:remove).and_raise(RuntimeError)
366
+ Release.send :tag_release
367
+ end
368
+
369
+ it 'should inform the user' do
370
+ lambda { Release.send :tag_release }.should show_info('Tagging release 1.0.1')
371
+ end
372
+ end
373
+
374
+
375
+ describe '#commit_new_snapshot' do
376
+ before do
377
+ write 'buildfile', 'THIS_VERSION = "1.0.0"'
378
+ Svn.stub!(:commit)
379
+ end
380
+
381
+ it 'should update the buildfile with a new version number' do
382
+ Release.send :commit_new_snapshot
383
+ file('buildfile').should contain('THIS_VERSION = "1.0.1-SNAPSHOT"')
384
+ end
385
+
386
+ it 'should commit the new buildfile on the trunk' do
387
+ Svn.should_receive(:commit).with(File.expand_path('buildfile'), 'Changed version number to 1.0.1-SNAPSHOT')
388
+ Release.send :commit_new_snapshot
389
+ end
390
+
391
+ it 'should inform the user of the new version' do
392
+ lambda { Release.send :commit_new_snapshot }.should show_info('Current version is now 1.0.1-SNAPSHOT')
393
+ end
394
+ end
395
+
396
+ end
397
+
398
+
399
+ describe Buildr::Svn, '#repo_url' do
400
+ it 'should extract the SVN URL from svn info' do
401
+ Svn.stub!(:svn, 'info').and_return(<<EOF)
402
+ Path: .
403
+ URL: http://my.repo.org/foo/trunk
404
+ Repository Root: http://my.repo.org
405
+ Repository UUID: 12345678-9abc-def0-1234-56789abcdef0
406
+ Revision: 112
407
+ Node Kind: directory
408
+ Schedule: normal
409
+ Last Changed Author: Lacton
410
+ Last Changed Rev: 110
411
+ Last Changed Date: 2008-08-19 12:00:00 +0200 (Tue, 19 Aug 2008)
412
+ EOF
413
+ Svn.repo_url.should == 'http://my.repo.org/foo/trunk'
414
+ end
415
+ end
@@ -0,0 +1,537 @@
1
+ # Licensed to the Apache Software Foundation (ASF) under one or more
2
+ # contributor license agreements. See the NOTICE file distributed with this
3
+ # work for additional information regarding copyright ownership. The ASF
4
+ # licenses this file to you under the Apache License, Version 2.0 (the
5
+ # "License"); you may not use this file except in compliance with the License.
6
+ # You may obtain a copy of the License at
7
+ #
8
+ # http://www.apache.org/licenses/LICENSE-2.0
9
+ #
10
+ # Unless required by applicable law or agreed to in writing, software
11
+ # distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
12
+ # WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
13
+ # License for the specific language governing permissions and limitations under
14
+ # the License.
15
+
16
+
17
+ require File.join(File.dirname(__FILE__), '../spec_helpers')
18
+
19
+
20
+ describe Project, " check task" do
21
+
22
+ it "should execute last thing from package task" do
23
+ task "action"
24
+ define "foo", :version=>"1.0" do
25
+ package :jar
26
+ task("package").enhance { task("action").invoke }
27
+ end
28
+ lambda { project("foo").task("package").invoke }.should run_tasks(["foo:package", "action", "foo:check"])
29
+ end
30
+
31
+ it "should execute all project's expectations" do
32
+ task "expectation"
33
+ define "foo", :version=>"1.0" do
34
+ check { task("expectation").invoke }
35
+ end
36
+ lambda { project("foo").task("package").invoke }.should run_task("expectation")
37
+ end
38
+
39
+ it "should succeed if there are no expectations" do
40
+ define "foo", :version=>"1.0"
41
+ lambda { project("foo").task("package").invoke }.should_not raise_error
42
+ end
43
+
44
+ it "should succeed if all expectations passed" do
45
+ define "foo", :version=>"1.0" do
46
+ check { true }
47
+ check { false }
48
+ end
49
+ lambda { project("foo").task("package").invoke }.should_not raise_error
50
+ end
51
+
52
+ it "should fail if any expectation failed" do
53
+ define "foo", :version=>"1.0" do
54
+ check
55
+ check { fail "sorry" }
56
+ check
57
+ end
58
+ lambda { project("foo").task("package").invoke }.should raise_error(RuntimeError, /Checks failed/)
59
+ end
60
+ end
61
+
62
+
63
+ describe Project, "#check" do
64
+
65
+ it "should add expectation" do
66
+ define "foo" do
67
+ expectations.should be_empty
68
+ check
69
+ expectations.size.should be(1)
70
+ end
71
+ end
72
+
73
+ it "should treat no arguments as expectation against project" do
74
+ define "foo" do
75
+ subject = self
76
+ check do
77
+ it.should be(subject)
78
+ description.should eql(subject.to_s)
79
+ end
80
+ end
81
+ lambda { project("foo").task("package").invoke }.should_not raise_error
82
+ end
83
+
84
+ it "should treat single string argument as description, expectation against project" do
85
+ define "foo" do
86
+ subject = self
87
+ check "should be project" do
88
+ it.should be(subject)
89
+ description.should eql("#{subject} should be project")
90
+ end
91
+ end
92
+ lambda { project("foo").task("package").invoke }.should_not raise_error
93
+ end
94
+
95
+ it "should treat single object argument as subject" do
96
+ define "foo" do
97
+ subject = Object.new
98
+ check subject do
99
+ it.should be(subject)
100
+ description.should eql(subject.to_s)
101
+ end
102
+ end
103
+ lambda { project("foo").task("package").invoke }.should_not raise_error
104
+ end
105
+
106
+ it "should treat first object as subject, second object as description" do
107
+ define "foo" do
108
+ subject = Object.new
109
+ check subject, "should exist" do
110
+ it.should be(subject)
111
+ description.should eql("#{subject} should exist")
112
+ end
113
+ end
114
+ lambda { project("foo").task("package").invoke }.should_not raise_error
115
+ end
116
+
117
+ it "should work without block" do
118
+ define "foo" do
119
+ check "implement later"
120
+ end
121
+ lambda { project("foo").task("package").invoke }.should_not raise_error
122
+ end
123
+ end
124
+
125
+
126
+ describe Buildr::Checks::Expectation, " matchers" do
127
+
128
+ it "should include Buildr matchers exist and contain" do
129
+ define "foo" do
130
+ check do
131
+ self.should respond_to(:exist)
132
+ self.should respond_to(:contain)
133
+ end
134
+ end
135
+ lambda { project("foo").task("package").invoke }.should_not raise_error
136
+ end
137
+
138
+ it "should include RSpec matchers like be and eql" do
139
+ define "foo" do
140
+ check do
141
+ self.should respond_to(:be)
142
+ self.should respond_to(:eql)
143
+ end
144
+ end
145
+ lambda { project("foo").task("package").invoke }.should_not raise_error
146
+ end
147
+
148
+ it "should include RSpec predicates like be_nil and be_empty" do
149
+ define "foo" do
150
+ check do
151
+ nil.should be_nil
152
+ [].should be_empty
153
+ end
154
+ end
155
+ lambda { project("foo").task("package").invoke }.should_not raise_error
156
+ end
157
+ end
158
+
159
+
160
+ describe Buildr::Checks::Expectation, " exist" do
161
+
162
+ it "should pass if file exists" do
163
+ define "foo" do
164
+ build file("test") { |task| write task.name }
165
+ check(file("test")) { it.should exist }
166
+ end
167
+ lambda { project("foo").task("package").invoke }.should_not raise_error
168
+ end
169
+
170
+ it "should fail if file does not exist" do
171
+ define "foo" do
172
+ check(file("test")) { it.should exist }
173
+ end
174
+ lambda { project("foo").task("package").invoke }.should raise_error(RuntimeError, /Checks failed/)
175
+ end
176
+
177
+ it "should not attempt to invoke task" do
178
+ define "foo" do
179
+ file("test") { |task| write task.name }
180
+ check(file("test")) { it.should exist }
181
+ end
182
+ lambda { project("foo").task("package").invoke }.should raise_error(RuntimeError, /Checks failed/)
183
+ end
184
+
185
+ it "should pass if ZIP path exists" do
186
+ write "resources/test"
187
+ define "foo", :version=>"1.0" do
188
+ package(:jar).include("resources")
189
+ check(package(:jar).path("resources")) { it.should exist }
190
+ end
191
+ lambda { project("foo").task("package").invoke }.should_not raise_error
192
+ end
193
+
194
+ it "should fail if ZIP path does not exist" do
195
+ mkpath "resources"
196
+ define "foo", :version=>"1.0" do
197
+ package(:jar).include("resources")
198
+ check(package(:jar)) { it.path("not-resources").should exist }
199
+ end
200
+ lambda { project("foo").task("package").invoke }.should raise_error(RuntimeError, /Checks failed/)
201
+ end
202
+
203
+ it "should pass if ZIP entry exists" do
204
+ write "resources/test"
205
+ define "foo", :version=>"1.0" do
206
+ package(:jar).include("resources")
207
+ check(package(:jar).entry("resources/test")) { it.should exist }
208
+ check(package(:jar).path("resources").entry("test")) { it.should exist }
209
+ end
210
+ lambda { project("foo").task("package").invoke }.should_not raise_error
211
+ end
212
+
213
+ it "should fail if ZIP path does not exist" do
214
+ mkpath "resources"
215
+ define "foo", :version=>"1.0" do
216
+ package(:jar).include("resources")
217
+ check(package(:jar).entry("resources/test")) { it.should exist }
218
+ end
219
+ lambda { project("foo").task("package").invoke }.should raise_error(RuntimeError, /Checks failed/)
220
+ end
221
+ end
222
+
223
+
224
+ describe Buildr::Checks::Expectation, " be_empty" do
225
+
226
+ it "should pass if file has no content" do
227
+ define "foo" do
228
+ build file("test") { write "test" }
229
+ check(file("test")) { it.should be_empty }
230
+ end
231
+ lambda { project("foo").task("package").invoke }.should_not raise_error
232
+ end
233
+
234
+ it "should fail if file has content" do
235
+ define "foo" do
236
+ build file("test") { write "test", "something" }
237
+ check(file("test")) { it.should be_empty }
238
+ end
239
+ lambda { project("foo").task("package").invoke }.should raise_error(RuntimeError, /Checks failed/)
240
+ end
241
+
242
+ it "should fail if file does not exist" do
243
+ define "foo" do
244
+ check(file("test")) { it.should be_empty }
245
+ end
246
+ lambda { project("foo").task("package").invoke }.should raise_error(RuntimeError, /Checks failed/)
247
+ end
248
+
249
+ it "should pass if directory is empty" do
250
+ define "foo" do
251
+ build file("test") { mkpath "test" }
252
+ check(file("test")) { it.should be_empty }
253
+ end
254
+ lambda { project("foo").task("package").invoke }.should_not raise_error
255
+ end
256
+
257
+ it "should fail if directory has any files" do
258
+ define "foo" do
259
+ build file("test") { write "test/file" }
260
+ check(file("test")) { it.should be_empty }
261
+ end
262
+ lambda { project("foo").task("package").invoke }.should raise_error(RuntimeError, /Checks failed/)
263
+ end
264
+
265
+ it "should pass if ZIP path is empty" do
266
+ mkpath "resources"
267
+ define "foo", :version=>"1.0" do
268
+ package(:jar).include("resources")
269
+ check(package(:jar).path("resources")) { it.should be_empty }
270
+ end
271
+ lambda { project("foo").task("package").invoke }.should_not raise_error
272
+ end
273
+
274
+ it "should fail if ZIP path has any entries" do
275
+ write "resources/test"
276
+ define "foo", :version=>"1.0" do
277
+ package(:jar).include("resources")
278
+ check(package(:jar).path("resources")) { it.should be_empty }
279
+ end
280
+ lambda { project("foo").task("package").invoke }.should raise_error(RuntimeError, /Checks failed/)
281
+ end
282
+
283
+ it "should pass if ZIP entry has no content" do
284
+ write "resources/test"
285
+ define "foo", :version=>"1.0" do
286
+ package(:jar).include("resources")
287
+ check(package(:jar).entry("resources/test")) { it.should be_empty }
288
+ check(package(:jar).path("resources").entry("test")) { it.should be_empty }
289
+ end
290
+ lambda { project("foo").task("package").invoke }.should_not raise_error
291
+ end
292
+
293
+ it "should fail if ZIP entry has content" do
294
+ write "resources/test", "something"
295
+ define "foo", :version=>"1.0" do
296
+ package(:jar).include("resources")
297
+ check(package(:jar).entry("resources/test")) { it.should be_empty }
298
+ end
299
+ lambda { project("foo").task("package").invoke }.should raise_error(RuntimeError, /Checks failed/)
300
+ end
301
+
302
+ it "should fail if ZIP entry does not exist" do
303
+ mkpath "resources"
304
+ define "foo", :version=>"1.0" do
305
+ package(:jar).include("resources")
306
+ check(package(:jar).entry("resources/test")) { it.should be_empty }
307
+ end
308
+ lambda { project("foo").task("package").invoke }.should raise_error(RuntimeError, /Checks failed/)
309
+ end
310
+ end
311
+
312
+
313
+ describe Buildr::Checks::Expectation, " contain(file)" do
314
+
315
+ it "should pass if file content matches string" do
316
+ define "foo" do
317
+ build file("test") { write "test", "something" }
318
+ check(file("test")) { it.should contain("thing") }
319
+ end
320
+ lambda { project("foo").task("package").invoke }.should_not raise_error
321
+ end
322
+
323
+ it "should pass if file content matches pattern" do
324
+ define "foo" do
325
+ build file("test") { write "test", "something\nor\nanother" }
326
+ check(file("test")) { it.should contain(/or/) }
327
+ end
328
+ lambda { project("foo").task("package").invoke }.should_not raise_error
329
+ end
330
+
331
+ it "should pass if file content matches all arguments" do
332
+ define "foo" do
333
+ build file("test") { write "test", "something\nor\nanother" }
334
+ check(file("test")) { it.should contain(/or/, /other/) }
335
+ end
336
+ lambda { project("foo").task("package").invoke }.should_not raise_error
337
+ end
338
+
339
+ it "should fail unless file content matchs all arguments" do
340
+ define "foo" do
341
+ build file("test") { write "test", "something" }
342
+ check(file("test")) { it.should contain(/some/, /other/) }
343
+ end
344
+ lambda { project("foo").task("package").invoke }.should raise_error(RuntimeError, /Checks failed/)
345
+ end
346
+
347
+ it "should fail if file content does not match" do
348
+ define "foo" do
349
+ build file("test") { write "test", "something" }
350
+ check(file("test")) { it.should contain(/other/) }
351
+ end
352
+ lambda { project("foo").task("package").invoke }.should raise_error(RuntimeError, /Checks failed/)
353
+ end
354
+
355
+ it "should fail if file does not exist" do
356
+ define "foo" do
357
+ check(file("test")) { it.should contain(/anything/) }
358
+ end
359
+ lambda { project("foo").task("package").invoke }.should raise_error(RuntimeError, /Checks failed/)
360
+ end
361
+ end
362
+
363
+
364
+ describe Buildr::Checks::Expectation, " contain(directory)" do
365
+
366
+ it "should pass if directory contains file" do
367
+ write "resources/test"
368
+ define "foo" do
369
+ check(file("resources")) { it.should contain("test") }
370
+ end
371
+ lambda { project("foo").task("package").invoke }.should_not raise_error
372
+ end
373
+
374
+ it "should pass if directory contains glob pattern" do
375
+ write "resources/with/test"
376
+ define "foo" do
377
+ check(file("resources")) { it.should contain("**/t*st") }
378
+ end
379
+ lambda { project("foo").task("package").invoke }.should_not raise_error
380
+ end
381
+
382
+ it "should pass if directory contains all arguments" do
383
+ write "resources/with/test"
384
+ define "foo" do
385
+ check(file("resources")) { it.should contain("**/test", "**/*") }
386
+ end
387
+ lambda { project("foo").task("package").invoke }.should_not raise_error
388
+ end
389
+
390
+ it "should fail unless directory contains all arguments" do
391
+ write "resources/test"
392
+ define "foo" do
393
+ check(file("resources")) { it.should contain("test", "or-not") }
394
+ end
395
+ lambda { project("foo").task("package").invoke }.should raise_error(RuntimeError, /Checks failed/)
396
+ end
397
+
398
+ it "should fail if directory is empty" do
399
+ mkpath "resources"
400
+ define "foo" do
401
+ check(file("resources")) { it.should contain("test") }
402
+ end
403
+ lambda { project("foo").task("package").invoke }.should raise_error(RuntimeError, /Checks failed/)
404
+ end
405
+
406
+ it "should fail if directory does not exist" do
407
+ define "foo" do
408
+ check(file("resources")) { it.should contain }
409
+ end
410
+ lambda { project("foo").task("package").invoke }.should raise_error(RuntimeError, /Checks failed/)
411
+ end
412
+ end
413
+
414
+
415
+ describe Buildr::Checks::Expectation, " contain(zip.entry)" do
416
+
417
+ it "should pass if ZIP entry content matches string" do
418
+ write "resources/test", "something"
419
+ define "foo", :version=>"1.0" do
420
+ package(:jar).include("resources")
421
+ check(package(:jar).entry("resources/test")) { it.should contain("thing") }
422
+ #check(package(:jar)) { it.entry("resources/test").should contain("thing") }
423
+ end
424
+ lambda { project("foo").task("package").invoke }.should_not raise_error
425
+ end
426
+
427
+ it "should pass if ZIP entry content matches pattern" do
428
+ write "resources/test", "something\nor\another"
429
+ define "foo", :version=>"1.0" do
430
+ package(:jar).include("resources")
431
+ check(package(:jar).entry("resources/test")) { it.should contain(/or/) }
432
+ #check(package(:jar)) { it.entry("resources/test").should contain(/or/) }
433
+ end
434
+ lambda { project("foo").task("package").invoke }.should_not raise_error
435
+ end
436
+
437
+ it "should pass if ZIP entry content matches all arguments" do
438
+ write "resources/test", "something\nor\nanother"
439
+ define "foo", :version=>"1.0" do
440
+ package(:jar).include("resources")
441
+ check(package(:jar).entry("resources/test")) { it.should contain(/or/, /other/) }
442
+ #check(package(:jar)) { it.entry("resources/test").should contain(/or/, /other/) }
443
+ end
444
+ lambda { project("foo").task("package").invoke }.should_not raise_error
445
+ end
446
+
447
+ it "should fail unless ZIP path contains all arguments" do
448
+ write "resources/test", "something"
449
+ define "foo", :version=>"1.0" do
450
+ package(:jar).include("resources")
451
+ check(package(:jar).entry("resources/test")) { it.should contain(/some/, /other/) }
452
+ #check(package(:jar)) { it.entry("resources/test").should contain(/some/, /other/) }
453
+ end
454
+ lambda { project("foo").task("package").invoke }.should raise_error(RuntimeError, /Checks failed/)
455
+ end
456
+
457
+ it "should fail if ZIP entry content does not match" do
458
+ write "resources/test", "something"
459
+ define "foo", :version=>"1.0" do
460
+ package(:jar).include("resources")
461
+ check(package(:jar).entry("resources/test")) { it.should contain(/other/) }
462
+ #check(package(:jar)) { it.entry("resources/test").should contain(/other/) }
463
+ end
464
+ lambda { project("foo").task("package").invoke }.should raise_error(RuntimeError, /Checks failed/)
465
+ end
466
+
467
+ it "should fail if ZIP entry does not exist" do
468
+ mkpath "resources"
469
+ define "foo", :version=>"1.0" do
470
+ package(:jar).include("resources")
471
+ check(package(:jar).entry("resources/test")) { it.should contain(/anything/) }
472
+ #check(package(:jar)) { it.entry("resources/test").should contain(/anything/) }
473
+ end
474
+ lambda { project("foo").task("package").invoke }.should raise_error(RuntimeError, /Checks failed/)
475
+ end
476
+ end
477
+
478
+
479
+ describe Buildr::Checks::Expectation, " contain(zip.path)" do
480
+
481
+ it "should pass if ZIP path contains file" do
482
+ write "resources/test"
483
+ define "foo", :version=>"1.0" do
484
+ package(:jar).include("resources")
485
+ check(package(:jar).path("resources")) { it.should contain("test") }
486
+ end
487
+ lambda { project("foo").task("package").invoke }.should_not raise_error
488
+ end
489
+
490
+ it "should handle deep nesting" do
491
+ write "resources/test/test2.efx"
492
+ define "foo", :version=>"1.0" do
493
+ package(:jar).include("*")
494
+ check(package(:jar)) { it.should contain("resources/test/test2.efx") }
495
+ check(package(:jar).path("resources")) { it.should contain("test/test2.efx") }
496
+ check(package(:jar).path("resources/test")) { it.should contain("test2.efx") }
497
+ end
498
+ lambda { project("foo").task("package").invoke }.should_not raise_error
499
+ end
500
+
501
+
502
+ it "should pass if ZIP path contains pattern" do
503
+ write "resources/with/test"
504
+ define "foo", :version=>"1.0" do
505
+ package(:jar).include("resources")
506
+ check(package(:jar).path("resources")) { it.should contain("**/t*st") }
507
+ end
508
+ lambda { project("foo").task("package").invoke }.should_not raise_error
509
+ end
510
+
511
+ it "should pass if ZIP path contains all arguments" do
512
+ write "resources/with/test"
513
+ define "foo", :version=>"1.0" do
514
+ package(:jar).include("resources")
515
+ check(package(:jar).path("resources")) { it.should contain("**/test", "**/*") }
516
+ end
517
+ lambda { project("foo").task("package").invoke }.should_not raise_error
518
+ end
519
+
520
+ it "should fail unless ZIP path contains all arguments" do
521
+ write "resources/test"
522
+ define "foo", :version=>"1.0" do
523
+ package(:jar).include("resources")
524
+ check(package(:jar).path("resources")) { it.should contain("test", "or-not") }
525
+ end
526
+ lambda { project("foo").task("package").invoke }.should raise_error(RuntimeError, /Checks failed/)
527
+ end
528
+
529
+ it "should fail if ZIP path is empty" do
530
+ mkpath "resources"
531
+ define "foo", :version=>"1.0" do
532
+ package(:jar).include("resources")
533
+ check(package(:jar).path("resources")) { it.should contain("test") }
534
+ end
535
+ lambda { project("foo").task("package").invoke }.should raise_error(RuntimeError, /Checks failed/)
536
+ end
537
+ end