Merge branch '9850-cwl-js' closes #9850
[arvados.git] / build / run-build-packages.sh
1 #!/bin/bash
2
3 . `dirname "$(readlink -f "$0")"`/run-library.sh
4 . `dirname "$(readlink -f "$0")"`/libcloud-pin
5
6 read -rd "\000" helpmessage <<EOF
7 $(basename $0): Build Arvados packages
8
9 Syntax:
10         WORKSPACE=/path/to/arvados $(basename $0) [options]
11
12 Options:
13
14 --build-bundle-packages  (default: false)
15     Build api server and workbench packages with vendor/bundle included
16 --debug
17     Output debug information (default: false)
18 --target
19     Distribution to build packages for (default: debian7)
20 --command
21     Build command to execute (defaults to the run command defined in the
22     Docker image)
23
24 WORKSPACE=path         Path to the Arvados source tree to build packages from
25
26 EOF
27
28 EXITCODE=0
29 DEBUG=${ARVADOS_DEBUG:-0}
30 TARGET=debian7
31 COMMAND=
32
33 PARSEDOPTS=$(getopt --name "$0" --longoptions \
34     help,build-bundle-packages,debug,target: \
35     -- "" "$@")
36 if [ $? -ne 0 ]; then
37     exit 1
38 fi
39
40 eval set -- "$PARSEDOPTS"
41 while [ $# -gt 0 ]; do
42     case "$1" in
43         --help)
44             echo >&2 "$helpmessage"
45             echo >&2
46             exit 1
47             ;;
48         --target)
49             TARGET="$2"; shift
50             ;;
51         --debug)
52             DEBUG=1
53             ;;
54         --command)
55             COMMAND="$2"; shift
56             ;;
57         --)
58             if [ $# -gt 1 ]; then
59                 echo >&2 "$0: unrecognized argument '$2'. Try: $0 --help"
60                 exit 1
61             fi
62             ;;
63     esac
64     shift
65 done
66
67 if [[ "$COMMAND" != "" ]]; then
68   COMMAND="/usr/local/rvm/bin/rvm-exec default bash /jenkins/$COMMAND --target $TARGET"
69 fi
70
71 STDOUT_IF_DEBUG=/dev/null
72 STDERR_IF_DEBUG=/dev/null
73 DASHQ_UNLESS_DEBUG=-q
74 if [[ "$DEBUG" != 0 ]]; then
75     STDOUT_IF_DEBUG=/dev/stdout
76     STDERR_IF_DEBUG=/dev/stderr
77     DASHQ_UNLESS_DEBUG=
78 fi
79
80 declare -a PYTHON_BACKPORTS PYTHON3_BACKPORTS
81
82 PYTHON2_VERSION=2.7
83 PYTHON3_VERSION=$(python3 -c 'import sys; print("{v.major}.{v.minor}".format(v=sys.version_info))')
84
85 ## These defaults are suitable for any Debian-based distribution.
86 # You can customize them as needed in distro sections below.
87 PYTHON2_PACKAGE=python$PYTHON2_VERSION
88 PYTHON2_PKG_PREFIX=python
89 PYTHON2_PREFIX=/usr
90 PYTHON2_INSTALL_LIB=lib/python$PYTHON2_VERSION/dist-packages
91
92 PYTHON3_PACKAGE=python$PYTHON3_VERSION
93 PYTHON3_PKG_PREFIX=python3
94 PYTHON3_PREFIX=/usr
95 PYTHON3_INSTALL_LIB=lib/python$PYTHON3_VERSION/dist-packages
96 ## End Debian Python defaults.
97
98 case "$TARGET" in
99     debian7)
100         FORMAT=deb
101         PYTHON_BACKPORTS=(python-gflags==2.0 google-api-python-client==1.4.2 \
102             oauth2client==1.5.2 pyasn1==0.1.7 pyasn1-modules==0.0.5 \
103             rsa uritemplate httplib2 ws4py pykka six pyexecjs jsonschema \
104             ciso8601 pycrypto backports.ssl_match_hostname llfuse==0.41.1 \
105             'pycurl<7.21.5' contextlib2 pyyaml 'rdflib>=4.2.0' \
106             shellescape mistune typing avro ruamel.ordereddict)
107         PYTHON3_BACKPORTS=(docker-py==1.7.2 six requests websocket-client)
108         ;;
109     debian8)
110         FORMAT=deb
111         PYTHON_BACKPORTS=(python-gflags==2.0 google-api-python-client==1.4.2 \
112             oauth2client==1.5.2 pyasn1==0.1.7 pyasn1-modules==0.0.5 \
113             rsa uritemplate httplib2 ws4py pykka six pyexecjs jsonschema \
114             ciso8601 pycrypto backports.ssl_match_hostname llfuse==0.41.1 \
115             'pycurl<7.21.5' pyyaml 'rdflib>=4.2.0' \
116             shellescape mistune typing avro ruamel.ordereddict)
117         PYTHON3_BACKPORTS=(docker-py==1.7.2 six requests websocket-client)
118         ;;
119     ubuntu1204)
120         FORMAT=deb
121         PYTHON_BACKPORTS=(python-gflags==2.0 google-api-python-client==1.4.2 \
122             oauth2client==1.5.2 pyasn1==0.1.7 pyasn1-modules==0.0.5 \
123             rsa uritemplate httplib2 ws4py pykka six pyexecjs jsonschema \
124             ciso8601 pycrypto backports.ssl_match_hostname llfuse==0.41.1 \
125             contextlib2 'pycurl<7.21.5' pyyaml 'rdflib>=4.2.0' \
126             shellescape mistune typing avro isodate ruamel.ordereddict)
127         PYTHON3_BACKPORTS=(docker-py==1.7.2 six requests websocket-client)
128         ;;
129     ubuntu1404)
130         FORMAT=deb
131         PYTHON_BACKPORTS=(pyasn1==0.1.7 pyasn1-modules==0.0.5 llfuse==0.41.1 ciso8601 \
132             google-api-python-client==1.4.2 six uritemplate oauth2client==1.5.2 httplib2 \
133             rsa 'pycurl<7.21.5' backports.ssl_match_hostname pyyaml 'rdflib>=4.2.0' \
134             shellescape mistune typing avro ruamel.ordereddict)
135         PYTHON3_BACKPORTS=(docker-py==1.7.2 requests websocket-client)
136         ;;
137     centos6)
138         FORMAT=rpm
139         PYTHON2_PACKAGE=$(rpm -qf "$(which python$PYTHON2_VERSION)" --queryformat '%{NAME}\n')
140         PYTHON2_PKG_PREFIX=$PYTHON2_PACKAGE
141         PYTHON2_PREFIX=/opt/rh/python27/root/usr
142         PYTHON2_INSTALL_LIB=lib/python$PYTHON2_VERSION/site-packages
143         PYTHON3_PACKAGE=$(rpm -qf "$(which python$PYTHON3_VERSION)" --queryformat '%{NAME}\n')
144         PYTHON3_PKG_PREFIX=$PYTHON3_PACKAGE
145         PYTHON3_PREFIX=/opt/rh/python33/root/usr
146         PYTHON3_INSTALL_LIB=lib/python$PYTHON3_VERSION/site-packages
147         PYTHON_BACKPORTS=(python-gflags==2.0 google-api-python-client==1.4.2 \
148             oauth2client==1.5.2 pyasn1==0.1.7 pyasn1-modules==0.0.5 \
149             rsa uritemplate httplib2 ws4py pykka six pyexecjs jsonschema \
150             ciso8601 pycrypto backports.ssl_match_hostname 'pycurl<7.21.5' \
151             python-daemon lockfile llfuse==0.41.1 'pbr<1.0' pyyaml \
152             'rdflib>=4.2.0' shellescape mistune typing avro requests \
153             isodate pyparsing sparqlwrapper html5lib==0.9999999 keepalive \
154             ruamel.ordereddict)
155         PYTHON3_BACKPORTS=(docker-py==1.7.2 six requests websocket-client)
156         export PYCURL_SSL_LIBRARY=nss
157         ;;
158     centos7)
159         FORMAT=rpm
160         PYTHON2_PACKAGE=$(rpm -qf "$(which python$PYTHON2_VERSION)" --queryformat '%{NAME}\n')
161         PYTHON2_PKG_PREFIX=$PYTHON2_PACKAGE
162         PYTHON2_INSTALL_LIB=lib/python$PYTHON2_VERSION/site-packages
163         PYTHON3_PACKAGE=$(rpm -qf "$(which python$PYTHON3_VERSION)" --queryformat '%{NAME}\n')
164         PYTHON3_PKG_PREFIX=$PYTHON3_PACKAGE
165         PYTHON3_PREFIX=/opt/rh/python33/root/usr
166         PYTHON3_INSTALL_LIB=lib/python$PYTHON3_VERSION/site-packages
167         PYTHON_BACKPORTS=(python-gflags==2.0 google-api-python-client==1.4.2 \
168             oauth2client==1.5.2 pyasn1==0.1.7 pyasn1-modules==0.0.5 \
169             rsa uritemplate httplib2 ws4py pykka pyexecjs jsonschema \
170             ciso8601 pycrypto 'pycurl<7.21.5' \
171             python-daemon llfuse==0.41.1 'pbr<1.0' pyyaml \
172             'rdflib>=4.2.0' shellescape mistune typing avro \
173             isodate pyparsing sparqlwrapper html5lib==0.9999999 keepalive \
174             ruamel.ordereddict)
175         PYTHON3_BACKPORTS=(docker-py==1.7.2 six requests websocket-client)
176         export PYCURL_SSL_LIBRARY=nss
177         ;;
178     *)
179         echo -e "$0: Unknown target '$TARGET'.\n" >&2
180         exit 1
181         ;;
182 esac
183
184
185 if ! [[ -n "$WORKSPACE" ]]; then
186   echo >&2 "$helpmessage"
187   echo >&2
188   echo >&2 "Error: WORKSPACE environment variable not set"
189   echo >&2
190   exit 1
191 fi
192
193 # Test for fpm
194 fpm --version >/dev/null 2>&1
195
196 if [[ "$?" != 0 ]]; then
197   echo >&2 "$helpmessage"
198   echo >&2
199   echo >&2 "Error: fpm not found"
200   echo >&2
201   exit 1
202 fi
203
204 EASY_INSTALL2=$(find_easy_install -$PYTHON2_VERSION "")
205 EASY_INSTALL3=$(find_easy_install -$PYTHON3_VERSION 3)
206
207 RUN_BUILD_PACKAGES_PATH="`dirname \"$0\"`"
208 RUN_BUILD_PACKAGES_PATH="`( cd \"$RUN_BUILD_PACKAGES_PATH\" && pwd )`"  # absolutized and normalized
209 if [ -z "$RUN_BUILD_PACKAGES_PATH" ] ; then
210   # error; for some reason, the path is not accessible
211   # to the script (e.g. permissions re-evaled after suid)
212   exit 1  # fail
213 fi
214
215 debug_echo "$0 is running from $RUN_BUILD_PACKAGES_PATH"
216 debug_echo "Workspace is $WORKSPACE"
217
218 if [[ -f /etc/profile.d/rvm.sh ]]; then
219     source /etc/profile.d/rvm.sh
220     GEM="rvm-exec default gem"
221 else
222     GEM=gem
223 fi
224
225 # Make all files world-readable -- jenkins runs with umask 027, and has checked
226 # out our git tree here
227 chmod o+r "$WORKSPACE" -R
228
229 # More cleanup - make sure all executables that we'll package are 755
230 cd "$WORKSPACE"
231 find -type d -name 'bin' |xargs -I {} find {} -type f |xargs -I {} chmod 755 {}
232
233 # Now fix our umask to something better suited to building and publishing
234 # gems and packages
235 umask 0022
236
237 debug_echo "umask is" `umask`
238
239 if [[ ! -d "$WORKSPACE/packages/$TARGET" ]]; then
240   mkdir -p $WORKSPACE/packages/$TARGET
241   chown --reference="$WORKSPACE" "$WORKSPACE/packages/$TARGET"
242 fi
243
244 # Perl packages
245 debug_echo -e "\nPerl packages\n"
246
247 cd "$WORKSPACE/sdk/perl"
248
249 if [[ -e Makefile ]]; then
250   make realclean >"$STDOUT_IF_DEBUG"
251 fi
252 find -maxdepth 1 \( -name 'MANIFEST*' -or -name "libarvados-perl*.$FORMAT" \) \
253     -delete
254 rm -rf install
255
256 perl Makefile.PL INSTALL_BASE=install >"$STDOUT_IF_DEBUG" && \
257     make install INSTALLDIRS=perl >"$STDOUT_IF_DEBUG" && \
258     fpm_build install/lib/=/usr/share libarvados-perl \
259     "Curoverse, Inc." dir "$(version_from_git)" install/man/=/usr/share/man \
260     "$WORKSPACE/LICENSE-2.0.txt=/usr/share/doc/libarvados-perl/LICENSE-2.0.txt" && \
261     mv --no-clobber libarvados-perl*.$FORMAT "$WORKSPACE/packages/$TARGET/"
262
263 # Ruby gems
264 debug_echo -e "\nRuby gems\n"
265
266 FPM_GEM_PREFIX=$($GEM environment gemdir)
267
268 cd "$WORKSPACE/sdk/ruby"
269 handle_ruby_gem arvados
270
271 cd "$WORKSPACE/sdk/cli"
272 handle_ruby_gem arvados-cli
273
274 cd "$WORKSPACE/services/login-sync"
275 handle_ruby_gem arvados-login-sync
276
277 # Python packages
278 debug_echo -e "\nPython packages\n"
279
280 cd "$WORKSPACE/sdk/pam"
281 handle_python_package
282
283 cd "$WORKSPACE/sdk/python"
284 handle_python_package
285
286 cd "$WORKSPACE/sdk/cwl"
287 handle_python_package
288
289 cd "$WORKSPACE/services/fuse"
290 handle_python_package
291
292 cd "$WORKSPACE/services/nodemanager"
293 handle_python_package
294
295 # arvados-src
296 (
297     set -e
298
299     cd "$WORKSPACE"
300     COMMIT_HASH=$(format_last_commit_here "%H")
301
302     SRC_BUILD_DIR=$(mktemp -d)
303     # mktemp creates the directory with 0700 permissions by default
304     chmod 755 $SRC_BUILD_DIR
305     git clone $DASHQ_UNLESS_DEBUG "$WORKSPACE/.git" "$SRC_BUILD_DIR"
306     cd "$SRC_BUILD_DIR"
307
308     # go into detached-head state
309     git checkout $DASHQ_UNLESS_DEBUG "$COMMIT_HASH"
310     echo "$COMMIT_HASH" >git-commit.version
311
312     cd "$SRC_BUILD_DIR"
313     PKG_VERSION=$(version_from_git)
314     cd $WORKSPACE/packages/$TARGET
315     fpm_build $SRC_BUILD_DIR/=/usr/local/arvados/src arvados-src 'Curoverse, Inc.' 'dir' "$PKG_VERSION" "--exclude=usr/local/arvados/src/.git" "--url=https://arvados.org" "--license=GNU Affero General Public License, version 3.0" "--description=The Arvados source code" "--architecture=all"
316
317     rm -rf "$SRC_BUILD_DIR"
318 )
319
320 # On older platforms we need to publish a backport of libfuse >=2.9.2,
321 # and we need to build and install it here in order to even build an
322 # llfuse package.
323 cd $WORKSPACE/packages/$TARGET
324 if [[ $TARGET =~ ubuntu1204 ]]; then
325     # port libfuse 2.9.2 to Ubuntu 12.04
326     LIBFUSE_DIR=$(mktemp -d)
327     (
328         cd $LIBFUSE_DIR
329         # download fuse 2.9.2 ubuntu 14.04 source package
330         file="fuse_2.9.2.orig.tar.xz" && curl -L -o "${file}" "http://archive.ubuntu.com/ubuntu/pool/main/f/fuse/${file}"
331         file="fuse_2.9.2-4ubuntu4.14.04.1.debian.tar.xz" && curl -L -o "${file}" "http://archive.ubuntu.com/ubuntu/pool/main/f/fuse/${file}"
332         file="fuse_2.9.2-4ubuntu4.14.04.1.dsc" && curl -L -o "${file}" "http://archive.ubuntu.com/ubuntu/pool/main/f/fuse/${file}"
333
334         # install dpkg-source and dpkg-buildpackage commands
335         apt-get install -y --no-install-recommends dpkg-dev
336
337         # extract source and apply patches
338         dpkg-source -x fuse_2.9.2-4ubuntu4.14.04.1.dsc
339         rm -f fuse_2.9.2.orig.tar.xz fuse_2.9.2-4ubuntu4.14.04.1.debian.tar.xz fuse_2.9.2-4ubuntu4.14.04.1.dsc
340
341         # add new version to changelog
342         cd fuse-2.9.2
343         (
344             echo "fuse (2.9.2-5) precise; urgency=low"
345             echo
346             echo "  * Backported from trusty-security to precise"
347             echo
348             echo " -- Joshua Randall <jcrandall@alum.mit.edu>  Thu, 4 Feb 2016 11:31:00 -0000"
349             echo
350             cat debian/changelog
351         ) > debian/changelog.new
352         mv debian/changelog.new debian/changelog
353
354         # install build-deps and build
355         apt-get install -y --no-install-recommends debhelper dh-autoreconf libselinux-dev
356         dpkg-buildpackage -rfakeroot -b
357     )
358     fpm_build "$LIBFUSE_DIR/fuse_2.9.2-5_amd64.deb" fuse "Ubuntu Developers" deb "2.9.2" --iteration 5
359     fpm_build "$LIBFUSE_DIR/libfuse2_2.9.2-5_amd64.deb" libfuse2 "Ubuntu Developers" deb "2.9.2" --iteration 5
360     fpm_build "$LIBFUSE_DIR/libfuse-dev_2.9.2-5_amd64.deb" libfuse-dev "Ubuntu Developers" deb "2.9.2" --iteration 5
361     dpkg -i \
362         "$WORKSPACE/packages/$TARGET/fuse_2.9.2-5_amd64.deb" \
363         "$WORKSPACE/packages/$TARGET/libfuse2_2.9.2-5_amd64.deb" \
364         "$WORKSPACE/packages/$TARGET/libfuse-dev_2.9.2-5_amd64.deb"
365     apt-get -y --no-install-recommends -f install
366     rm -rf $LIBFUSE_DIR
367 elif [[ $TARGET =~ centos6 ]]; then
368     # port fuse 2.9.2 to centos 6
369     # install tools to build rpm from source
370     yum install -y rpm-build redhat-rpm-config
371     LIBFUSE_DIR=$(mktemp -d)
372     (
373         cd "$LIBFUSE_DIR"
374         # download fuse 2.9.2 centos 7 source rpm
375         file="fuse-2.9.2-6.el7.src.rpm" && curl -L -o "${file}" "http://vault.centos.org/7.2.1511/os/Source/SPackages/${file}"
376         (
377             # modify source rpm spec to remove conflict on filesystem version
378             mkdir -p /root/rpmbuild/SOURCES
379             cd /root/rpmbuild/SOURCES
380             rpm2cpio ${LIBFUSE_DIR}/fuse-2.9.2-6.el7.src.rpm | cpio -i
381             perl -pi -e 's/Conflicts:\s*filesystem.*//g' fuse.spec
382         )
383         # build rpms from source
384         rpmbuild -bb /root/rpmbuild/SOURCES/fuse.spec
385         rm -f fuse-2.9.2-6.el7.src.rpm
386         # move built RPMs to LIBFUSE_DIR
387         mv "/root/rpmbuild/RPMS/x86_64/fuse-2.9.2-6.el6.x86_64.rpm" ${LIBFUSE_DIR}/
388         mv "/root/rpmbuild/RPMS/x86_64/fuse-libs-2.9.2-6.el6.x86_64.rpm" ${LIBFUSE_DIR}/
389         mv "/root/rpmbuild/RPMS/x86_64/fuse-devel-2.9.2-6.el6.x86_64.rpm" ${LIBFUSE_DIR}/
390         rm -rf /root/rpmbuild
391     )
392     fpm_build "$LIBFUSE_DIR/fuse-libs-2.9.2-6.el6.x86_64.rpm" fuse-libs "Centos Developers" rpm "2.9.2" --iteration 5
393     fpm_build "$LIBFUSE_DIR/fuse-2.9.2-6.el6.x86_64.rpm" fuse "Centos Developers" rpm "2.9.2" --iteration 5 --no-auto-depends
394     fpm_build "$LIBFUSE_DIR/fuse-devel-2.9.2-6.el6.x86_64.rpm" fuse-devel "Centos Developers" rpm "2.9.2" --iteration 5 --no-auto-depends
395     yum install -y \
396         "$WORKSPACE/packages/$TARGET/fuse-libs-2.9.2-5.x86_64.rpm" \
397         "$WORKSPACE/packages/$TARGET/fuse-2.9.2-5.x86_64.rpm" \
398         "$WORKSPACE/packages/$TARGET/fuse-devel-2.9.2-5.x86_64.rpm"
399 fi
400
401 # Go binaries
402 cd $WORKSPACE/packages/$TARGET
403 export GOPATH=$(mktemp -d)
404 package_go_binary sdk/go/crunchrunner crunchrunner \
405     "Crunchrunner executes a command inside a container and uploads the output"
406 package_go_binary services/arv-git-httpd arvados-git-httpd \
407     "Provide authenticated http access to Arvados-hosted git repositories"
408 package_go_binary services/crunch-dispatch-local crunch-dispatch-local \
409     "Dispatch Crunch containers on the local system"
410 package_go_binary services/crunch-dispatch-slurm crunch-dispatch-slurm \
411     "Dispatch Crunch containers to a SLURM cluster"
412 package_go_binary services/crunch-run crunch-run \
413     "Supervise a single Crunch container"
414 package_go_binary services/crunchstat crunchstat \
415     "Gather cpu/memory/network statistics of running Crunch jobs"
416 package_go_binary services/datamanager arvados-data-manager \
417     "Ensure block replication levels, report disk usage, and determine which blocks should be deleted when space is needed"
418 package_go_binary services/keep-balance keep-balance \
419     "Rebalance and garbage-collect data blocks stored in Arvados Keep"
420 package_go_binary services/keepproxy keepproxy \
421     "Make a Keep cluster accessible to clients that are not on the LAN"
422 package_go_binary services/keepstore keepstore \
423     "Keep storage daemon, accessible to clients on the LAN"
424 package_go_binary services/keep-web keep-web \
425     "Static web hosting service for user data stored in Arvados Keep"
426 package_go_binary tools/keep-block-check keep-block-check \
427     "Verify that all data from one set of Keep servers to another was copied"
428 package_go_binary tools/keep-rsync keep-rsync \
429     "Copy all data from one set of Keep servers to another"
430
431 # The Python SDK
432 # Please resist the temptation to add --no-python-fix-name to the fpm call here
433 # (which would remove the python- prefix from the package name), because this
434 # package is a dependency of arvados-fuse, and fpm can not omit the python-
435 # prefix from only one of the dependencies of a package...  Maybe I could
436 # whip up a patch and send it upstream, but that will be for another day. Ward,
437 # 2014-05-15
438 cd $WORKSPACE/packages/$TARGET
439 rm -rf "$WORKSPACE/sdk/python/build"
440 fpm_build $WORKSPACE/sdk/python "${PYTHON2_PKG_PREFIX}-arvados-python-client" 'Curoverse, Inc.' 'python' "$(awk '($1 == "Version:"){print $2}' $WORKSPACE/sdk/python/arvados_python_client.egg-info/PKG-INFO)" "--url=https://arvados.org" "--description=The Arvados Python SDK" --deb-recommends=git
441
442 # cwl-runner
443 cd $WORKSPACE/packages/$TARGET
444 rm -rf "$WORKSPACE/sdk/cwl/build"
445 fpm_build $WORKSPACE/sdk/cwl "${PYTHON2_PKG_PREFIX}-arvados-cwl-runner" 'Curoverse, Inc.' 'python' "$(awk '($1 == "Version:"){print $2}' $WORKSPACE/sdk/cwl/arvados_cwl_runner.egg-info/PKG-INFO)" "--url=https://arvados.org" "--description=The Arvados CWL runner" --iteration 3
446
447 # schema_salad. This is a python dependency of arvados-cwl-runner,
448 # but we can't use the usual PYTHONPACKAGES way to build this package due to the
449 # intricacies of how version numbers get generated in setup.py: we need version
450 # 1.7.20160316203940. If we don't explicitly list that version with the -v
451 # argument to fpm, and instead specify it as schema_salad==1.7.20160316203940, we get
452 # a package with version 1.7. That's because our gittagger hack is not being
453 # picked up by self.distribution.get_version(), which is called from
454 # https://github.com/jordansissel/fpm/blob/master/lib/fpm/package/pyfpm/get_metadata.py
455 # by means of this command:
456 #
457 # python2.7 setup.py --command-packages=pyfpm get_metadata --output=metadata.json
458 #
459 # So we build this thing separately.
460 #
461 # Ward, 2016-03-17
462 fpm_build schema_salad "" "" python 1.17.20160820171034
463
464 # And schema_salad now depends on ruamel-yaml, which apparently has a braindead setup.py that requires special arguments to build (otherwise, it aborts with 'error: you have to install with "pip install ."'). Sigh.
465 # Ward, 2016-05-26
466 fpm_build ruamel.yaml "" "" python 0.12.4 --python-setup-py-arguments "--single-version-externally-managed"
467
468 # And for cwltool we have the same problem as for schema_salad. Ward, 2016-03-17
469 fpm_build cwltool "" "" python 1.0.20160901133827
470
471 # FPM eats the trailing .0 in the python-rdflib-jsonld package when built with 'rdflib-jsonld>=0.3.0'. Force the version. Ward, 2016-03-25
472 fpm_build rdflib-jsonld "" "" python 0.3.0
473
474 # The PAM module
475 if [[ $TARGET =~ debian|ubuntu ]]; then
476     cd $WORKSPACE/packages/$TARGET
477     rm -rf "$WORKSPACE/sdk/pam/build"
478     fpm_build $WORKSPACE/sdk/pam libpam-arvados 'Curoverse, Inc.' 'python' "$(awk '($1 == "Version:"){print $2}' $WORKSPACE/sdk/pam/arvados_pam.egg-info/PKG-INFO)" "--url=https://arvados.org" "--description=PAM module for authenticating shell logins using Arvados API tokens" --depends libpam-python
479 fi
480
481 # The FUSE driver
482 # Please see comment about --no-python-fix-name above; we stay consistent and do
483 # not omit the python- prefix first.
484 cd $WORKSPACE/packages/$TARGET
485 rm -rf "$WORKSPACE/services/fuse/build"
486 fpm_build $WORKSPACE/services/fuse "${PYTHON2_PKG_PREFIX}-arvados-fuse" 'Curoverse, Inc.' 'python' "$(awk '($1 == "Version:"){print $2}' $WORKSPACE/services/fuse/arvados_fuse.egg-info/PKG-INFO)" "--url=https://arvados.org" "--description=The Keep FUSE driver"
487
488 # The node manager
489 cd $WORKSPACE/packages/$TARGET
490 rm -rf "$WORKSPACE/services/nodemanager/build"
491 fpm_build $WORKSPACE/services/nodemanager arvados-node-manager 'Curoverse, Inc.' 'python' "$(awk '($1 == "Version:"){print $2}' $WORKSPACE/services/nodemanager/arvados_node_manager.egg-info/PKG-INFO)" "--url=https://arvados.org" "--description=The Arvados node manager"
492
493 # The Docker image cleaner
494 cd $WORKSPACE/packages/$TARGET
495 rm -rf "$WORKSPACE/services/dockercleaner/build"
496 fpm_build $WORKSPACE/services/dockercleaner arvados-docker-cleaner 'Curoverse, Inc.' 'python3' "$(awk '($1 == "Version:"){print $2}' $WORKSPACE/services/dockercleaner/arvados_docker_cleaner.egg-info/PKG-INFO)" "--url=https://arvados.org" "--description=The Arvados Docker image cleaner"
497
498 # The Arvados crunchstat-summary tool
499 cd $WORKSPACE/packages/$TARGET
500 rm -rf "$WORKSPACE/tools/crunchstat-summary/build"
501 fpm_build $WORKSPACE/tools/crunchstat-summary ${PYTHON2_PKG_PREFIX}-crunchstat-summary 'Curoverse, Inc.' 'python' "$(awk '($1 == "Version:"){print $2}' $WORKSPACE/tools/crunchstat-summary/crunchstat_summary.egg-info/PKG-INFO)" "--url=https://arvados.org" "--description=Crunchstat-summary reads Arvados Crunch log files and summarize resource usage"
502
503 # Forked libcloud
504 LIBCLOUD_DIR=$(mktemp -d)
505 (
506     cd $LIBCLOUD_DIR
507     git clone $DASHQ_UNLESS_DEBUG https://github.com/curoverse/libcloud.git .
508     git checkout apache-libcloud-$LIBCLOUD_PIN
509     # libcloud is absurdly noisy without -q, so force -q here
510     OLD_DASHQ_UNLESS_DEBUG=$DASHQ_UNLESS_DEBUG
511     DASHQ_UNLESS_DEBUG=-q
512     handle_python_package
513     DASHQ_UNLESS_DEBUG=$OLD_DASHQ_UNLESS_DEBUG
514 )
515 fpm_build $LIBCLOUD_DIR "$PYTHON2_PKG_PREFIX"-apache-libcloud
516 rm -rf $LIBCLOUD_DIR
517
518 # Python 2 dependencies
519 declare -a PIP_DOWNLOAD_SWITCHES=(--no-deps)
520 # Add --no-use-wheel if this pip knows it.
521 pip wheel --help >/dev/null 2>&1
522 case "$?" in
523     0) PIP_DOWNLOAD_SWITCHES+=(--no-use-wheel) ;;
524     2) ;;
525     *) echo "WARNING: `pip wheel` test returned unknown exit code $?" ;;
526 esac
527
528 for deppkg in "${PYTHON_BACKPORTS[@]}"; do
529     outname=$(echo "$deppkg" | sed -e 's/^python-//' -e 's/[<=>].*//' -e 's/_/-/g' -e "s/^/${PYTHON2_PKG_PREFIX}-/")
530     case "$deppkg" in
531         httplib2|google-api-python-client)
532             # Work around 0640 permissions on some package files.
533             # See #7591 and #7991.
534             pyfpm_workdir=$(mktemp --tmpdir -d pyfpm-XXXXXX) && (
535                 set -e
536                 cd "$pyfpm_workdir"
537                 pip install "${PIP_DOWNLOAD_SWITCHES[@]}" --download . "$deppkg"
538                 # Sometimes pip gives us a tarball, sometimes a zip file...
539                 DOWNLOADED=`ls $deppkg-*`
540                 [[ "$DOWNLOADED" =~ ".tar" ]] && tar -xf $DOWNLOADED
541                 [[ "$DOWNLOADED" =~ ".zip" ]] && unzip $DOWNLOADED
542                 cd "$deppkg"-*/
543                 "python$PYTHON2_VERSION" setup.py $DASHQ_UNLESS_DEBUG egg_info build
544                 chmod -R go+rX .
545                 set +e
546                 fpm_build . "$outname" "" python "" --iteration 3
547                 # The upload step uses the package timestamp to determine
548                 # whether it's new.  --no-clobber plays nice with that.
549                 mv --no-clobber "$outname"*.$FORMAT "$WORKSPACE/packages/$TARGET"
550             )
551             if [ 0 != "$?" ]; then
552                 echo "ERROR: $deppkg build process failed"
553                 EXITCODE=1
554             fi
555             if [ -n "$pyfpm_workdir" ]; then
556                 rm -rf "$pyfpm_workdir"
557             fi
558             ;;
559         *)
560             fpm_build "$deppkg" "$outname"
561             ;;
562     esac
563 done
564
565 # Python 3 dependencies
566 for deppkg in "${PYTHON3_BACKPORTS[@]}"; do
567     outname=$(echo "$deppkg" | sed -e 's/^python-//' -e 's/[<=>].*//' -e 's/_/-/g' -e "s/^/${PYTHON3_PKG_PREFIX}-/")
568     # The empty string is the vendor argument: these aren't Curoverse software.
569     fpm_build "$deppkg" "$outname" "" python3
570 done
571
572 # Build the API server package
573 handle_rails_package arvados-api-server "$WORKSPACE/services/api" \
574     "$WORKSPACE/agpl-3.0.txt" --url="https://arvados.org" \
575     --description="Arvados API server - Arvados is a free and open source platform for big data science." \
576     --license="GNU Affero General Public License, version 3.0"
577
578 # Build the workbench server package
579 (
580     set -e
581     cd "$WORKSPACE/apps/workbench"
582
583     # We need to bundle to be ready even when we build a package without vendor directory
584     # because asset compilation requires it.
585     bundle install --path vendor/bundle >"$STDOUT_IF_DEBUG"
586
587     # clear the tmp directory; the asset generation step will recreate tmp/cache/assets,
588     # and we want that in the package, so it's easier to not exclude the tmp directory
589     # from the package - empty it instead.
590     rm -rf tmp
591     mkdir tmp
592
593     # Set up application.yml and production.rb so that asset precompilation works
594     \cp config/application.yml.example config/application.yml -f
595     \cp config/environments/production.rb.example config/environments/production.rb -f
596     sed -i 's/secret_token: ~/secret_token: xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx/' config/application.yml
597
598     RAILS_ENV=production RAILS_GROUPS=assets bundle exec rake assets:precompile >/dev/null
599
600     # Remove generated configuration files so they don't go in the package.
601     rm config/application.yml config/environments/production.rb
602 )
603
604 if [[ "$?" != "0" ]]; then
605   echo "ERROR: Asset precompilation failed"
606   EXITCODE=1
607 else
608   handle_rails_package arvados-workbench "$WORKSPACE/apps/workbench" \
609       "$WORKSPACE/agpl-3.0.txt" --url="https://arvados.org" \
610       --description="Arvados Workbench - Arvados is a free and open source platform for big data science." \
611       --license="GNU Affero General Public License, version 3.0"
612 fi
613
614 # clean up temporary GOPATH
615 rm -rf "$GOPATH"
616
617 exit $EXITCODE