diff --git a/eb_hooks.py b/eb_hooks.py index 9031d97831..0817de07b4 100644 --- a/eb_hooks.py +++ b/eb_hooks.py @@ -285,6 +285,32 @@ def pre_test_hook_ignore_failing_tests_SciPybundle(self, *args, **kwargs): self.cfg['testopts'] = "|| echo ignoring failing tests" +def pre_single_extension_hook(ext, *args, **kwargs): + """Main pre-configure hook: trigger custom functions based on software name.""" + if ext.name in PRE_SINGLE_EXTENSION_HOOKS: + PRE_SINGLE_EXTENSION_HOOKS[ext.name](ext, *args, **kwargs) + + +def pre_single_extension_testthat(ext, *args, **kwargs): + """ + Pre-extension hook for testthat R package, to fix build on top of recent glibc. + """ + if ext.name == 'testthat' and LooseVersion(ext.version) < LooseVersion('3.1.0'): + # use constant value instead of SIGSTKSZ for stack size, + # cfr. https://github.com/r-lib/testthat/issues/1373 + https://github.com/r-lib/testthat/pull/1403 + ext.cfg['preinstallopts'] = "sed -i 's/SIGSTKSZ/32768/g' inst/include/testthat/vendor/catch.h && " + + +def pre_single_extension_isoband(ext, *args, **kwargs): + """ + Pre-extension hook for isoband R package, to fix build on top of recent glibc. + """ + if ext.name == 'isoband' and LooseVersion(ext.version) < LooseVersion('0.2.5'): + # use constant value instead of SIGSTKSZ for stack size in vendored testthat included in isoband sources, + # cfr. https://github.com/r-lib/isoband/commit/6984e6ce8d977f06e0b5ff73f5d88e5c9a44c027 + ext.cfg['preinstallopts'] = "sed -i 's/SIGSTKSZ/32768/g' src/testthat/vendor/catch.h && " + + PARSE_HOOKS = { 'CGAL': parse_hook_cgal_toolchainopts_precise, 'fontconfig': parse_hook_fontconfig_add_fonts, @@ -307,3 +333,8 @@ def pre_test_hook_ignore_failing_tests_SciPybundle(self, *args, **kwargs): PRE_TEST_HOOKS = { 'SciPy-bundle': pre_test_hook_ignore_failing_tests_SciPybundle, } + +PRE_SINGLE_EXTENSION_HOOKS = { + 'isoband': pre_single_extension_isoband, + 'testthat': pre_single_extension_testthat, +} diff --git a/eessi-2023.06-eb-4.8.1-2022a.yml b/eessi-2023.06-eb-4.8.1-2022a.yml index 840feb96bb..ce1f587dad 100644 --- a/eessi-2023.06-eb-4.8.1-2022a.yml +++ b/eessi-2023.06-eb-4.8.1-2022a.yml @@ -13,11 +13,12 @@ easyconfigs: options: from-pr: 18881 - Boost.Python-1.79.0-GCC-11.3.0.eb - - netCDF-4.9.0-gompi-2022a.eb: - # use updated CMakeMake easyblock to avoid that -DCMAKE_SKIP_RPATH=ON is used, which breaks the netCDF test step - # see https://github.com/easybuilders/easybuild-easyblocks/pull/3012 - options: - include-easyblocks-from-pr: 3012 + - netCDF-4.9.0-gompi-2022a.eb + # - netCDF-4.9.0-gompi-2022a.eb: + # # use updated CMakeMake easyblock to avoid that -DCMAKE_SKIP_RPATH=ON is used, which breaks the netCDF test step + # # see https://github.com/easybuilders/easybuild-easyblocks/pull/3012 + # options: + # include-easyblocks-from-pr: 3012 - NCO-5.1.0-foss-2022a.eb - AdapterRemoval-2.3.3-GCC-11.3.0.eb - BEDTools-2.30.0-GCC-11.3.0.eb @@ -30,11 +31,12 @@ easyconfigs: - Ninja-1.10.2-GCCcore-11.3.0.eb - Z3-4.10.2-GCCcore-11.3.0.eb - SciPy-bundle-2022.05-foss-2022a.eb - - Xvfb-21.1.3-GCCcore-11.3.0.eb: - # enable exec permissions for xvfb-run after copying; - # need to also enable user write permissions on xvfb-run to ensure that copying with preserved permissions works - options: - from-pr: 18834 + - Xvfb-21.1.3-GCCcore-11.3.0.eb + # - Xvfb-21.1.3-GCCcore-11.3.0.eb: + # # enable exec permissions for xvfb-run after copying; + # # need to also enable user write permissions on xvfb-run to ensure that copying with preserved permissions works + # options: + # from-pr: 18834 - tbb-2021.5.0-GCCcore-11.3.0.eb - CMSeq-1.0.4-foss-2022a.eb - Pango-1.50.7-GCCcore-11.3.0.eb diff --git a/eessi-2023.06-eb-4.8.2-2022a.yml b/eessi-2023.06-eb-4.8.2-2022a.yml index 2a6721cd9a..02077b496b 100644 --- a/eessi-2023.06-eb-4.8.2-2022a.yml +++ b/eessi-2023.06-eb-4.8.2-2022a.yml @@ -1,2 +1,3 @@ easyconfigs: - CDO-2.0.6-gompi-2022a.eb + - R-4.2.1-foss-2022a.eb