From d3123c0d1bc2a2fa61094e1bfb685c9561ce7699 Mon Sep 17 00:00:00 2001 From: Remko van Wagensveld Date: Fri, 23 Aug 2024 17:24:26 +0200 Subject: [PATCH] fix: Remove confusing Notification regarding System updates This commit only shows the "System passed checks, updating ..." notification if a system update is available, not always when the ublue-update system update is being run. --- src/ublue_update/cli.py | 11 +++++++---- tests/unit/test_cli.py | 42 +++++++++++++++++++++++++++++++++++++++++ 2 files changed, 49 insertions(+), 4 deletions(-) diff --git a/src/ublue_update/cli.py b/src/ublue_update/cli.py index 5650ec3..c754fec 100644 --- a/src/ublue_update/cli.py +++ b/src/ublue_update/cli.py @@ -102,10 +102,13 @@ def run_updates(system, system_update_available): transaction_wait() if process_uid == 0: - notify( - "System Updater", - "System passed checks, updating ...", - ) + if system_update_available: + # Notify about a full system update but not about only + # distrobox and flatpak updates + notify( + "System Updater", + "System passed checks, updating ...", + ) users = [] try: users = get_active_sessions() diff --git a/tests/unit/test_cli.py b/tests/unit/test_cli.py index a04ef4a..1b20d8a 100644 --- a/tests/unit/test_cli.py +++ b/tests/unit/test_cli.py @@ -210,6 +210,48 @@ def test_run_updates_system( ["universal-blue-update-reboot=Reboot Now"], ) +@patch("ublue_update.cli.os") +@patch("ublue_update.cli.get_active_sessions") +@patch("ublue_update.cli.acquire_lock") +@patch("ublue_update.cli.transaction_wait") +@patch("ublue_update.cli.subprocess.run") +@patch("ublue_update.cli.log") +@patch("ublue_update.cli.pending_deployment_check") +@patch("ublue_update.cli.cfg") +@patch("ublue_update.cli.release_lock") +@patch("ublue_update.cli.notify") +def test_run_updates_without_image_update( + mock_notify, + mock_release_lock, + mock_cfg, + mock_pending_deployment_check, + mock_log, + mock_run, + mock_transaction_wait, + mock_acquire_lock, + mock_get_active_sesions, + mock_os, +): + mock_os.getuid.return_value = 0 + mock_acquire_lock.return_value = 3 + output = MagicMock(stdout=b"test log") + output.returncode = 1 + mock_run.return_value = output + mock_pending_deployment_check.return_value = True + mock_cfg.dbus_notify.return_value = True + # System Update, but no Image Update Available + run_updates(True, False) + mock_notify.assert_not_called() + mock_run.assert_any_call( + [ + "/usr/bin/topgrade", + "--config", + "/usr/share/ublue-update/topgrade-system.toml", + ], + capture_output=True, + ) + mock_notify.assert_not_called() + @patch("ublue_update.cli.os") @patch("ublue_update.cli.get_active_sessions")