blob: a451b8770a494cebd2f6bb8ee59cc69671de7259 (
plain)
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
100
101
102
|
#!/bin/bash
#
# Copyright 2018 Bloomberg Finance LP
#
# This program is free software; you can redistribute it and/or
# modify it under the terms of the GNU Lesser General Public
# License as published by the Free Software Foundation; either
# version 2 of the License, or (at your option) any later version.
#
# This library is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
# Lesser General Public License for more details.
#
# You should have received a copy of the GNU Lesser General Public
# License along with this library. If not, see <http://www.gnu.org/licenses/>.
#
# Authors:
# Chadnan Singh <csingh43@bloomberg.net>
# This is a helper script to generate Docker images using checkouts of
# BuildStream elements.
usage() {
cat <<EOF
USAGE: $(basename "$0") [-c BST_CMD] [-m MESSAGE] [-t TAG] [-h] ELEMENT
Create a Docker image from bst checkout of an element.
OPTIONS:
-c BST_CMD Path to BuildStream command (default: bst).
-m MESSAGE Commit message for the imported image.
-t TAG Tag of the imported image.
-h Print this help text and exit.
EXAMPLES:
# Import hello.bst as a Docker image with tag "bst-hello" and message "hello"
$(basename "$0") -m hello -t bst-hello hello.bst
# Import hello.bst as a Docker image with tag "bst-hello" using bst-here
$(basename "$0") -c bst-here -t bst-hello hello.bst
EOF
exit "$1"
}
die() {
echo "FATAL: $1" >&2
exit 1
}
bst_cmd=bst
docker_import_cmd=(docker import)
docker_image_tag=
while getopts c:m:t:h arg
do
case $arg in
c)
bst_cmd="$OPTARG"
;;
m)
docker_import_cmd+=('-m' "$OPTARG")
;;
t)
docker_image_tag="$OPTARG"
;;
h)
usage 0
;;
\?)
usage 1
esac
done
shift $((OPTIND-1))
if [[ "$#" != 1 ]]; then
echo "$0: No element specified" >&2
usage 1
fi
element="$1"
# Dump to a temporary file in the current directory.
# NOTE: We use current directory to try to ensure compatibility with scripts
# like bst-here, assuming that the current working directory is mounted
# inside the container.
checkout_tar="bst-checkout-$(basename "$element")-$RANDOM.tar"
echo "INFO: Checking out $element ..." >&2
$bst_cmd checkout --tar "$element" "$checkout_tar" || die "Failed to checkout $element"
echo "INFO: Successfully checked out $element" >&2
echo "INFO: Importing Docker image ..."
"${docker_import_cmd[@]}" "$checkout_tar" "$docker_image_tag" || die "Failed to import Docker image from tarball"
echo "INFO: Successfully import Docker image $docker_image_tag"
echo "INFO: Cleaning up ..."
rm "$checkout_tar" || die "Failed to remove $checkout_tar"
echo "INFO: Clean up finished"
|