From de65f87d55191c4225293148575f2e94e370a2b5 Mon Sep 17 00:00:00 2001 From: Reid Mello <30907815+rjmello@users.noreply.github.com> Date: Fri, 7 Apr 2023 16:55:36 -0400 Subject: [PATCH] Rename .funcx dir to .globus_compute The `.funcx` directory is now `.globus_compute`. If `.funcx` is present when `globus-compute-sdk` is installed and used, we rename it and create a symlink to avoid breaking existing workflows. Otherwise, we create a fresh `.globus_compute` directory. --- .github/ISSUE_TEMPLATE/bug_report.md | 2 +- .../globus_compute_endpoint/cli.py | 6 ++--- .../endpoint/endpoint.py | 4 ++-- compute_sdk/globus_compute_sdk/sdk/client.py | 2 +- .../sdk/login_manager/tokenstore.py | 22 +++++++++++++++---- docs/funcx_upgrade.rst | 4 ++-- helm/README.md | 4 ++-- helm/boot.sh | 10 ++++----- smoke_tests/tests/conftest.py | 6 ++--- smoke_tests/tests/sh/test_endpoint.sh | 2 +- 10 files changed, 38 insertions(+), 24 deletions(-) diff --git a/.github/ISSUE_TEMPLATE/bug_report.md b/.github/ISSUE_TEMPLATE/bug_report.md index 9471db973..bf5befa3d 100644 --- a/.github/ISSUE_TEMPLATE/bug_report.md +++ b/.github/ISSUE_TEMPLATE/bug_report.md @@ -32,5 +32,5 @@ A clear and concise description of what you expected to happen. - Where are you running the funcX script from? [e.g. Laptop/Workstation, Login node, Compute node] - Where does the endpoint run? [e.g. Laptop/Workstation, Login node] - What is your endpoint-uuid? -- Attach endpoint logs at `~/.funcx/` if this is an endpoint issue. +- Attach endpoint logs at `~/.globus_compute/` if this is an endpoint issue. Please let us know if you'd prefer to share logs privately. diff --git a/compute_endpoint/globus_compute_endpoint/cli.py b/compute_endpoint/globus_compute_endpoint/cli.py index 34392b001..f1f3767df 100644 --- a/compute_endpoint/globus_compute_endpoint/cli.py +++ b/compute_endpoint/globus_compute_endpoint/cli.py @@ -25,7 +25,7 @@ class CommandState: def __init__(self): - self.endpoint_config_dir: str = str(pathlib.Path.home() / ".funcx") + self.endpoint_config_dir: str = str(pathlib.Path.home() / ".globus_compute") self.debug = False self.no_color = False self.log_to_console = False @@ -191,8 +191,8 @@ def configure_endpoint( ): """Configure an endpoint - Drops a config.py template into the funcx configs directory. - The template usually goes to ~/.funcx//config.py + Drops a config.py template into the Globus Compute configs directory. + The template usually goes to ~/.globus_compute//config.py """ compute_dir = get_config_dir() ep_dir = compute_dir / name diff --git a/compute_endpoint/globus_compute_endpoint/endpoint/endpoint.py b/compute_endpoint/globus_compute_endpoint/endpoint/endpoint.py index c1bae07c7..1916d756a 100644 --- a/compute_endpoint/globus_compute_endpoint/endpoint/endpoint.py +++ b/compute_endpoint/globus_compute_endpoint/endpoint/endpoint.py @@ -95,8 +95,8 @@ def init_endpoint_dir( try: # pathlib.Path does not handle unusual umasks (e.g., 0o0111) so well # in the parents=True case, so temporarily change it. This is nominally - # only an issue for totally new users (no .funcx/!), but that is also - # precisely the interaction -- the first one -- that should go smoothly + # only an issue for totally new users (no .globus_compute/!), but that is + # also precisely the interaction -- the first one -- that should go smoothly endpoint_dir.mkdir(parents=True, exist_ok=True) config_target_path = Endpoint._config_file_path(endpoint_dir) diff --git a/compute_sdk/globus_compute_sdk/sdk/client.py b/compute_sdk/globus_compute_sdk/sdk/client.py index eacc14b4c..d62ce9bdb 100644 --- a/compute_sdk/globus_compute_sdk/sdk/client.py +++ b/compute_sdk/globus_compute_sdk/sdk/client.py @@ -29,7 +29,7 @@ logger = logging.getLogger(__name__) -_FUNCX_HOME = os.path.join("~", ".funcx") +_FUNCX_HOME = os.path.join("~", ".globus_compute") class Client: diff --git a/compute_sdk/globus_compute_sdk/sdk/login_manager/tokenstore.py b/compute_sdk/globus_compute_sdk/sdk/login_manager/tokenstore.py index 84134bd04..59555f8b8 100644 --- a/compute_sdk/globus_compute_sdk/sdk/login_manager/tokenstore.py +++ b/compute_sdk/globus_compute_sdk/sdk/login_manager/tokenstore.py @@ -36,11 +36,25 @@ def invalidate_old_config() -> None: def _ensure_funcx_dir() -> pathlib.Path: - dirname = _home() / ".funcx" - try: - os.makedirs(dirname) - except FileExistsError: + legacy_dirname = _home() / ".funcx" + dirname = _home() / ".globus_compute" + + if dirname.is_dir(): pass + + elif dirname.is_file(): + raise FileExistsError( + f"Error creating directory {dirname}, " + "please remove or rename the conflicting file" + ) + + elif legacy_dirname.is_dir(): + legacy_dirname.replace(dirname) + legacy_dirname.symlink_to(dirname, target_is_directory=True) + + else: + dirname.mkdir(parents=True, exist_ok=True) + return dirname diff --git a/docs/funcx_upgrade.rst b/docs/funcx_upgrade.rst index 86bdbe4b7..3a18c1c19 100644 --- a/docs/funcx_upgrade.rst +++ b/docs/funcx_upgrade.rst @@ -23,7 +23,7 @@ If you currently have funcX installed, we recommend these steps to upgrade to Globus Compute: | $ pip uninstall funcx - | $ mv ~/.funcx ~/.compute # Optional + | $ mv ~/.funcx ~/.globus_compute # Optional | $ Install Globus Compute SDK in its own venv `as detailed here `__ The `funcx` package is still available on PyPI but will merely be a wrapper @@ -38,7 +38,7 @@ the `Globus Compute Endpoint` and is `available on PyPI `_. | $ pip uninstall funcx-endpoint - | $ mv ~/.funcx ~/.compute # Optional + | $ mv ~/.funcx ~/.globus_compute # Optional | $ Install Globus Compute Endpoint `using pipx `__ The `funcx-endpoint` package is still available on PyPI but will merely be a wrapper diff --git a/helm/README.md b/helm/README.md index 155ed5ee4..4355b2814 100644 --- a/helm/README.md +++ b/helm/README.md @@ -85,10 +85,10 @@ will already have generated the credential file. A prompt beginning "Please authenticate with Globus here:" and with a long URL to a Globus authentication workflow will print to the terminal; follow the URL and paste the resulting token back into the terminal. This will - create the credential file at `$HOME/.funcx/storage.db`. + create the credential file at `$HOME/.globus_compute/storage.db`. 1. Create a Kubernetes secret named `compute-sdk-tokens` with this file: ```shell - $ kubectl create secret generic compute-sdk-tokens --from-file=$HOME/.funcx/storage.db + $ kubectl create secret generic compute-sdk-tokens --from-file=$HOME/.globus_compute/storage.db ``` It is important to name the secret `compute-sdk-tokens` as this chart looks for that secret name, specifically. diff --git a/helm/boot.sh b/helm/boot.sh index 82e1a66a8..95f00ec1a 100755 --- a/helm/boot.sh +++ b/helm/boot.sh @@ -5,13 +5,13 @@ EP_UUID="$1"; shift echo -e "\n Preparing to start kubelet Endpoint: $EP_UUID ($EP_NAME)\n" -mkdir -p "$HOME/.funcx/$EP_NAME/" -cp /compute/"$EP_NAME"/* "$HOME/.funcx/$EP_NAME/" -cp /compute/config/config.py "$HOME/.funcx/" +mkdir -p "$HOME/.globus_compute/$EP_NAME/" +cp /compute/"$EP_NAME"/* "$HOME/.globus_compute/$EP_NAME/" +cp /compute/config/config.py "$HOME/.globus_compute/" if [[ -e "/compute/credentials/storage.db" ]]; then - cp /compute/credentials/storage.db "$HOME/.funcx/" - chmod 600 "$HOME/.funcx/storage.db" + cp /compute/credentials/storage.db "$HOME/.globus_compute/" + chmod 600 "$HOME/.globus_compute/storage.db" fi exec globus-compute-endpoint start "$EP_NAME" --endpoint-uuid "$EP_UUID" "$@" diff --git a/smoke_tests/tests/conftest.py b/smoke_tests/tests/conftest.py index 4e2c87c0d..a2fc83606 100644 --- a/smoke_tests/tests/conftest.py +++ b/smoke_tests/tests/conftest.py @@ -16,8 +16,8 @@ # # 1. `--endpoint` opt # 2. COMPUTE_LOCAL_ENDPOINT_ID (seen here) -# 3. COMPUTE_LOCAL_ENDPOINT_NAME (the name of a dir in `~/.funcx/`) -# 4. An endpoint ID found in ~/.funcx/default/endpoint.json +# 3. COMPUTE_LOCAL_ENDPOINT_NAME (the name of a dir in `~/.globus_compute/`) +# 4. An endpoint ID found in ~/.globus_compute/default/endpoint.json # # this var starts with the ID env var load _LOCAL_ENDPOINT_ID = os.getenv("COMPUTE_LOCAL_ENDPOINT_ID") @@ -61,7 +61,7 @@ def _get_local_endpoint_id(): # - `--endpoint` is not passed local_endpoint_name = os.getenv("COMPUTE_LOCAL_ENDPOINT_NAME", "default") data_path = os.path.join( - os.path.expanduser("~"), ".funcx", local_endpoint_name, "endpoint.json" + os.path.expanduser("~"), ".globus_compute", local_endpoint_name, "endpoint.json" ) try: diff --git a/smoke_tests/tests/sh/test_endpoint.sh b/smoke_tests/tests/sh/test_endpoint.sh index 9a0aeaeb2..970ec2ea4 100755 --- a/smoke_tests/tests/sh/test_endpoint.sh +++ b/smoke_tests/tests/sh/test_endpoint.sh @@ -4,7 +4,7 @@ set -e env="smoke_test_environment" -conf_dir="$(eval echo ~"/.funcx/smoke_test")" +conf_dir="$(eval echo ~"/.globus_compute/smoke_test")" cleanup(){ [[ -d $conf_dir ]] && rm -rf "$conf_dir"