From 5c56e009386245b3d8f74ce6362b0fc93ca308b2 Mon Sep 17 00:00:00 2001 From: Scott K Logan Date: Thu, 25 Jul 2024 15:28:56 -0500 Subject: [PATCH] Add support to logging directory setup for no verb (#655) Explicitly support "no verb" in the logging directory setup, as opposed to treating it as an empty string or raising an exception. --- colcon_core/location.py | 11 +++++++---- test/test_location.py | 11 +++++++++++ 2 files changed, 18 insertions(+), 4 deletions(-) diff --git a/colcon_core/location.py b/colcon_core/location.py index f65517ccb..8924929f7 100644 --- a/colcon_core/location.py +++ b/colcon_core/location.py @@ -211,10 +211,13 @@ def create_log_path(verb_name): ignore_marker.touch() # create latest symlinks - _create_symlink(path, path.parent / f'latest_{verb_name}') - _create_symlink( - path.parent / f'latest_{verb_name}', - path.parent / 'latest') + if verb_name is None: + _create_symlink(path, path.parent / 'latest') + else: + _create_symlink(path, path.parent / f'latest_{verb_name}') + _create_symlink( + path.parent / f'latest_{verb_name}', + path.parent / 'latest') def _reset_log_path_creation_global(): diff --git a/test/test_location.py b/test/test_location.py index 61a8656c0..0141feae5 100644 --- a/test/test_location.py +++ b/test/test_location.py @@ -190,6 +190,17 @@ def test_create_log_path(reset_log_path_creation_global): assert (log_path / subdirectory).exists() assert not (log_path / 'latest').is_symlink() + # check that `latest_verb` is skipped when there is no verb + (log_path / subdirectory).rmdir() + (log_path / 'latest').rmdir() + (log_path / 'latest_verb').unlink() + location._create_log_path_called = False + create_log_path(None) + assert (log_path / subdirectory).exists() + assert (log_path / 'latest').is_symlink() + assert (log_path / 'latest').resolve() == \ + (log_path / subdirectory).resolve() + def test__create_symlink(): # check cases where functions raise exceptions and ensure it is being