From a6a68881cd67e01274681c4fade9e992224c2109 Mon Sep 17 00:00:00 2001 From: Silvio Tomatis Date: Thu, 18 Apr 2019 15:12:13 +0200 Subject: [PATCH] Make sure we don't hang in non-interactive environments --- tutor/config.py | 21 ++++++++++++++------- 1 file changed, 14 insertions(+), 7 deletions(-) diff --git a/tutor/config.py b/tutor/config.py index bec18f7..20ac2fb 100644 --- a/tutor/config.py +++ b/tutor/config.py @@ -1,5 +1,6 @@ import json import os +import sys import click @@ -77,14 +78,20 @@ def load(root): load_defaults(config) if not env.is_up_to_date(root): - click.confirm(fmt.alert( - "The current environment stored at {} is not up-to-date: it is at " - "v{} while the 'tutor' binary is at v{}. The environment will be " - "upgraded now. Any change you might have made will be overwritten.".format( - env.base_dir(root), env.version(root), __version__ - ) - ), abort=True) should_update_env = True + if os.isatty(sys.stdin.fileno()): + # Interactive mode: ask the user permission to proceed + click.confirm(fmt.alert( + "The current environment stored at {} is not up-to-date: it is at " + "v{} while the 'tutor' binary is at v{}. The environment will be " + "upgraded now. Any change you might have made will be overwritten.".format( + env.base_dir(root), env.version(root), __version__ + ) + ), abort=True) + elif os.environ.get('TUTOR_OVERWRITE_ENV'): + pass # Non-interactive mode with environment variable authorizing us to go + else: + raise click.Abort # Non-interactive mode with no authorization: abort if should_update_env: save_env(root, config)