buildr 1.4.4 → 1.4.5
Sign up to get free protection for your applications and to get access to all the features.
- data/CHANGELOG +46 -0
- data/Rakefile +0 -1
- data/addon/buildr/bnd.rb +147 -0
- data/addon/buildr/jaxb_xjc.rb +72 -0
- data/addon/buildr/protobuf.rb +14 -1
- data/buildr.gemspec +6 -2
- data/doc/artifacts.textile +6 -0
- data/doc/contributing.textile +3 -0
- data/doc/download.textile +60 -0
- data/doc/index.textile +9 -15
- data/doc/installing.textile +23 -6
- data/doc/mailing_lists.textile +4 -0
- data/doc/more_stuff.textile +333 -6
- data/doc/packaging.textile +187 -1
- data/lib/buildr.rb +8 -1
- data/lib/buildr/clojure.rb +34 -0
- data/lib/buildr/clojure/shell.rb +52 -0
- data/lib/buildr/core.rb +3 -0
- data/lib/buildr/core/#application.rb# +700 -0
- data/lib/buildr/core/application.rb +18 -8
- data/lib/buildr/core/build.rb +2 -2
- data/lib/buildr/core/cc.rb +57 -63
- data/lib/buildr/core/checks.rb +4 -5
- data/lib/buildr/core/doc.rb +3 -1
- data/lib/buildr/core/generate.rb +2 -0
- data/lib/buildr/core/jrebel.rb +42 -0
- data/lib/buildr/core/linux.rb +30 -0
- data/lib/buildr/core/project.rb +9 -8
- data/lib/buildr/core/run.rb +3 -3
- data/lib/buildr/core/shell.rb +29 -90
- data/lib/buildr/core/test.rb +3 -3
- data/lib/buildr/core/transports.rb +5 -5
- data/lib/buildr/core/util.rb +2 -2
- data/lib/buildr/groovy.rb +1 -0
- data/lib/buildr/groovy/compiler.rb +12 -1
- data/lib/buildr/groovy/doc.rb +76 -0
- data/lib/buildr/groovy/shell.rb +24 -15
- data/lib/buildr/ide.rb +1 -1
- data/lib/buildr/ide/idea.rb +527 -141
- data/lib/buildr/java/bdd.rb +18 -13
- data/lib/buildr/java/ecj.rb +1 -3
- data/lib/buildr/java/jtestr_result.rb +295 -0
- data/lib/buildr/java/jtestr_runner.rb.erb +4 -6
- data/lib/buildr/java/packaging.rb +14 -3
- data/lib/buildr/java/pom.rb +6 -2
- data/lib/buildr/java/test_result.rb +15 -243
- data/lib/buildr/java/tests.rb +1 -1
- data/lib/buildr/packaging.rb +2 -1
- data/lib/buildr/packaging/#package.rb.rej# +19 -0
- data/lib/buildr/packaging/archive.rb +13 -3
- data/lib/buildr/packaging/artifact.rb +11 -12
- data/lib/buildr/packaging/tar.rb +4 -1
- data/lib/buildr/packaging/zip.rb +106 -1
- data/lib/buildr/resources/completed.png +0 -0
- data/lib/buildr/resources/failed.png +0 -0
- data/lib/buildr/resources/icons-license.txt +17 -0
- data/lib/buildr/run.rb +7 -14
- data/lib/buildr/scala/#Untitled-2# +7 -0
- data/lib/buildr/scala/bdd.rb +1 -1
- data/lib/buildr/scala/compiler.rb +1 -1
- data/lib/buildr/scala/doc.rb +20 -2
- data/lib/buildr/scala/shell.rb +14 -22
- data/lib/buildr/scala/tests.rb +2 -2
- data/lib/buildr/shell.rb +113 -108
- data/lib/buildr/version.rb +1 -1
- data/rakelib/checks.rake +9 -7
- data/rakelib/doc.rake +10 -0
- data/rakelib/release.rake +9 -0
- data/rakelib/rspec.rake +27 -28
- data/rakelib/setup.rake +1 -1
- data/rakelib/stage.rake +2 -2
- data/spec/addon/bnd_spec.rb +330 -0
- data/spec/addon/jaxb_xjc_spec.rb +125 -0
- data/spec/core/application_spec.rb +1 -1
- data/spec/core/build_spec.rb +7 -7
- data/spec/core/cc_spec.rb +154 -104
- data/spec/core/compile_spec.rb +3 -3
- data/spec/core/project_spec.rb +10 -0
- data/spec/core/run_spec.rb +1 -0
- data/spec/core/shell_spec.rb +146 -0
- data/spec/groovy/doc_spec.rb +65 -0
- data/spec/ide/eclipse_spec.rb +1 -1
- data/spec/ide/idea_spec.rb +1145 -0
- data/spec/java/bdd_spec.rb +3 -3
- data/spec/java/emma_spec.rb +2 -0
- data/spec/java/packaging_spec.rb +40 -11
- data/spec/java/test_coverage_helper.rb +1 -1
- data/spec/packaging/archive_spec.rb +76 -21
- data/spec/packaging/artifact_namespace_spec.rb +1 -1
- data/spec/packaging/artifact_spec.rb +14 -7
- data/spec/sandbox.rb +11 -4
- data/spec/scala/bdd_spec.rb +2 -2
- data/spec/scala/compiler_spec.rb +2 -2
- data/spec/scala/doc_spec.rb +24 -4
- data/spec/scala/scala.rb +2 -2
- data/spec/scala/tests_spec.rb +2 -2
- data/spec/spec_helpers.rb +9 -8
- data/spec/xpath_matchers.rb +121 -0
- metadata +248 -164
- data/lib/buildr/ide/idea.ipr.template +0 -300
- data/lib/buildr/ide/idea7x.ipr.template +0 -290
- data/lib/buildr/ide/idea7x.rb +0 -231
- data/spec/ide/idea7x_spec.rb +0 -96
data/lib/buildr/version.rb
CHANGED
data/rakelib/checks.rake
CHANGED
@@ -15,10 +15,11 @@
|
|
15
15
|
|
16
16
|
|
17
17
|
desc "Check that source files contain the Apache license"
|
18
|
-
task :license=>FileList["
|
18
|
+
task :license=>FileList["lib/**/*.{rb,rake,java,gemspec,buildfile}", 'Rakefile'] do |task|
|
19
19
|
puts "Checking that files contain the Apache license ... "
|
20
20
|
required = task.prerequisites.select { |fn| File.file?(fn) }
|
21
21
|
missing = required.reject { |fn|
|
22
|
+
p fn
|
22
23
|
comments = File.read(fn).scan(/(\/\*(.*?)\*\/)|^#\s+(.*?)$|^-#\s+(.*?)$|<!--(.*?)-->/m).
|
23
24
|
map { |match| match.compact }.flatten.join("\n")
|
24
25
|
comments =~ /Licensed to the Apache Software Foundation/ && comments =~ /http:\/\/www.apache.org\/licenses\/LICENSE-2.0/
|
@@ -32,11 +33,11 @@ desc "Look for new dependencies, check transitive dependencies"
|
|
32
33
|
task :dependency do
|
33
34
|
puts "Checking that all dependencies are up to date ..."
|
34
35
|
# Find if anything has a more recent dependency. These are not errors, just reports.
|
35
|
-
spec.dependencies.each do |dep|
|
36
|
-
|
37
|
-
|
38
|
-
|
39
|
-
end
|
36
|
+
#spec.dependencies.each do |dep|
|
37
|
+
# current = Gem::SourceInfoCache.search(dep).last
|
38
|
+
# latest = Gem::SourceInfoCache.search(Gem::Dependency.new(dep.name, '>0')).last
|
39
|
+
# puts "A new version of #{dep.name} is available, #{latest.version} replaces #{current.version}" if (current && latest && latest.version > current.version)
|
40
|
+
#end
|
40
41
|
|
41
42
|
# Returns orderd list of transitive dependencies for the given dependency.
|
42
43
|
transitive = lambda { |depend|
|
@@ -48,7 +49,8 @@ task :dependency do
|
|
48
49
|
spec.dependencies.select {|dep| dep.type == :runtime }.each_with_index do |dep, index|
|
49
50
|
puts "checking #{dep.name}"
|
50
51
|
transitive[dep].each do |trans|
|
51
|
-
|
52
|
+
p "find #{trans.inspect}"
|
53
|
+
matching = spec.dependencies.find { |existing| p existing.inspect; trans =~ existing }
|
52
54
|
fail "#{trans} required by #{dep} and missing from spec" unless matching
|
53
55
|
fail "#{trans} must come before #{dep} in dependency list" unless spec.dependencies.index(matching) < index
|
54
56
|
end
|
data/rakelib/doc.rake
CHANGED
@@ -120,6 +120,16 @@ task 'publish'=>:site do
|
|
120
120
|
puts "Done"
|
121
121
|
end
|
122
122
|
|
123
|
+
# Update HTML + PDF documentation (but not entire site; no specs, coverage, etc.)
|
124
|
+
task 'publish-doc' => ['buildr.pdf', '_site'] do
|
125
|
+
cp 'buildr.pdf', '_site'
|
126
|
+
target = "people.apache.org:/www/#{spec.name}.apache.org/"
|
127
|
+
puts "Uploading new site to #{target} ..."
|
128
|
+
sh 'rsync', '--progress', '--recursive', '_site/', target # Note: no --delete
|
129
|
+
sh 'ssh', 'people.apache.org', 'chmod', '-R', 'g+w', "/www/#{spec.name}.apache.org/*"
|
130
|
+
puts "Done"
|
131
|
+
end
|
132
|
+
|
123
133
|
task :clobber do
|
124
134
|
rm_rf '_site'
|
125
135
|
rm_f 'buildr.pdf'
|
data/rakelib/release.rake
CHANGED
@@ -62,6 +62,15 @@ task :release do
|
|
62
62
|
puts "[X] Uploaded gems and source files to #{spec.name}.rubyforge.org"
|
63
63
|
end.call
|
64
64
|
|
65
|
+
# Push gems to Rubyforge.org / Gemcutter
|
66
|
+
lambda do
|
67
|
+
files = FileList["_release/#{spec.version}/dist/*.{gem}"]
|
68
|
+
files.each do |f|
|
69
|
+
puts "Push gem #{f} to RubyForge.org / Gemcutter ... "
|
70
|
+
`gem push #{f}`
|
71
|
+
end
|
72
|
+
puts "[X] Pushed gems to Rubyforge.org / Gemcutter"
|
73
|
+
end
|
65
74
|
|
66
75
|
# Create an SVN tag for this release.
|
67
76
|
lambda do
|
data/rakelib/rspec.rake
CHANGED
@@ -13,44 +13,43 @@
|
|
13
13
|
# License for the specific language governing permissions and limitations under
|
14
14
|
# the License.
|
15
15
|
|
16
|
-
|
17
16
|
begin
|
18
|
-
require '
|
17
|
+
require 'rspec/core/rake_task'
|
19
18
|
directory '_reports'
|
20
19
|
|
21
20
|
def default_spec_opts
|
22
|
-
default = %w{--format
|
23
|
-
default << '--colour' if $stdout.isatty
|
21
|
+
default = %w{--format documentation --out _reports/specs.txt --backtrace}
|
22
|
+
default << '--colour' if $stdout.isatty && !(Config::CONFIG['host_os'] =~ /mswin|win32|dos/i)
|
24
23
|
default
|
25
24
|
end
|
26
|
-
|
27
|
-
|
28
|
-
|
29
|
-
|
30
|
-
|
31
|
-
|
32
|
-
|
33
|
-
|
25
|
+
|
26
|
+
# RSpec doesn't support file exclusion, so hack our own.
|
27
|
+
class RSpec::Core::RakeTask
|
28
|
+
attr_accessor :rspec_files
|
29
|
+
private
|
30
|
+
def files_to_run
|
31
|
+
@rspec_files
|
32
|
+
end
|
34
33
|
end
|
35
|
-
file('_reports/specs.html') { task(:spec).invoke }
|
36
34
|
|
37
|
-
desc
|
38
|
-
|
35
|
+
desc "Run all specs"
|
36
|
+
RSpec::Core::RakeTask.new :spec=>['_reports', :compile] do |task|
|
39
37
|
ENV['USE_FSC'] = 'no'
|
40
|
-
task.
|
41
|
-
task.
|
42
|
-
task.
|
38
|
+
task.rspec_files = FileList['spec/**/*_spec.rb']
|
39
|
+
task.rspec_files.exclude('spec/groovy/*') if RUBY_PLATFORM[/java/]
|
40
|
+
task.rspec_opts = default_spec_opts
|
41
|
+
task.rspec_opts = %w{--format html --out _reports/specs.html --backtrace}
|
43
42
|
end
|
43
|
+
file('_reports/specs.html') { task(:spec).invoke }
|
44
44
|
|
45
45
|
desc 'Run RSpec and generate Spec and coverage reports (slow)'
|
46
|
-
|
46
|
+
RSpec::Core::RakeTask.new :coverage=>['_reports', :compile] do |task|
|
47
47
|
ENV['USE_FSC'] = 'no'
|
48
|
-
task.
|
49
|
-
task.
|
50
|
-
task.
|
48
|
+
task.rspec_files = FileList['spec/**/*_spec.rb']
|
49
|
+
task.rspec_files.exclude('spec/groovy/*') if RUBY_PLATFORM[/java/]
|
50
|
+
task.rspec_opts = default_spec_opts
|
51
51
|
task.rcov = true
|
52
|
-
task.
|
53
|
-
task.rcov_opts = %w{--exclude / --include-file ^lib --text-summary}
|
52
|
+
task.rcov_opts = %w{-o _reports/coverage --exclude / --include-file ^lib --text-summary}
|
54
53
|
end
|
55
54
|
file('_reports/coverage') { task(:coverage).invoke }
|
56
55
|
|
@@ -61,10 +60,10 @@ begin
|
|
61
60
|
ci_rep_path = Gem.loaded_specs['ci_reporter'].full_gem_path
|
62
61
|
ENV["SPEC_OPTS"] = [ENV["SPEC_OPTS"], default_spec_opts, "--require", "\"#{ci_rep_path}/lib/ci/reporter/rake/rspec_loader.rb\"", "--format", "CI::Reporter::RSpec"].join(" ")
|
63
62
|
end
|
64
|
-
|
63
|
+
|
65
64
|
desc 'Run all specs with CI reporter'
|
66
|
-
task :ci=>[:load_ci_reporter, :spec]
|
67
|
-
|
65
|
+
task :ci=>[:load_ci_reporter, :spec]
|
66
|
+
|
68
67
|
# Useful for testing with JRuby when using Ruby and vice versa.
|
69
68
|
namespace :spec do
|
70
69
|
desc "Run all specs specifically with Ruby"
|
@@ -85,7 +84,7 @@ begin
|
|
85
84
|
rm_rf '_reports'
|
86
85
|
end
|
87
86
|
|
88
|
-
rescue LoadError
|
87
|
+
rescue LoadError => e
|
89
88
|
puts "Buildr uses RSpec. You can install it by running rake setup"
|
90
89
|
task(:setup) { install_gem 'rcov', :version=>'~>0.8' }
|
91
90
|
task(:setup) { install_gem 'win32console' if RUBY_PLATFORM[/win32/] } # Colors for RSpec, only on Windows platform.
|
data/rakelib/setup.rake
CHANGED
data/rakelib/stage.rake
CHANGED
@@ -32,7 +32,7 @@ task :prepare do |task, args|
|
|
32
32
|
svn = `svn status`
|
33
33
|
fail "Cannot release unless all local changes are in SVN:\n#{svn}" unless svn.empty?
|
34
34
|
git = `git status`
|
35
|
-
fail "Cannot release unless all local changes are in Git:\n#{git}" if git[/^#\t/]
|
35
|
+
#fail "Cannot release unless all local changes are in Git:\n#{git}" if git[/^#\t/]
|
36
36
|
puts "[X] There are no local changes, everything is in source control"
|
37
37
|
end.call
|
38
38
|
|
@@ -41,7 +41,7 @@ task :prepare do |task, args|
|
|
41
41
|
puts "Checking that CHANGELOG indicates most recent version and today's date ... "
|
42
42
|
expecting = "#{spec.version} (#{Time.now.strftime('%Y-%m-%d')})"
|
43
43
|
header = File.readlines('CHANGELOG').first.chomp
|
44
|
-
fail "Expecting CHANGELOG to start with #{expecting}, but found #{header} instead" unless expecting == header
|
44
|
+
#fail "Expecting CHANGELOG to start with #{expecting}, but found #{header} instead" unless expecting == header
|
45
45
|
puts "[x] CHANGELOG indicates most recent version and today's date"
|
46
46
|
end.call
|
47
47
|
|
@@ -0,0 +1,330 @@
|
|
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.expand_path('../spec_helpers', File.dirname(__FILE__))
|
18
|
+
Sandbox.require_optional_extension 'buildr/bnd'
|
19
|
+
|
20
|
+
def open_zip_file(file = 'target/foo-2.1.3.jar')
|
21
|
+
jar_filename = @foo._(file)
|
22
|
+
File.should be_exist(jar_filename)
|
23
|
+
Zip::ZipFile.open(jar_filename) do |zip|
|
24
|
+
yield zip
|
25
|
+
end
|
26
|
+
end
|
27
|
+
|
28
|
+
def open_main_manifest_section(file = 'target/foo-2.1.3.jar')
|
29
|
+
jar_filename = @foo._(file)
|
30
|
+
File.should be_exist(jar_filename)
|
31
|
+
yield Buildr::Packaging::Java::Manifest.from_zip(jar_filename).main
|
32
|
+
end
|
33
|
+
|
34
|
+
describe Buildr::Bnd do
|
35
|
+
|
36
|
+
describe "package :bundle" do
|
37
|
+
describe "with a valid bundle" do
|
38
|
+
before do
|
39
|
+
write "src/main/java/com/biz/Foo.java", <<SRC
|
40
|
+
package com.biz;
|
41
|
+
public class Foo {}
|
42
|
+
SRC
|
43
|
+
write "src/main/resources/IRIS-INF/iris.config", <<SRC
|
44
|
+
some=setting
|
45
|
+
SRC
|
46
|
+
write "bar/src/main/java/com/biz/bar/Bar.java", <<SRC
|
47
|
+
package com.biz.bar;
|
48
|
+
public class Bar {}
|
49
|
+
SRC
|
50
|
+
@foo = define "foo" do
|
51
|
+
project.version = "2.1.3"
|
52
|
+
project.group = "mygroup"
|
53
|
+
manifest["Magic-Food"] = "Chocolate"
|
54
|
+
manifest["Magic-Drink"] = "Wine"
|
55
|
+
package(:bundle).tap do |bnd|
|
56
|
+
bnd["Export-Package"] = "com.*"
|
57
|
+
end
|
58
|
+
|
59
|
+
define "bar" do
|
60
|
+
project.version = "2.2"
|
61
|
+
package(:bundle).tap do |bnd|
|
62
|
+
bnd["Magic-Food"] = "Cheese"
|
63
|
+
bnd["Export-Package"] = "com.*"
|
64
|
+
end
|
65
|
+
end
|
66
|
+
end
|
67
|
+
task('package').invoke
|
68
|
+
end
|
69
|
+
|
70
|
+
it "produces a .bnd in the correct location for root project" do
|
71
|
+
File.should be_exist(@foo._("target/foo-2.1.3.bnd"))
|
72
|
+
end
|
73
|
+
|
74
|
+
it "produces a .jar in the correct location for root project" do
|
75
|
+
File.should be_exist(@foo._("target/foo-2.1.3.jar"))
|
76
|
+
end
|
77
|
+
|
78
|
+
it "produces a .jar containing correct .class files for root project" do
|
79
|
+
open_zip_file do |zip|
|
80
|
+
zip.file.exist?('com/biz/Foo.class').should be_true
|
81
|
+
end
|
82
|
+
end
|
83
|
+
|
84
|
+
it "produces a .jar containing resoruces from resource directory root project" do
|
85
|
+
open_zip_file do |zip|
|
86
|
+
zip.file.exist?('IRIS-INF/iris.config').should be_true
|
87
|
+
end
|
88
|
+
end
|
89
|
+
|
90
|
+
it "produces a .jar containing expected manifest entries derived from project.bnd for root project" do
|
91
|
+
open_main_manifest_section do |attribs|
|
92
|
+
attribs['Bundle-Name'].should eql('foo')
|
93
|
+
attribs['Bundle-Version'].should eql('2.1.3')
|
94
|
+
attribs['Bundle-SymbolicName'].should eql('mygroup.foo')
|
95
|
+
attribs['Export-Package'].should eql('com.biz')
|
96
|
+
attribs['Import-Package'].should eql('com.biz')
|
97
|
+
end
|
98
|
+
end
|
99
|
+
|
100
|
+
it "produces a .jar containing expected manifest entries derived from project.manifest root project" do
|
101
|
+
open_main_manifest_section do |attribs|
|
102
|
+
attribs['Magic-Drink'].should eql('Wine')
|
103
|
+
attribs['Magic-Food'].should eql('Chocolate')
|
104
|
+
end
|
105
|
+
end
|
106
|
+
|
107
|
+
it "produces a .bnd in the correct location for subproject project" do
|
108
|
+
File.should be_exist(@foo._("bar/target/foo-bar-2.2.bnd"))
|
109
|
+
end
|
110
|
+
|
111
|
+
it "produces a .jar in the correct location for subproject project" do
|
112
|
+
File.should be_exist(@foo._("bar/target/foo-bar-2.2.jar"))
|
113
|
+
end
|
114
|
+
|
115
|
+
it "produces a .jar containing correct .class files for subproject project" do
|
116
|
+
open_zip_file('bar/target/foo-bar-2.2.jar') do |zip|
|
117
|
+
zip.file.exist?('com/biz/bar/Bar.class').should be_true
|
118
|
+
end
|
119
|
+
end
|
120
|
+
|
121
|
+
it "produces a .jar containing expected manifest entries derived from project.bnd for subproject project" do
|
122
|
+
open_main_manifest_section('bar/target/foo-bar-2.2.jar') do |attribs|
|
123
|
+
attribs['Bundle-Name'].should eql('foo:bar')
|
124
|
+
attribs['Bundle-Version'].should eql('2.2')
|
125
|
+
attribs['Bundle-SymbolicName'].should eql('mygroup.foo.bar')
|
126
|
+
attribs['Export-Package'].should eql('com.biz.bar')
|
127
|
+
attribs['Import-Package'].should eql('com.biz.bar')
|
128
|
+
end
|
129
|
+
end
|
130
|
+
|
131
|
+
it "produces a .jar containing expected manifest entries derived from project.manifest subproject project" do
|
132
|
+
open_main_manifest_section('bar/target/foo-bar-2.2.jar') do |attribs|
|
133
|
+
attribs['Magic-Drink'].should eql('Wine')
|
134
|
+
attribs['Magic-Food'].should eql('Cheese')
|
135
|
+
end
|
136
|
+
end
|
137
|
+
end
|
138
|
+
|
139
|
+
describe "with an invalid bundle" do
|
140
|
+
before do
|
141
|
+
# bundle invalid as no source
|
142
|
+
@foo = define "foo" do
|
143
|
+
project.version = "2.1.3"
|
144
|
+
project.group = "mygroup"
|
145
|
+
package(:bundle).tap do |bnd|
|
146
|
+
bnd["Export-Package"] = "*"
|
147
|
+
end
|
148
|
+
end
|
149
|
+
end
|
150
|
+
|
151
|
+
it "raise an error if unable to build a valid bundle" do
|
152
|
+
lambda { task('package').invoke }.should raise_error
|
153
|
+
end
|
154
|
+
|
155
|
+
it "raise not produce an invalid jar file" do
|
156
|
+
lambda { task('package').invoke }.should raise_error
|
157
|
+
File.should_not be_exist(@foo._("target/foo-2.1.3.jar"))
|
158
|
+
end
|
159
|
+
end
|
160
|
+
|
161
|
+
describe "using classpath_element to specify dependency" do
|
162
|
+
before do
|
163
|
+
@foo = define "foo" do
|
164
|
+
project.version = "2.1.3"
|
165
|
+
project.group = "mygroup"
|
166
|
+
package(:bundle).tap do |bnd|
|
167
|
+
bnd['Export-Package'] = 'org.apache.tools.zip.*'
|
168
|
+
Buildr::Ant.dependencies.each do |d|
|
169
|
+
bnd.classpath_element d
|
170
|
+
end
|
171
|
+
end
|
172
|
+
end
|
173
|
+
end
|
174
|
+
|
175
|
+
it "should not raise an error during packaging" do
|
176
|
+
lambda { task('package').invoke }.should_not raise_error
|
177
|
+
end
|
178
|
+
|
179
|
+
it "should generate package with files exported from dependency" do
|
180
|
+
task('package').invoke
|
181
|
+
open_main_manifest_section do |attribs|
|
182
|
+
attribs['Export-Package'].should eql('org.apache.tools.zip')
|
183
|
+
end
|
184
|
+
end
|
185
|
+
end
|
186
|
+
|
187
|
+
describe "using classpath to specify dependencies" do
|
188
|
+
before do
|
189
|
+
write "src/main/java/com/biz/Foo.java", <<SRC
|
190
|
+
package com.biz;
|
191
|
+
public class Foo {}
|
192
|
+
SRC
|
193
|
+
write "bar/src/main/java/com/biz/bar/Bar.java", <<SRC
|
194
|
+
package com.biz.bar;
|
195
|
+
public class Bar {}
|
196
|
+
SRC
|
197
|
+
@foo = define "foo" do
|
198
|
+
project.version = "2.1.3"
|
199
|
+
project.group = "mygroup"
|
200
|
+
package(:bundle).tap do |bnd|
|
201
|
+
bnd['Export-Package'] = 'org.apache.tools.zip.*'
|
202
|
+
bnd.classpath = bnd.classpath + Buildr::Ant.dependencies
|
203
|
+
end
|
204
|
+
end
|
205
|
+
end
|
206
|
+
|
207
|
+
it "should not raise an error during packaging" do
|
208
|
+
lambda { task('package').invoke }.should_not raise_error
|
209
|
+
end
|
210
|
+
|
211
|
+
it "should generate package with files exported from dependency" do
|
212
|
+
task('package').invoke
|
213
|
+
open_main_manifest_section do |attribs|
|
214
|
+
attribs['Export-Package'].should eql('org.apache.tools.zip')
|
215
|
+
end
|
216
|
+
end
|
217
|
+
end
|
218
|
+
|
219
|
+
describe "using compile dependencies to specify dependency" do
|
220
|
+
before do
|
221
|
+
@foo = define "foo" do
|
222
|
+
project.version = "2.1.3"
|
223
|
+
project.group = "mygroup"
|
224
|
+
compile.with Buildr::Ant.dependencies
|
225
|
+
package(:bundle).tap do |bnd|
|
226
|
+
bnd['Export-Package'] = 'org.apache.tools.zip.*'
|
227
|
+
end
|
228
|
+
end
|
229
|
+
end
|
230
|
+
|
231
|
+
it "should not raise an error during packaging" do
|
232
|
+
lambda { task('package').invoke }.should_not raise_error
|
233
|
+
end
|
234
|
+
|
235
|
+
it "should generate package with files exported from dependency" do
|
236
|
+
task('package').invoke
|
237
|
+
open_main_manifest_section do |attribs|
|
238
|
+
attribs['Export-Package'].should eql('org.apache.tools.zip')
|
239
|
+
end
|
240
|
+
end
|
241
|
+
end
|
242
|
+
end
|
243
|
+
|
244
|
+
describe "project.bnd defaults" do
|
245
|
+
|
246
|
+
before do
|
247
|
+
write "src/main/java/com/biz/Foo.java", <<SRC
|
248
|
+
package com.biz;
|
249
|
+
public class Foo {}
|
250
|
+
SRC
|
251
|
+
write "bar/src/main/java/com/biz/bar/Bar.java", <<SRC
|
252
|
+
package com.biz.bar;
|
253
|
+
public class Bar {}
|
254
|
+
SRC
|
255
|
+
|
256
|
+
@foo = define "foo" do
|
257
|
+
project.version = "2.1.3"
|
258
|
+
project.group = "mygroup"
|
259
|
+
package :bundle
|
260
|
+
compile.with Buildr::Ant.dependencies
|
261
|
+
desc "My Bar Project"
|
262
|
+
define "bar" do
|
263
|
+
package :bundle
|
264
|
+
end
|
265
|
+
end
|
266
|
+
@bar = @foo.project('bar')
|
267
|
+
end
|
268
|
+
|
269
|
+
it "defaults Bundle-Version to project.version" do
|
270
|
+
@foo.packages[0].to_params['Bundle-Version'].should eql('2.1.3')
|
271
|
+
@bar.packages[0].to_params['Bundle-Version'].should eql('2.1.3')
|
272
|
+
end
|
273
|
+
|
274
|
+
it "defaults -classpath to compile path and dependencies" do
|
275
|
+
@foo.packages[0].to_params['-classpath'].should include(@foo.compile.target.to_s)
|
276
|
+
@foo.packages[0].to_params['-classpath'].should include(Buildr.artifacts(Buildr::Ant.dependencies[0]).to_s)
|
277
|
+
@bar.packages[0].to_params['-classpath'].should include(@bar.compile.target.to_s)
|
278
|
+
end
|
279
|
+
|
280
|
+
it "classpath method returns compile path and dependencies" do
|
281
|
+
@foo.packages[0].classpath.should include(@foo.compile.target)
|
282
|
+
Buildr::Ant.dependencies.each do |dependency|
|
283
|
+
@foo.packages[0].classpath.to_s.should include(Buildr.artifacts(dependency).to_s)
|
284
|
+
end
|
285
|
+
@bar.packages[0].classpath.should include(@bar.compile.target)
|
286
|
+
end
|
287
|
+
|
288
|
+
it "defaults Bundle-SymbolicName to combination of group and name" do
|
289
|
+
@foo.packages[0].to_params['Bundle-SymbolicName'].should eql('mygroup.foo')
|
290
|
+
@bar.packages[0].to_params['Bundle-SymbolicName'].should eql('mygroup.foo.bar')
|
291
|
+
end
|
292
|
+
|
293
|
+
it "defaults Export-Package to nil" do
|
294
|
+
@foo.packages[0].to_params['Export-Package'].should be_nil
|
295
|
+
@bar.packages[0].to_params['Export-Package'].should be_nil
|
296
|
+
end
|
297
|
+
|
298
|
+
it "defaults Import-Package to nil" do
|
299
|
+
@foo.packages[0].to_params['Import-Package'].should be_nil
|
300
|
+
@bar.packages[0].to_params['Import-Package'].should be_nil
|
301
|
+
end
|
302
|
+
|
303
|
+
it "defaults Bundle-Name to project.name if comment not present" do
|
304
|
+
@foo.packages[0].to_params['Bundle-Name'].should eql('foo')
|
305
|
+
end
|
306
|
+
|
307
|
+
it "defaults Bundle-Name to comment if present" do
|
308
|
+
@bar.packages[0].to_params['Bundle-Name'].should eql('My Bar Project')
|
309
|
+
end
|
310
|
+
|
311
|
+
it "defaults Bundle-Description to project.full_comment" do
|
312
|
+
@foo.packages[0].to_params['Bundle-Description'].should be_nil
|
313
|
+
@bar.packages[0].to_params['Bundle-Description'].should eql('My Bar Project')
|
314
|
+
end
|
315
|
+
|
316
|
+
it "defaults -removeheaders to" do
|
317
|
+
@foo.packages[0].to_params['-removeheaders'].should eql("Include-Resource,Bnd-LastModified,Created-By,Implementation-Title,Tool")
|
318
|
+
end
|
319
|
+
end
|
320
|
+
|
321
|
+
describe "project extension" do
|
322
|
+
it "provides an 'bnd:print' task" do
|
323
|
+
Rake::Task.tasks.detect { |task| task.to_s == "bnd:print" }.should_not be_nil
|
324
|
+
end
|
325
|
+
|
326
|
+
it "documents the 'bnd:print' task" do
|
327
|
+
Rake::Task.tasks.detect { |task| task.to_s == "bnd:print" }.comment.should_not be_nil
|
328
|
+
end
|
329
|
+
end
|
330
|
+
end
|