Skip to content

Commit

Permalink
changes for pyinstaller experimentation
Browse files Browse the repository at this point in the history
  • Loading branch information
dmichaels-harvard committed Jun 12, 2024
1 parent 1c2d2e6 commit 348d5de
Show file tree
Hide file tree
Showing 10 changed files with 28 additions and 22 deletions.
1 change: 1 addition & 0 deletions CHANGELOG.rst
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,7 @@ Change Log
8.10.1
======
* Changes related to pyinstaller experimentation for smaht-submitr.
Mostly changing calls to exit to sys.exit; and related license_utils change.


8.10.0
Expand Down
5 changes: 3 additions & 2 deletions dcicutils/command_utils.py
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@
import re
import requests
import subprocess
import sys

from typing import Callable, Optional
from .exceptions import InvalidParameterError
Expand Down Expand Up @@ -372,7 +373,7 @@ def fail(*message):
raise ScriptFailure(' '.join(message))
try:
yield fail
exit(0)
sys.exit(0)
except (Exception, ScriptFailure) as e:
if DEBUG_SCRIPT:
# If debugging, let the error propagate, do not trap it.
Expand All @@ -384,7 +385,7 @@ def fail(*message):
else:
message = str(e) # Note: We ignore the type, which isn't intended to be shown.
PRINT(message)
exit(1)
sys.exit(1)


class Question:
Expand Down
4 changes: 2 additions & 2 deletions dcicutils/deployment_utils.py
Original file line number Diff line number Diff line change
Expand Up @@ -396,9 +396,9 @@ def main(cls):
packaging_was_successful = cls.build_application_version(args.repo, args.version_name, branch=args.branch)
if packaging_was_successful: # XXX: how to best detect?
time.sleep(5) # give EB a second to catch up (it needs it)
exit(cls.deploy_new_version(args.env, args.repo, args.version_name))
sys.exit(cls.deploy_new_version(args.env, args.repo, args.version_name))
else:
exit(cls.deploy_indexer(args.env, args.application_version))
sys.exit(cls.deploy_indexer(args.env, args.application_version))


class IniFileManager:
Expand Down
7 changes: 4 additions & 3 deletions dcicutils/ecr_scripts.py
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@
import boto3
import contextlib
import os
import sys

from typing import Optional, Union, List
from .command_utils import yes_or_no
Expand Down Expand Up @@ -68,7 +69,7 @@ def ecr_command_context(account_number, ecs_repository=None, ecr_client=None):
elif account_number != account_number_in_environ:
raise RuntimeError("The account number you have specified does not match your declared credentials.")
yield ECRCommandContext(account_number=account_number, ecs_repository=ecs_repository, ecr_client=ecr_client)
exit(0)
sys.exit(0)
except botocore.exceptions.ClientError as e:
error_info = e.response.get('Error', {})
message = error_info.get('Message')
Expand All @@ -77,12 +78,12 @@ def ecr_command_context(account_number, ecs_repository=None, ecr_client=None):
raise RuntimeError("Your security token seems to have expired.")
elif message:
PRINT(f"{code}: {message}")
exit(1)
sys.exit(1)
else:
raise
except Exception as e:
PRINT(f"{full_class_name(e)}: {e}")
exit(1)
sys.exit(1)


class ECRCommandContext:
Expand Down
9 changes: 5 additions & 4 deletions dcicutils/env_scripts.py
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
import argparse
import boto3
import json
import sys
import yaml

from .lang_utils import disjoined_list
Expand Down Expand Up @@ -52,7 +53,7 @@ def show_global_env_bucket(bucket, mode='json', key=None):
else:
PRINT(f"There is no default bucket. Please use a '--bucket' argument"
f" to specify one of {disjoined_list(envs_buckets)}.")
exit(1)
sys.exit(1)

print_heading(bucket, style='=')

Expand All @@ -70,23 +71,23 @@ def show_global_env_bucket(bucket, mode='json', key=None):
except Exception as e:
PRINT("Bucket contents could not be downlaoded.")
print_error_message(e)
exit(1)
sys.exit(1)

object = None # Without this, PyCharm fusses that object might not get set. -kmp 20-Jul-2022
try:
object = json.load(object_stream)
except Exception as e:
PRINT("Bucket contents could not be parsed as JSON.")
print_error_message(e)
exit(1)
sys.exit(1)

if mode == 'json':
PRINT(json.dumps(object, indent=2, default=str))
elif mode == 'yaml':
PRINT(yaml.dump(object))
else:
PRINT(f"Unknown mode: {mode}. Try 'json' or 'yaml'.")
exit(1)
sys.exit(1)


DEFAULT_BUCKET = get_env_bucket()
Expand Down
2 changes: 1 addition & 1 deletion dcicutils/progress_bar.py
Original file line number Diff line number Diff line change
Expand Up @@ -249,7 +249,7 @@ def handle_secondary_interrupt(signum: int, frame: frame) -> None: # noqa
if self._interrupt_exit_message:
if isinstance(interrupt_exit_message := self._interrupt_exit_message(self), str):
print(interrupt_exit_message)
exit(1)
sys.exit(1)
elif interrupt_stop is False or ((interrupt_stop is None) and (self._interrupt_exit is False)):
set_interrupt_handler(handle_interrupt)
interrupt_continue = self._interrupt_continue(self) if self._interrupt_continue else None
Expand Down
3 changes: 2 additions & 1 deletion dcicutils/scripts/publish_to_pypi.py
Original file line number Diff line number Diff line change
Expand Up @@ -33,6 +33,7 @@
import os
import requests
import subprocess
import sys
import toml

from typing import Tuple, Union
Expand Down Expand Up @@ -335,7 +336,7 @@ def exit_with_no_action() -> None:
first prints a message saying no action was taken.
"""
PRINT("Exiting without taking action.")
exit(1)
sys.exit(1)


PRINT = print
Expand Down
14 changes: 7 additions & 7 deletions dcicutils/scripts/view_portal_object.py
Original file line number Diff line number Diff line change
Expand Up @@ -201,17 +201,17 @@ def main():
return
else:
_print(f"No PATCH data found in file: {args.patch}")
exit(1)
sys.exit(1)

data = _get_portal_object(portal=portal, uuid=args.uuid, raw=args.raw,
database=args.database, check=args.bool, verbose=args.verbose)
if args.bool:
if data:
_print(f"{args.uuid}: found")
exit(0)
sys.exit(0)
else:
_print(f"{args.uuid}: not found")
exit(1)
sys.exit(1)
if args.copy:
pyperclip.copy(json.dumps(data, indent=4))
if args.yaml:
Expand Down Expand Up @@ -597,18 +597,18 @@ def tree_generator(name: str, prefix: str = ""):
def _read_json_from_file(file: str) -> Optional[dict]:
if not os.path.exists(file):
_print(f"Cannot find file: {file}")
exit(1)
sys.exit(1)
try:
with io.open(file, "r") as f:
try:
return json.load(f)
except Exception:
_print(f"Cannot parse JSON in file: {file}")
exit(1)
sys.exit(1)
except Exception as e:
print(e)
_print(f"Cannot open file: {file}")
exit(1)
sys.exit(1)


def _print(*args, **kwargs):
Expand All @@ -620,7 +620,7 @@ def _print(*args, **kwargs):
def _exit(message: Optional[str] = None) -> None:
if message:
_print(f"ERROR: {message}")
exit(1)
sys.exit(1)


if __name__ == "__main__":
Expand Down
2 changes: 1 addition & 1 deletion pyproject.toml
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
[tool.poetry]
name = "dcicutils"
version = "8.10.0.1b1" # TODO: To become 8.10.1
version = "8.10.0.1b2" # TODO: To become 8.10.1
description = "Utility package for interacting with the 4DN Data Portal and other 4DN resources"
authors = ["4DN-DCIC Team <[email protected]>"]
license = "MIT"
Expand Down
3 changes: 2 additions & 1 deletion test/test_command_utils.py
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
import os
import pytest
import sys
import tempfile

from unittest import mock
Expand Down Expand Up @@ -378,7 +379,7 @@ def test_script_catch_errors():
with script_catch_errors():
PRINT(normal_output)
PRINT(custom_exit_message)
exit(1) # Bypasses script_catch_errors context manager, so won't show SCRIPT_ERROR_HERALD
sys.exit(1) # Bypasses script_catch_errors context manager, so won't show SCRIPT_ERROR_HERALD
sys_exit = exit_exc.value
assert isinstance(sys_exit, SystemExit)
assert sys_exit.code == 1
Expand Down

0 comments on commit 348d5de

Please sign in to comment.