From 7e232d5caff0928e51376d1ed6789f82848c94c0 Mon Sep 17 00:00:00 2001 From: AdamSimpson Date: Sun, 18 Feb 2018 10:27:40 -0500 Subject: [PATCH] Don't unbuffer if client doesn't have a tty --- Builder/scripts/docker-builder-backend.sh | 14 +++++++++----- Builder/scripts/singularity-builder-backend.sh | 10 +++++++--- Builder/src/main.cpp | 5 +++++ 3 files changed, 21 insertions(+), 8 deletions(-) diff --git a/Builder/scripts/docker-builder-backend.sh b/Builder/scripts/docker-builder-backend.sh index 0822b7b..8703d8a 100755 --- a/Builder/scripts/docker-builder-backend.sh +++ b/Builder/scripts/docker-builder-backend.sh @@ -2,13 +2,17 @@ source /home/builder/environment.sh -# Test for any arguments, such as --debug +# Test for any arguments for i in "$@" do case ${i} in --debug) DEBUG_FLAG='--debug' - shift # past argument with no value + shift + ;; + --tty) + TTY='/usr/bin/unbuffer' + shift ;; *) echo "unknown argument to singularity-builder-backend.sh" @@ -45,13 +49,13 @@ docker ${DEBUG_FLAG} run -d -p 5000:5000 --restart=always --name registry regist # Build the Dockerfile docker image in the current directory mv ./container.def Dockerfile -/usr/bin/unbuffer /usr/bin/docker ${DEBUG_FLAG} build -t localhost:5000/docker_image:latest . || { echo 'Build Failed' ; exit 1; } +${TTY} /usr/bin/docker ${DEBUG_FLAG} build -t localhost:5000/docker_image:latest . || { echo 'Build Failed' ; exit 1; } # Push to the local registry -/usr/bin/unbuffer /usr/bin/docker ${DEBUG_FLAG} push localhost:5000/docker_image:latest +${TTY} /usr/bin/docker ${DEBUG_FLAG} push localhost:5000/docker_image:latest # Build the singularity container from the docker image export SINGULARITY_CACHEDIR=/home/builder/.singularity export SINGULARITY_NOHTTPS=true # Needed as we're pulling from localhost export SINGULARITY_PULLFOLDER=/home/builder -/usr/bin/unbuffer /usr/local/bin/singularity ${DEBUG_FLAG} build container.simg docker://localhost:5000/docker_image:latest \ No newline at end of file +${TTY} /usr/local/bin/singularity ${DEBUG_FLAG} build container.simg docker://localhost:5000/docker_image:latest \ No newline at end of file diff --git a/Builder/scripts/singularity-builder-backend.sh b/Builder/scripts/singularity-builder-backend.sh index a796524..45401ef 100755 --- a/Builder/scripts/singularity-builder-backend.sh +++ b/Builder/scripts/singularity-builder-backend.sh @@ -2,13 +2,17 @@ source /home/builder/environment.sh -# Test for any arguments, such as --debug +# Test for any arguments for i in "$@" do case ${i} in --debug) DEBUG_FLAG='--debug' - shift # past argument with no value + shift + ;; + --tty) + TTY='/usr/bin/unbuffer' + shift ;; *) echo "unknown argument to singularity-builder-backend.sh" @@ -36,4 +40,4 @@ if [[ ${GREP_RC} -eq 0 ]] ; then fi export SINGULARITY_CACHEDIR=/home/builder/.singularity -/usr/bin/unbuffer /usr/local/bin/singularity ${DEBUG_FLAG} build ./container.simg ./container.def \ No newline at end of file +${TTY} /usr/local/bin/singularity ${DEBUG_FLAG} build ./container.simg ./container.def \ No newline at end of file diff --git a/Builder/src/main.cpp b/Builder/src/main.cpp index f107d15..b6019bf 100644 --- a/Builder/src/main.cpp +++ b/Builder/src/main.cpp @@ -92,6 +92,11 @@ std::string build_command(const ClientData &client_data) { build_command += " --debug"; } + // Enable pseudo tty + if (client_data.tty) { + build_command += " --tty"; + } + Logger::info("Build command prepared: " + build_command); return build_command;