From 2ed5a1eb2112a9a13d59b785064507cc3af05614 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marek=20Marczykowski-G=C3=B3recki?= Date: Wed, 3 Jul 2024 22:02:40 +0200 Subject: [PATCH 1/2] tests: update expeted error codes of qubes-vm-update When refreshing metadata fails, it's supposed to exit with code 23. Related to https://github.com/QubesOS/qubes-core-admin-linux/pull/160 --- qubes/tests/integ/vm_update.py | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/qubes/tests/integ/vm_update.py b/qubes/tests/integ/vm_update.py index 4bd8e1cb1..f821d7e48 100644 --- a/qubes/tests/integ/vm_update.py +++ b/qubes/tests/integ/vm_update.py @@ -639,7 +639,7 @@ def test_130_no_network_qubes_vm_update(self): self.update_via_proxy_qubes_vm_update_impl( method="qubes-vm-update", options=(), - expected_ret_codes=(1, 2, 5), + expected_ret_codes=(23,), break_repo=True ) @@ -647,7 +647,7 @@ def test_131_no_network_qubes_vm_update_cli(self): self.update_via_proxy_qubes_vm_update_impl( method="qubes-vm-update", options=("--no-progress",), - expected_ret_codes=(1, 2, 5), + expected_ret_codes=(23,), break_repo=True ) From 212ff6943661d8e8cecd850e1b9bd901eacfa2dc Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marek=20Marczykowski-G=C3=B3recki?= Date: Thu, 4 Jul 2024 14:08:08 +0200 Subject: [PATCH 2/2] tests: fix testing qubes-vm-update error reporting Previously the expected_ret_codes applied to both qubes-vm-update and later check if a package was updated (`rpm -q|grep ...` etc). With unified qubes-vm-update exit codes, this approach is too broad as qubes-vm-update is now expected to exit with very specific error, not just "any error" - and this doesn't match grep's exit code anymore. Fix this by adding another parameter for expected grep result (whether updated package is expected or not). --- qubes/tests/integ/vm_update.py | 17 +++++++++++------ 1 file changed, 11 insertions(+), 6 deletions(-) diff --git a/qubes/tests/integ/vm_update.py b/qubes/tests/integ/vm_update.py index f821d7e48..e9732d9e2 100644 --- a/qubes/tests/integ/vm_update.py +++ b/qubes/tests/integ/vm_update.py @@ -491,7 +491,8 @@ def update_via_proxy_qubes_vm_update_impl( method="direct", options=(), expected_ret_codes=None, - break_repo=False + break_repo=False, + expect_updated=True, ): """ Test both whether updates proxy works and whether is actually used @@ -502,6 +503,7 @@ def update_via_proxy_qubes_vm_update_impl( :type options: tuple :type expected_ret_codes: tuple :type break_repo: bool + :type: expect_updated: bool """ if self.template.count("minimal"): self.skipTest("Template {} not supported by this test".format( @@ -545,7 +547,7 @@ def update_via_proxy_qubes_vm_update_impl( self.assertRunCommandReturnCode( self.testvm1, self.upgrade_test_cmd.format('test-pkg'), - expected_ret_codes + (0,) if expect_updated else (1,) ) def test_010_update_via_proxy(self): @@ -570,13 +572,14 @@ def upgrade_status_notify(self): )) def updates_available_notification_qubes_vm_update_impl( - self, method="direct", options=()): + self, method="direct", options=(), expect_updated=True): """ Test if updates-available flags is updated. :type self: qubes.tests.SystemTestCase | VmUpdatesMixin :type method: str :type options: tuple + :type expect_updated: bool """ self.start_standalone_vm_with_repo() @@ -608,7 +611,7 @@ def updates_available_notification_qubes_vm_update_impl( self.assertRunCommandReturnCode( self.testvm1, self.upgrade_test_cmd.format('test-pkg'), - self.ret_code_ok + (0,) if expect_updated else (1,) ) def test_020_updates_available_notification(self): @@ -640,7 +643,8 @@ def test_130_no_network_qubes_vm_update(self): method="qubes-vm-update", options=(), expected_ret_codes=(23,), - break_repo=True + break_repo=True, + expect_updated=False, ) def test_131_no_network_qubes_vm_update_cli(self): @@ -648,7 +652,8 @@ def test_131_no_network_qubes_vm_update_cli(self): method="qubes-vm-update", options=("--no-progress",), expected_ret_codes=(23,), - break_repo=True + break_repo=True, + expect_updated=False, )