forked from cloudfoundry/ibm-websphere-liberty-buildpack
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Rakefile
100 lines (90 loc) · 3.08 KB
/
Rakefile
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
# IBM WebSphere Application Server Liberty Buildpack
# Copyright (c) 2013 the original author or authors.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
require 'rspec/core/rake_task'
RSpec::Core::RakeTask.new(:spec) do |t|
t.rspec_opts = '--tty' if ENV.has_key? 'RAKE_FORCE_COLOR'
end
require 'ci/reporter/rake/rspec'
task :spec => "ci:setup:rspec"
require 'yard'
YARD::Rake::YardocTask.new do |t|
t.options = ['--no-stats']
end
require 'rubocop/rake_task'
Rubocop::RakeTask.new do |t|
Sickill::Rainbow.enabled = true if ENV.has_key? 'RAKE_FORCE_COLOR'
end
require 'open3'
task :check_api_doc do
puts "\nChecking API documentation..."
output = Open3.capture3("yard stats --list-undoc")[0]
if output !~ /100.00% documented/
puts "\nFailed due to undocumented public API:\n\n#{output}"
exit 1
else
puts "\n#{output}\n"
end
end
require 'rake/clean'
CLEAN.include %w(.yardoc coverage)
CLOBBER.include %w(doc pkg)
task :default => [ :rubocop, :check_api_doc, :yard, :spec ]
desc "Package buildpack together with admin cache"
task :package, [:zipfile, :hosts] do |t, args|
source = File.dirname(__FILE__)
basename = File.basename(source)
if args.zipfile.nil?
hash = `git rev-parse --short HEAD`.chomp
zipfile = File.expand_path(File.join('..', "#{basename}-#{hash}.zip"), source)
else
zipfile = File.expand_path(args.zipfile)
zipfile << ".zip" unless zipfile.end_with? (".zip")
end
puts "Using #{zipfile} as a buildpack zip output file"
if File.exists? (zipfile)
puts "The output file already exists. Change the output location."
exit 1
end
if args.hosts == '*'
cache_hosts = nil
puts "Caching all resources"
elsif args.hosts == '-'
cache_hosts = []
puts "Caching disabled"
else
if args.hosts.nil?
cache_hosts = ['public.dhe.ibm.com']
else
cache_hosts = args.hosts.split
end
puts "Caching files hosted on #{cache_hosts.join(', ')}"
end
require 'tmpdir'
Dir.mktmpdir do |root|
$LOAD_PATH.unshift File.expand_path(File.join('..', 'resources'), __FILE__)
require 'download_buildpack_cache'
FileUtils.cp_r(source, root)
dest = File.join(root, basename)
bc = BuildpackCache.new(File.join(dest, 'admin_cache'))
# Collect all remote content using all config files
configs = bc.collect_configs nil, cache_hosts
bc.download_cache(configs)
# Fix file permissions
system("find #{dest} -type f -exec chmod a+r {} \\;")
system("find #{dest} -type d -exec chmod a+rx {} \\;")
system("chmod a+rx #{dest}/bin/*")
system("cd #{dest} && zip -r #{zipfile} [email protected] .")
end
end