mirror of
https://github.com/ChristianLight/tutor.git
synced 2024-12-13 14:43:03 +00:00
Make sure we don't hang in non-interactive environments
This commit is contained in:
parent
08f157698f
commit
a6a68881cd
@ -1,5 +1,6 @@
|
|||||||
import json
|
import json
|
||||||
import os
|
import os
|
||||||
|
import sys
|
||||||
|
|
||||||
import click
|
import click
|
||||||
|
|
||||||
@ -77,14 +78,20 @@ def load(root):
|
|||||||
load_defaults(config)
|
load_defaults(config)
|
||||||
|
|
||||||
if not env.is_up_to_date(root):
|
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
|
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:
|
if should_update_env:
|
||||||
save_env(root, config)
|
save_env(root, config)
|
||||||
|
Loading…
Reference in New Issue
Block a user