ood_packaging 0.0.1.rc.7 → 0.0.3.r2.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/bin/ood_packaging +3 -7
- data/lib/ood_packaging/build.rb +29 -5
- data/lib/ood_packaging/build_box/docker-image/Dockerfile.erb +12 -9
- data/lib/ood_packaging/build_box/docker-image/install.sh.erb +1 -1
- data/lib/ood_packaging/build_box.rb +6 -0
- data/lib/ood_packaging/package.rb +64 -30
- data/lib/ood_packaging/tasks.rb +9 -2
- data/lib/ood_packaging/utils.rb +2 -2
- data/lib/ood_packaging/version.rb +8 -8
- metadata +3 -3
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 7fcaaed05fcdf85f942480ee3c0c983dcb636e68c033ad2e613bbda346893109
|
4
|
+
data.tar.gz: 96a5eea4c809d8d076374dc0d2855e5b390cb5f42410edb8e60fee23349b534f
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 506cc31f4d30572a1d8c1e38e338d3133bca116a1543d861ba9c8b3ea489f4924c19428d3f9d8aa7aaf0ff332f9b8e5345a224fdd88bbbc587c4b6fef00e2200
|
7
|
+
data.tar.gz: df75dfdf6f84cf24bd1b3a6f2b3572106e417fbe0af705f390ac74fd74b0273833229347fc26ce6fb4f20145e6f3263cadfc1dd1294fe7138263c2270e965787
|
data/bin/ood_packaging
CHANGED
@@ -2,13 +2,9 @@
|
|
2
2
|
# frozen_string_literal: true
|
3
3
|
|
4
4
|
require 'optparse'
|
5
|
-
|
6
|
-
|
7
|
-
|
8
|
-
rescue LoadError
|
9
|
-
$LOAD_PATH.unshift(File.expand_path(File.join(__dir__, '../lib')))
|
10
|
-
require 'ood_packaging'
|
11
|
-
end
|
5
|
+
libdir = File.expand_path(File.join(__dir__, '../lib'))
|
6
|
+
$LOAD_PATH.unshift(libdir) if Dir.exist?(libdir)
|
7
|
+
require 'ood_packaging'
|
12
8
|
|
13
9
|
options = {}
|
14
10
|
OptionParser.new do |opts|
|
data/lib/ood_packaging/build.rb
CHANGED
@@ -76,6 +76,8 @@ class OodPackaging::Build
|
|
76
76
|
'/package/rpm'
|
77
77
|
elsif Dir.exist?('/package/packaging/rpm')
|
78
78
|
'/package/packaging/rpm'
|
79
|
+
elsif Dir.exist?('/package/packaging')
|
80
|
+
'/package/packaging'
|
79
81
|
else
|
80
82
|
'/package'
|
81
83
|
end
|
@@ -92,6 +94,8 @@ class OodPackaging::Build
|
|
92
94
|
def debian_dir
|
93
95
|
@debian_dir ||= if Dir.exist?('/package/deb/debian')
|
94
96
|
'/package/deb/debian'
|
97
|
+
elsif Dir.exist?('/package/packaging/deb')
|
98
|
+
'/package/packaging/deb'
|
95
99
|
else
|
96
100
|
'/package/debian'
|
97
101
|
end
|
@@ -142,6 +146,7 @@ class OodPackaging::Build
|
|
142
146
|
rpmbuild! if build_box.rpm?
|
143
147
|
debuild! if build_box.deb?
|
144
148
|
copy_output!
|
149
|
+
show_output!
|
145
150
|
gpg_sign! if build_box.rpm? && gpg_sign?
|
146
151
|
sanity!
|
147
152
|
end
|
@@ -190,10 +195,17 @@ class OodPackaging::Build
|
|
190
195
|
def bootstrap_get_source!
|
191
196
|
if ENV['SKIP_DOWNLOAD'] == 'true'
|
192
197
|
puts "\tSKIP_DOWNLOAD detected, skipping download sources".blue
|
193
|
-
|
194
|
-
puts "\tDownloading sources defined in #{spec_file}".blue
|
195
|
-
sh "spectool #{rpm_defines.join(' ')} -g -R -S #{spec_file}#{cmd_suffix}"
|
198
|
+
return
|
196
199
|
end
|
200
|
+
output = `spectool #{rpm_defines.join(' ')} -l -R -S #{spec_file} 2>&1 | grep 'Source0:'`.strip
|
201
|
+
exit_code = $CHILD_STATUS.exitstatus
|
202
|
+
if exit_code.zero?
|
203
|
+
source = File.join(work_dir, 'SOURCES', File.basename(output))
|
204
|
+
tar = File.join(work_dir, 'SOURCES', ENV['TAR_NAME'])
|
205
|
+
sh "mv #{tar} #{source}" if !File.exist?(source) && File.exist?(tar)
|
206
|
+
end
|
207
|
+
puts "\tDownloading sources defined in #{spec_file}".blue
|
208
|
+
sh "spectool #{rpm_defines.join(' ')} -g -R -S #{spec_file}#{cmd_suffix}"
|
197
209
|
end
|
198
210
|
|
199
211
|
def bootstrap_deb!
|
@@ -210,7 +222,7 @@ class OodPackaging::Build
|
|
210
222
|
puts "\tBootstrap debian build files".blue
|
211
223
|
Dir.chdir(deb_work_dir) do
|
212
224
|
sh "dh_make -s -y --createorig -f ../#{deb_name}.tar.gz#{cmd_suffix} || true"
|
213
|
-
sh "dch -b -v #{deb_version} 'Release #{deb_version}'#{cmd_suffix}"
|
225
|
+
sh "dch -b -v #{deb_version} --controlmaint 'Release #{deb_version}'#{cmd_suffix}"
|
214
226
|
end
|
215
227
|
end
|
216
228
|
|
@@ -236,9 +248,14 @@ class OodPackaging::Build
|
|
236
248
|
|
237
249
|
def install_deb_dependencies!
|
238
250
|
sh "sudo apt update -y#{cmd_suffix}"
|
251
|
+
tool = [
|
252
|
+
'DEBIAN_FRONTEND=noninteractive apt-cudf-get --solver aspcud',
|
253
|
+
'-o APT::Get::Assume-Yes=1 -o APT::Get::Allow-Downgrades=1',
|
254
|
+
'-o Debug::pkgProblemResolver=0 -o APT::Install-Recommends=0'
|
255
|
+
]
|
239
256
|
cmd = [
|
240
257
|
'mk-build-deps --install --remove --root-cmd sudo',
|
241
|
-
"--tool='
|
258
|
+
"--tool='#{tool.join(' ')}'"
|
242
259
|
]
|
243
260
|
Dir.chdir(deb_work_dir) do
|
244
261
|
sh "#{cmd.join(' ')}#{cmd_suffix}"
|
@@ -277,6 +294,13 @@ class OodPackaging::Build
|
|
277
294
|
end
|
278
295
|
end
|
279
296
|
|
297
|
+
def show_output!
|
298
|
+
puts '== Copied output =='.blue
|
299
|
+
Dir["#{output_dir}/*"].each do |f|
|
300
|
+
puts "\tSaved output #{f}".blue
|
301
|
+
end
|
302
|
+
end
|
303
|
+
|
280
304
|
def gpg_sign!
|
281
305
|
puts '== GPG sign RPMs =='.blue
|
282
306
|
rpms.each do |rpm|
|
@@ -2,32 +2,35 @@ FROM <%= base_image %>
|
|
2
2
|
MAINTAINER Trey Dockendorf <tdockendorf@osc.edu>
|
3
3
|
ENV LANG=en_US.UTF-8
|
4
4
|
ENV LC_CTYPE=en_US.UTF-8
|
5
|
+
ENV USER=<%= ctr_user %>
|
5
6
|
ENV GEM_PATH=<%= ctr_gems_dir %>:
|
6
|
-
<% if
|
7
|
+
<% if scl? -%>
|
7
8
|
RUN yum update -y && yum clean all && rm -rf /var/cache/yum/*
|
8
9
|
RUN yum install -y yum-utils epel-release centos-release-scl && yum clean all && rm -rf /var/cache/yum/*
|
9
10
|
RUN yum install -y <%= scl_ruby %>-ruby sudo which wget @buildsys-build \
|
10
11
|
rpm-build rpmdevtools rpm-sign scl-utils-build && \
|
11
12
|
yum clean all && rm -rf /var/cache/yum/*
|
12
|
-
|
13
|
+
RUN rm -f /etc/yum.repos.d/CentOS-Vault.repo /etc/yum.repos.d/CentOS-Sources.repo
|
14
|
+
RUN head -n 13 /etc/yum.repos.d/CentOS-SCLo-scl.repo > /etc/yum.repos.d/CentOS-SCLo.repo
|
15
|
+
RUN head -n 13 /etc/yum.repos.d/CentOS-SCLo-scl-rh.repo >> /etc/yum.repos.d/CentOS-SCLo.repo
|
16
|
+
RUN rm -f /etc/yum.repos.d/CentOS-SCLo-scl-rh.repo /etc/yum.repos.d/CentOS-SCLo-scl.repo
|
17
|
+
<% elsif dnf? -%>
|
13
18
|
RUN dnf update -y && dnf clean all && rm -rf /var/cache/dnf/*
|
14
19
|
RUN dnf install -y dnf-utils epel-release langpacks-en glibc-all-langpacks && dnf clean all && rm -rf /var/cache/dnf/*
|
15
20
|
RUN dnf config-manager --set-enabled powertools && dnf clean all && rm -rf /var/cache/dnf/*
|
16
|
-
RUN dnf module enable -y ruby:<%= ruby_version %> && dnf clean all && rm -rf /var/cache/dnf/*
|
17
|
-
RUN dnf
|
18
|
-
RUN dnf install -y ruby sudo which wget \
|
21
|
+
RUN dnf module enable -y ruby:<%= ruby_version %> nodejs:<%= nodejs_version %> && dnf clean all && rm -rf /var/cache/dnf/*
|
22
|
+
RUN dnf install -y systemd ruby nodejs sudo which wget \
|
19
23
|
gcc-c++ gcc make patch \
|
20
24
|
rpm-build rpmdevtools rpm-sign scl-utils-build && \
|
21
25
|
dnf clean all && rm -rf /var/cache/dnf/*
|
22
|
-
<% elsif
|
26
|
+
<% elsif deb? -%>
|
23
27
|
ENV DEBIAN_FRONTEND=noninteractive
|
24
28
|
RUN apt update -y && apt upgrade -y && apt clean all -y
|
25
29
|
RUN apt update -y && apt install -y locales && locale-gen $LANG && \
|
26
30
|
apt clean all -y
|
27
31
|
RUN apt update -y && apt install -y apt-transport-https ca-certificates \
|
28
|
-
init debhelper devscripts dh-make build-essential lintian equivs \
|
29
|
-
sudo rake wget curl ruby && \
|
30
|
-
ln -snf /bin/bundle2.7 /bin/bundle && \
|
32
|
+
init debhelper devscripts dh-make build-essential apt-cudf lintian equivs \
|
33
|
+
sudo rake wget curl ruby bundler && \
|
31
34
|
apt clean all -y
|
32
35
|
RUN echo "deb https://deb.nodesource.com/node_<%= nodejs_version %>.x <%= codename %> main" > /etc/apt/sources.list.d/nodesource.list
|
33
36
|
RUN curl -s https://deb.nodesource.com/gpgkey/nodesource.gpg.key | gpg --dearmor > /etc/apt/trusted.gpg.d/nodesource.gpg
|
@@ -72,7 +72,7 @@ echo "allow-loopback-pinentry" >> <%= ctr_gpg_dir %>/gpg-agent.conf
|
|
72
72
|
<%- end -%>
|
73
73
|
|
74
74
|
header "Install ood_packaging gem"
|
75
|
-
<%- if
|
75
|
+
<%- if scl? -%>
|
76
76
|
run scl enable <%= scl_ruby %> -- gem install --no-doc --bindir <%= ctr_scripts_dir %> --install-dir <%= ctr_gems_dir %> /build/*.gem
|
77
77
|
<%- else -%>
|
78
78
|
run gem install --no-doc --bindir <%= ctr_scripts_dir %> --install-dir <%= ctr_gems_dir %> /build/*.gem
|
@@ -12,10 +12,12 @@ class OodPackaging::BuildBox
|
|
12
12
|
BASE_IMAGES = {
|
13
13
|
'el7' => 'centos:7',
|
14
14
|
'el8' => 'rockylinux/rockylinux:8',
|
15
|
+
'ubuntu-18.04' => 'ubuntu:18.04',
|
15
16
|
'ubuntu-20.04' => 'ubuntu:20.04'
|
16
17
|
}.freeze
|
17
18
|
|
18
19
|
CODENAMES = {
|
20
|
+
'ubuntu-18.04' => 'bionic',
|
19
21
|
'ubuntu-20.04' => 'focal'
|
20
22
|
}.freeze
|
21
23
|
|
@@ -133,6 +135,10 @@ class OodPackaging::BuildBox
|
|
133
135
|
sh [container_runtime, 'push', image_tag].join(' ')
|
134
136
|
end
|
135
137
|
|
138
|
+
def pull!
|
139
|
+
sh [container_runtime, 'pull', image_tag].join(' ')
|
140
|
+
end
|
141
|
+
|
136
142
|
def save!(path)
|
137
143
|
sh [container_runtime, 'save', image_tag, '| gzip >', path].join(' ')
|
138
144
|
end
|
@@ -21,8 +21,6 @@ class OodPackaging::Package
|
|
21
21
|
@config = config
|
22
22
|
@config[:dist] = 'el8' if tar_only?
|
23
23
|
@build_box = OodPackaging::BuildBox.new(config)
|
24
|
-
@clean_work_dir = config[:clean_work_dir].nil? ? true : config[:clean_work_dir]
|
25
|
-
@clean_output_dir = config[:clean_output_dir].nil? ? true : config[:clean_output_dir]
|
26
24
|
raise ArgumentError, 'Package is required' if package.nil?
|
27
25
|
raise ArgumentError, 'Version is required' if version.nil?
|
28
26
|
raise ArgumentError, "Package #{package} is not a directory" unless Dir.exist?(package)
|
@@ -33,12 +31,18 @@ class OodPackaging::Package
|
|
33
31
|
@container_name ||= SecureRandom.uuid
|
34
32
|
end
|
35
33
|
|
36
|
-
def debug
|
34
|
+
def debug?
|
37
35
|
return true if ENV['OOD_PACKAGING_DEBUG'] == 'true'
|
38
36
|
|
39
37
|
@config[:debug].nil? ? false : @config[:debug]
|
40
38
|
end
|
41
39
|
|
40
|
+
def cmd_suffix
|
41
|
+
return '' if debug?
|
42
|
+
|
43
|
+
' 2>/dev/null 1>/dev/null'
|
44
|
+
end
|
45
|
+
|
42
46
|
def attach?
|
43
47
|
return true if ENV['OOD_PACKAGING_ATTACH'] == 'true'
|
44
48
|
|
@@ -49,10 +53,22 @@ class OodPackaging::Package
|
|
49
53
|
@work_dir ||= File.expand_path(@config[:work_dir])
|
50
54
|
end
|
51
55
|
|
56
|
+
def clean_work_dir
|
57
|
+
return false if ENV['OOD_PACKAGING_CLEAN_WORK_DIR'] == 'false'
|
58
|
+
|
59
|
+
@config[:clean_work_dir].nil? ? true : @config[:clean_work_dir]
|
60
|
+
end
|
61
|
+
|
52
62
|
def output_dir
|
53
63
|
@output_dir ||= File.expand_path(@config[:output_dir])
|
54
64
|
end
|
55
65
|
|
66
|
+
def clean_output_dir
|
67
|
+
return false if ENV['OOD_PACKAGING_CLEAN_OUTPUT_DIR'] == 'false'
|
68
|
+
|
69
|
+
@config[:clean_output_dir].nil? ? true : @config[:clean_output_dir]
|
70
|
+
end
|
71
|
+
|
56
72
|
def package
|
57
73
|
@config[:package]
|
58
74
|
end
|
@@ -90,8 +106,6 @@ class OodPackaging::Package
|
|
90
106
|
|
91
107
|
def gpg_files
|
92
108
|
[
|
93
|
-
OpenStruct.new(private_key: File.join(proj_root, 'ondemand.sec'), passphrase: File.join(proj_root, '.gpgpass')),
|
94
|
-
OpenStruct.new(private_key: File.join(package, 'ondemand.sec'), passphrase: File.join(package, '.gpgpass')),
|
95
109
|
OpenStruct.new(private_key: @config[:gpg_private_key], passphrase: @config[:gpg_passphrase]),
|
96
110
|
OpenStruct.new(private_key: ENV['OOD_PACKAGING_GPG_PRIVATE_KEY'],
|
97
111
|
passphrase: ENV['OOD_PACKAGING_GPG_PASSPHRASE'])
|
@@ -109,8 +123,12 @@ class OodPackaging::Package
|
|
109
123
|
!gpg_files.nil?
|
110
124
|
end
|
111
125
|
|
126
|
+
def default_gpg_name
|
127
|
+
'OnDemand Release Signing Key'
|
128
|
+
end
|
129
|
+
|
112
130
|
def gpg_name
|
113
|
-
@config[:gpg_name].nil? ?
|
131
|
+
@config[:gpg_name].nil? ? default_gpg_name : @config[:gpg_name]
|
114
132
|
end
|
115
133
|
|
116
134
|
def container_init
|
@@ -126,10 +144,23 @@ class OodPackaging::Package
|
|
126
144
|
package
|
127
145
|
end
|
128
146
|
|
129
|
-
def
|
130
|
-
|
131
|
-
|
147
|
+
def tar_name
|
148
|
+
version = if build_box.rpm?
|
149
|
+
rpm_version
|
150
|
+
else
|
151
|
+
deb_version
|
152
|
+
end
|
153
|
+
"#{package_name}-#{version}"
|
154
|
+
end
|
132
155
|
|
156
|
+
def rpm_tar_dest_dir
|
157
|
+
[
|
158
|
+
File.join(package, 'rpm'),
|
159
|
+
File.join(package, 'packaging/rpm'),
|
160
|
+
File.join(package, 'packaging')
|
161
|
+
].each do |dir|
|
162
|
+
return dir if Dir.exist?(dir)
|
163
|
+
end
|
133
164
|
File.join(package, 'packaging/rpm')
|
134
165
|
end
|
135
166
|
|
@@ -161,7 +192,7 @@ class OodPackaging::Package
|
|
161
192
|
cmd.concat exec_launchers if docker_runtime?
|
162
193
|
cmd.concat ['scl', 'enable', scl_ruby, '--'] if podman_runtime? && build_box.scl?
|
163
194
|
cmd.concat [File.join(ctr_scripts_dir, 'rake')]
|
164
|
-
cmd.concat ['-q'] unless debug
|
195
|
+
cmd.concat ['-q'] unless debug?
|
165
196
|
cmd.concat ['-f', File.join(ctr_scripts_dir, 'Rakefile'), 'ood_packaging:package:build']
|
166
197
|
cmd
|
167
198
|
end
|
@@ -187,33 +218,31 @@ class OodPackaging::Package
|
|
187
218
|
end
|
188
219
|
|
189
220
|
def clean!
|
190
|
-
sh "rm -rf #{work_dir}", verbose: debug if
|
191
|
-
sh "rm -rf #{output_dir}", verbose: debug if
|
221
|
+
sh "rm -rf #{work_dir}", verbose: debug? if clean_work_dir
|
222
|
+
sh "rm -rf #{output_dir}", verbose: debug? if clean_output_dir
|
192
223
|
end
|
193
224
|
|
194
225
|
def bootstrap!
|
195
|
-
sh "mkdir -p #{work_dir}", verbose: debug
|
196
|
-
sh "mkdir -p #{output_dir}", verbose: debug
|
226
|
+
sh "mkdir -p #{work_dir}", verbose: debug?
|
227
|
+
sh "mkdir -p #{output_dir}", verbose: debug?
|
197
228
|
end
|
198
229
|
|
199
230
|
def tar!
|
200
231
|
cmd = ['git', 'ls-files', '.', '|', tar, '-c']
|
201
232
|
if build_box.rpm?
|
202
233
|
dir = rpm_tar_dest_dir
|
203
|
-
version = rpm_version
|
204
234
|
else
|
205
235
|
dir = deb_tar_dest_dir.tap { |p| sh "mkdir -p #{p}" }
|
206
|
-
version = deb_version
|
207
236
|
cmd.concat ["--transform 'flags=r;s,packaging/deb,debian,'"]
|
208
237
|
end
|
209
|
-
tar_file = "#{dir}/#{
|
210
|
-
cmd.concat ["--transform 's,^,#{
|
238
|
+
tar_file = "#{dir}/#{tar_name}.tar.gz"
|
239
|
+
cmd.concat ["--transform 's,^,#{tar_name}/,'"]
|
211
240
|
cmd.concat ['-T', '-', '|', "gzip > #{tar_file}"]
|
212
241
|
|
213
242
|
sh "rm #{tar_file}" if File.exist?(tar_file)
|
214
243
|
puts "Create tar archive #{tar_file}".blue
|
215
244
|
Dir.chdir(tar_path) do
|
216
|
-
sh cmd.join(' '), verbose: debug
|
245
|
+
sh cmd.join(' '), verbose: debug?
|
217
246
|
end
|
218
247
|
end
|
219
248
|
|
@@ -227,19 +256,19 @@ class OodPackaging::Package
|
|
227
256
|
tar! if tar?
|
228
257
|
container_start!
|
229
258
|
container_exec!(exec_rake)
|
259
|
+
puts "Build SUCCESS: package=#{package} dist=#{build_box.dist}".green
|
230
260
|
rescue RuntimeError
|
231
|
-
# ret = 1
|
232
261
|
puts "Build FAILED package=#{package} dist=#{build_box.dist}".red
|
233
262
|
raise
|
234
|
-
else
|
235
|
-
puts "Build SUCCESS: package=#{package} dist=#{build_box.dist}".green
|
236
263
|
ensure
|
237
264
|
container_exec!(exec_attach, ['-i', '-t']) if attach?
|
238
|
-
container_kill! if container_running?
|
265
|
+
container_kill! if container_running? && !attach?
|
239
266
|
end
|
240
267
|
|
241
268
|
def container_running?
|
242
|
-
|
269
|
+
cmd = "#{container_runtime} inspect #{container_name} 2>/dev/null 1>/dev/null"
|
270
|
+
puts cmd if debug?
|
271
|
+
`#{cmd}`
|
243
272
|
$CHILD_STATUS.success?
|
244
273
|
end
|
245
274
|
|
@@ -250,9 +279,9 @@ class OodPackaging::Package
|
|
250
279
|
cmd.concat container_mounts
|
251
280
|
cmd.concat [build_box.image_tag]
|
252
281
|
cmd.concat [container_init]
|
253
|
-
cmd.concat ['1>/dev/null'] unless debug
|
282
|
+
cmd.concat ['1>/dev/null'] unless debug?
|
254
283
|
puts "Starting container #{container_name} using image #{build_box.image_tag}".blue
|
255
|
-
sh cmd.join(' '), verbose: debug
|
284
|
+
sh cmd.join(' '), verbose: debug?
|
256
285
|
end
|
257
286
|
|
258
287
|
def container_exec!(exec_cmd, extra_args = [])
|
@@ -264,14 +293,18 @@ class OodPackaging::Package
|
|
264
293
|
cmd.concat [container_name]
|
265
294
|
cmd.concat exec_cmd
|
266
295
|
puts "Build STARTED: package=#{package} dist=#{build_box.dist} exec=#{exec_cmd[-1]}".blue
|
267
|
-
sh cmd.join(' '), verbose: debug
|
296
|
+
sh cmd.join(' '), verbose: debug?
|
297
|
+
true
|
298
|
+
rescue RuntimeError
|
299
|
+
container_kill! if container_running? && !attach?
|
300
|
+
raise
|
268
301
|
end
|
269
302
|
|
270
303
|
def container_kill!
|
271
304
|
puts "Killing container #{container_name}".blue
|
272
305
|
cmd = [container_runtime, 'kill', container_name]
|
273
|
-
cmd.concat [
|
274
|
-
sh cmd.join(' '), verbose: debug
|
306
|
+
cmd.concat [cmd_suffix] unless debug?
|
307
|
+
sh cmd.join(' '), verbose: debug?
|
275
308
|
end
|
276
309
|
|
277
310
|
def container_env
|
@@ -279,12 +312,13 @@ class OodPackaging::Package
|
|
279
312
|
'DIST' => build_box.dist,
|
280
313
|
'PACKAGE' => package_name,
|
281
314
|
'VERSION' => version,
|
315
|
+
'TAR_NAME' => "#{tar_name}.tar.gz",
|
282
316
|
'GPG_SIGN' => gpg_sign,
|
283
317
|
'GPG_NAME' => gpg_name,
|
284
318
|
'SKIP_DOWNLOAD' => @config[:skip_download],
|
285
319
|
'OOD_UID' => Process.uid,
|
286
320
|
'OOD_GID' => Process.gid,
|
287
|
-
'DEBUG' => debug
|
321
|
+
'DEBUG' => debug?
|
288
322
|
}
|
289
323
|
env['GPG_PUBKEY'] = '/gpg.pub' if @config[:gpg_pubkey]
|
290
324
|
env
|
data/lib/ood_packaging/tasks.rb
CHANGED
@@ -28,6 +28,12 @@ namespace :ood_packaging do
|
|
28
28
|
@build_box.push!
|
29
29
|
end
|
30
30
|
|
31
|
+
desc 'Pull buildbox image'
|
32
|
+
task :pull, [:dist] do |_task, args|
|
33
|
+
@build_box = OodPackaging::BuildBox.new(args)
|
34
|
+
@build_box.pull!
|
35
|
+
end
|
36
|
+
|
31
37
|
desc 'Save buildbox image'
|
32
38
|
task :save, [:dist, :path] do |_task, args|
|
33
39
|
@build_box = OodPackaging::BuildBox.new(args)
|
@@ -44,8 +50,9 @@ namespace :ood_packaging do
|
|
44
50
|
OodPackaging::RakeTask.new(:internal, [:package, :dist]) do |t, args|
|
45
51
|
name = args[:package].split(':').last
|
46
52
|
t.package = File.join(proj_root, 'packages', name)
|
47
|
-
|
48
|
-
t.
|
53
|
+
dist = args[:dist] || ENV['OOD_PACKAGING_DIST']
|
54
|
+
t.dist = dist
|
55
|
+
t.version = OodPackaging.package_version(name, dist)
|
49
56
|
t.work_dir = File.join(proj_root, 'tmp/work')
|
50
57
|
t.output_dir = File.join(proj_root, 'tmp/output')
|
51
58
|
end
|
data/lib/ood_packaging/utils.rb
CHANGED
@@ -55,7 +55,7 @@ module OodPackaging::Utils
|
|
55
55
|
end
|
56
56
|
|
57
57
|
def ondemand_repo_version
|
58
|
-
'2.
|
58
|
+
'2.0'
|
59
59
|
end
|
60
60
|
|
61
61
|
def ruby_version
|
@@ -67,7 +67,7 @@ module OodPackaging::Utils
|
|
67
67
|
end
|
68
68
|
|
69
69
|
def nodejs_version
|
70
|
-
'
|
70
|
+
'12'
|
71
71
|
end
|
72
72
|
|
73
73
|
def ctr_scripts_dir
|
@@ -2,25 +2,25 @@
|
|
2
2
|
|
3
3
|
# Version code for OodPackaging
|
4
4
|
module OodPackaging
|
5
|
-
VERSION = '0.0.
|
5
|
+
VERSION = '0.0.3.r2.0'
|
6
6
|
PACKAGE_VERSION = {
|
7
7
|
'ondemand-release' => {
|
8
|
-
'(ubuntu|debian)' => '2.
|
9
|
-
'default' => '2.
|
8
|
+
'(ubuntu|debian)' => '2.0.0',
|
9
|
+
'default' => '2.0'
|
10
10
|
},
|
11
11
|
'ondemand-release-latest' => {
|
12
12
|
'(ubuntu|debian)' => '1',
|
13
|
-
'default' => '1-
|
13
|
+
'default' => '1-7'
|
14
14
|
},
|
15
|
-
'ondemand-runtime' => '2.
|
16
|
-
'passenger' => '6.0.
|
15
|
+
'ondemand-runtime' => '2.0-2',
|
16
|
+
'passenger' => '6.0.14',
|
17
17
|
'cjose' => '0.6.1',
|
18
18
|
'mod_auth_openidc' => '2.4.5',
|
19
19
|
'sqlite' => '3.26.0-4',
|
20
20
|
'ondemand_exporter' => '0.9.0',
|
21
21
|
'ondemand-compute' => {
|
22
|
-
'(ubuntu|debian)' => '2.
|
23
|
-
'default' => '2.
|
22
|
+
'(ubuntu|debian)' => '2.0',
|
23
|
+
'default' => '2.0'
|
24
24
|
},
|
25
25
|
'python-websockify' => '0.8.0',
|
26
26
|
'turbovnc' => '2.2.5'
|
metadata
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: ood_packaging
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.0.
|
4
|
+
version: 0.0.3.r2.0
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Trey Dockendorf
|
@@ -9,7 +9,7 @@ authors:
|
|
9
9
|
autorequire:
|
10
10
|
bindir: bin
|
11
11
|
cert_chain: []
|
12
|
-
date:
|
12
|
+
date: 2022-07-27 00:00:00.000000000 Z
|
13
13
|
dependencies:
|
14
14
|
- !ruby/object:Gem::Dependency
|
15
15
|
name: rake
|
@@ -113,7 +113,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
|
|
113
113
|
- !ruby/object:Gem::Version
|
114
114
|
version: 1.3.1
|
115
115
|
requirements: []
|
116
|
-
rubygems_version: 3.
|
116
|
+
rubygems_version: 3.2.33
|
117
117
|
signing_key:
|
118
118
|
specification_version: 4
|
119
119
|
summary: Open OnDemand packaging library
|