aboutsummaryrefslogtreecommitdiff
path: root/run_unittests.py
diff options
context:
space:
mode:
authorDavid Seifert <16636962+SoapGentoo@users.noreply.github.com>2019-09-09 01:48:57 +0200
committerJussi Pakkanen <jpakkane@gmail.com>2019-09-08 19:48:57 -0400
commite19a49b8957cd06d6f121812b7b00ef60a57fc7c (patch)
tree22a6842d0f0c36ade922cc9d3574ef541c8eecf9 /run_unittests.py
parentc9042fc3eeb0f4e76f5cc1716677aec39e1821b7 (diff)
downloadmeson-e19a49b8957cd06d6f121812b7b00ef60a57fc7c.zip
meson-e19a49b8957cd06d6f121812b7b00ef60a57fc7c.tar.gz
meson-e19a49b8957cd06d6f121812b7b00ef60a57fc7c.tar.bz2
Fix static archives stripping (#5905)
* Do not strip static archives Stripping static archives without more fine-grained options (e.g. `-g`) leads to failures such as ld: libfoo.a: error adding symbols: archive has no index; run ranlib to add one because GNU strip removes *every* symbol in a static archive by default. Given that static archives are not final build artifacts (unlike executables and shared libraries), stripping them gains little and only causes more edge case failures. * Gentoo's portage only strips debug information: https://github.com/gentoo/portage/blob/86f211e3a552753eb945670a39c1a3b14c3c3bd1/bin/estrip#L322 * Fedora also only strips debug information: https://github.com/rpm-software-management/rpm/blob/e9c13c6565cf4782d1f73255ee9144dd9bd2aca7/scripts/brp-strip-static-archive#L18 * Debian also only does some very light stripping: https://github.com/Debian/debhelper/blob/72ed1d3261730d56da6afde0ec7f52f32976e04d/dh_strip#L374 Fixes #4138 * Add test case for static archive stripping
Diffstat (limited to 'run_unittests.py')
-rwxr-xr-xrun_unittests.py27
1 files changed, 27 insertions, 0 deletions
diff --git a/run_unittests.py b/run_unittests.py
index 04d67a8..07f0b93 100755
--- a/run_unittests.py
+++ b/run_unittests.py
@@ -5331,6 +5331,33 @@ endian = 'little'
self.build()
@skipIfNoPkgconfig
+ def test_static_archive_stripping(self):
+ '''
+ Check that Meson produces valid static archives with --strip enabled
+ '''
+ with tempfile.TemporaryDirectory() as tempdirname:
+ testdirbase = os.path.join(self.unit_test_dir, '68 static archive stripping')
+
+ # build lib
+ self.new_builddir()
+ testdirlib = os.path.join(testdirbase, 'lib')
+ testlibprefix = os.path.join(tempdirname, 'libprefix')
+ self.init(testdirlib, extra_args=['--prefix=' + testlibprefix,
+ '--libdir=lib',
+ '--default-library=static',
+ '--buildtype=debug',
+ '--strip'], default_args=False)
+ self.build()
+ self.install(use_destdir=False)
+
+ # build executable (uses lib, fails if static archive has been stripped incorrectly)
+ pkg_dir = os.path.join(testlibprefix, 'lib/pkgconfig')
+ self.new_builddir()
+ self.init(os.path.join(testdirbase, 'app'),
+ override_envvars={'PKG_CONFIG_PATH': pkg_dir})
+ self.build()
+
+ @skipIfNoPkgconfig
def test_pkgconfig_formatting(self):
testdir = os.path.join(self.unit_test_dir, '38 pkgconfig format')
self.init(testdir)