if [ $# -ne 1 ]; then
FATAL "arg is container name"
fi
- lxc config show $1 2>&1 >/dev/null
+ lxc config show $1 >/dev/null 2>&1
if [ $? -eq 0 ]; then
DEBUG "container $1 exists"
return 0
fi
INFO "creating container $2 using image $1"
DEBUG "lxc launch $1 $2"
- sudo lxc launch "$1" "$2"
+ lxc launch "$1" "$2"
+}
+
+create_privileged_container() {
+ if [ $# -ne 2 ]; then
+ FATAL "args are image container"
+ fi
+ INFO "creating container $2 using image $1"
+ DEBUG "lxc launch $1 $2"
+ lxc launch "$1" "$2" -c security.privileged=true
}
container_exec() {
container="$1"
shift
- DEBUG "exec in $1 \"$*\""
+ DEBUG "exec in $container \"$*\""
lxc exec "$container" -- $*
}
+container_exec_stderr() {
+ container="$1"
+ shift
+ DEBUG "exec in $container \"$*\""
+ lxc exec "$container" -- $* 2>&1
+}
wait_container_up() {
[ $# -eq 1 ] || FATAL "arg is container name got $# args - $*"
RE="1 received"
while [ $ct -lt 60 ]; do
let ct=ct+1
- output=$(container_exec "$1" ping -c 1 google.com)
+ output=$(container_exec_stderr "$1" ping -c 1 google.com)
if [[ $output =~ $RE ]]; then
DEBUG "$1 is up"
return
done
FATAL "container $1 did not start"
}
+container_push_tree() {
+ # create a tarball locally, pipe it into the container and unpack it there
+ [ $# -eq 3 ] || FATAL "args are container dir_from dir_to (dir_to MUST exist)"
+ tar -C "$2" -c . -f - | container_exec $1 tar -C "$3" -x -f -
+}
+
+container_push_devops() {
+ [ $# -eq 1 ] || FATAL "arg is container name got $# args - $*"
+ container_exec "$1" mkdir -p /root/devops
+ container_push_tree "$1" "$(dirname $OSM_JENKINS)" "/root/devops"
+}