summarylogtreecommitdiffstats
path: root/0003-tests-Fix-unit-tests-with-high-parallelism.patch
diff options
context:
space:
mode:
Diffstat (limited to '0003-tests-Fix-unit-tests-with-high-parallelism.patch')
-rw-r--r--0003-tests-Fix-unit-tests-with-high-parallelism.patch56
1 files changed, 56 insertions, 0 deletions
diff --git a/0003-tests-Fix-unit-tests-with-high-parallelism.patch b/0003-tests-Fix-unit-tests-with-high-parallelism.patch
new file mode 100644
index 000000000000..397cca441dfe
--- /dev/null
+++ b/0003-tests-Fix-unit-tests-with-high-parallelism.patch
@@ -0,0 +1,56 @@
+From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
+From: "Jan Alexander Steffens (heftig)" <heftig@archlinux.org>
+Date: Tue, 5 Mar 2024 19:33:33 +0100
+Subject: [PATCH] tests: Fix unit tests with high parallelism
+
+On Arch's shiny new 48-core/96-thread build server, the
+`test_install_log_content` test fails because of an unexpected
+`invalid-symlink.txt` file. Apparently the test runs in parallel with
+`test_install_subdir_symlinks`, which modifies the `59 install subdir`
+source directory.
+
+To fix this, make `install_subdir_invalid_symlinks` copy the entire test
+into a tmpdir before modifying it.
+---
+ unittests/linuxliketests.py | 21 +++++++++------------
+ 1 file changed, 9 insertions(+), 12 deletions(-)
+
+diff --git a/unittests/linuxliketests.py b/unittests/linuxliketests.py
+index f66dc9769a8f..ce4d36fe024c 100644
+--- a/unittests/linuxliketests.py
++++ b/unittests/linuxliketests.py
+@@ -1413,25 +1413,22 @@ class LinuxlikeTests(BasePlatformTests):
+ Test that installation of broken symlinks works fine.
+ https://github.com/mesonbuild/meson/issues/3914
+ '''
+- testdir = os.path.join(self.common_test_dir, testdir)
++ testdir = self.copy_srcdir(os.path.join(self.common_test_dir, testdir))
+ subdir = os.path.join(testdir, subdir_path)
+ with chdir(subdir):
+ # Can't distribute broken symlinks in the source tree because it breaks
+ # the creation of zipapps. Create it dynamically and run the test by
+ # hand.
+ src = '../../nonexistent.txt'
+ os.symlink(src, 'invalid-symlink.txt')
+- try:
+- self.init(testdir)
+- self.build()
+- self.install()
+- install_path = subdir_path.split(os.path.sep)[-1]
+- link = os.path.join(self.installdir, 'usr', 'share', install_path, 'invalid-symlink.txt')
+- self.assertTrue(os.path.islink(link), msg=link)
+- self.assertEqual(src, os.readlink(link))
+- self.assertFalse(os.path.isfile(link), msg=link)
+- finally:
+- os.remove(os.path.join(subdir, 'invalid-symlink.txt'))
++ self.init(testdir)
++ self.build()
++ self.install()
++ install_path = subdir_path.split(os.path.sep)[-1]
++ link = os.path.join(self.installdir, 'usr', 'share', install_path, 'invalid-symlink.txt')
++ self.assertTrue(os.path.islink(link), msg=link)
++ self.assertEqual(src, os.readlink(link))
++ self.assertFalse(os.path.isfile(link), msg=link)
+
+ def test_install_subdir_symlinks(self):
+ self.install_subdir_invalid_symlinks('59 install subdir', os.path.join('sub', 'sub1'))