commit:     70a0b3a104fbce20ee72549dbc3f96115dce5c46
Author:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
AuthorDate: Sun Feb  4 14:17:19 2024 +0000
Commit:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
CommitDate: Thu Apr 25 20:42:37 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=70a0b3a1

ecm.eclass: Restrict ECM_TEST="optional" and punting dep to _KFSLOT=5

In dev-qt/qtbase:6, Qt6Test is always provided so it makes no sense to
go through the trouble of ripping out the build dependency.

We should still aim to avoid needless building of tests if not requested,
either by detecting unconditional use of ecm_add_test or expose existing
force* logic to ebuild developers to catch those as errors.

Signed-off-by: Andreas Sturmlechner <asturm <AT> gentoo.org>

 eclass/ecm.eclass | 50 +++++++++++++++++++++++++++++---------------------
 1 file changed, 29 insertions(+), 21 deletions(-)

diff --git a/eclass/ecm.eclass b/eclass/ecm.eclass
index d83320e991ed..6d64815984cc 100644
--- a/eclass/ecm.eclass
+++ b/eclass/ecm.eclass
@@ -125,20 +125,21 @@ fi
 # @ECLASS_VARIABLE: ECM_TEST
 # @DEFAULT_UNSET
 # @DESCRIPTION:
-# Will accept "true", "false", "optional", "forceoptional",
-# "forceoptional-recursive".
+# Will accept "true", "false", "forceoptional", and "forceoptional-recursive".
+# For KF5-based ebuilds, additionally accepts "optional".
 # Default value is "false", except for CATEGORY=kde-frameworks where it is
 # set to "true". If set to "false", do nothing.
-# For any other value, add "test" to IUSE (and for KF5 DEPEND on
-# dev-qt/qttest:5). If set to "optional", build with
-# -DCMAKE_DISABLE_FIND_PACKAGE_Qt${_KFSLOT}Test=ON when USE=!test. If set
-# to "forceoptional", punt Qt${_KFSLOT}Test dependency and ignore "autotests",
-# "test", "tests" subdirs from top-level CMakeLists.txt when USE=!test.
-# If set to "forceoptional-recursive", punt Qt${_KFSLOT}Test dependencies and
-# make autotest(s), unittest(s) and test(s) subdirs from *any* CMakeLists.txt
-# in ${S} and below conditional on BUILD_TESTING when USE=!test. This is always
-# meant as a short-term fix and creates ${T}/${P}-tests-optional.patch to
-# refine and submit upstream.
+# For any other value, add "test" to IUSE. If set to "forceoptional", ignore
+# "autotests", "test", "tests" subdirs from top-level CMakeLists.txt when
+# USE=!test. If set to "forceoptional-recursive", make autotest(s), unittest(s)
+# and test(s) subdirs from *any* CMakeLists.txt in ${S} and below conditional
+# on BUILD_TESTING when USE=!test. This is always meant as a short-term fix and
+# creates ${T}/${P}-tests-optional.patch to refine and submit upstream.
+# For KF5-based ebuilds:
+# Additionally DEPEND on dev-qt/qttest:5 if USE=test, but punt Qt5Test
+# dependency if set to "forceoptional*" with USE=!test.
+# If set to "optional", build with -DCMAKE_DISABLE_FIND_PACKAGE_Qt5Test=ON
+# when USE=!test.
 if [[ ${CATEGORY} = kde-frameworks ]]; then
        : "${ECM_TEST:=true}"
 fi
@@ -258,13 +259,13 @@ case ${ECM_QTHELP} in
 esac
 
 case ${ECM_TEST} in
-       true|optional|forceoptional|forceoptional-recursive)
-               IUSE+=" test"
-               if [[ ${_KFSLOT} == 5 ]]; then
-                       DEPEND+=" test? ( dev-qt/qttest:${_KFSLOT} )"
+       optional)
+               if [[ ${_KFSLOT} != 5 ]]; then
+                       eerror "Banned value for \${ECM_TEST}"
+                       die "Value ${ECM_TEST} is only supported in KF5"
                fi
-               RESTRICT+=" !test? ( test )"
                ;;
+       true|forceoptional|forceoptional-recursive) ;;
        false) ;;
        *)
                eerror "Unknown value for \${ECM_TEST}"
@@ -277,10 +278,17 @@ BDEPEND+="
        >=kde-frameworks/extra-cmake-modules-${KFMIN}:*
 "
 RDEPEND+=" >=kde-frameworks/kf-env-4"
+if [[ ${ECM_TEST} != false ]]; then
+       IUSE+=" test"
+       RESTRICT+=" !test? ( test )"
+fi
 if [[ ${_KFSLOT} == 6 ]]; then
        COMMONDEPEND+=" dev-qt/qtbase:${_KFSLOT}"
 else
        COMMONDEPEND+=" dev-qt/qtcore:${_KFSLOT}"
+       if [[ ${ECM_TEST} != false ]]; then
+               DEPEND+=" test? ( dev-qt/qttest:5 )"
+       fi
 fi
 
 DEPEND+=" ${COMMONDEPEND}"
@@ -498,11 +506,11 @@ ecm_src_prepare() {
        # only build unit tests when required
        if ! { in_iuse test && use test; } ; then
                if [[ ${ECM_TEST} = forceoptional ]] ; then
-                       ecm_punt_qt_module Test
+                       [[ ${_KFSLOT} = 5 ]] && ecm_punt_qt_module Test
                        # if forceoptional, also cover non-kde categories
                        cmake_comment_add_subdirectory autotests test tests
                elif [[ ${ECM_TEST} = forceoptional-recursive ]] ; then
-                       ecm_punt_qt_module Test
+                       [[ ${_KFSLOT} = 5 ]] && ecm_punt_qt_module Test
                        local f pf="${T}/${P}"-tests-optional.patch
                        touch ${pf} || die "Failed to touch patch file"
                        for f in $(find . -type f -name "CMakeLists.txt" -exec \
@@ -552,8 +560,8 @@ ecm_src_configure() {
        if in_iuse test && ! use test ; then
                cmakeargs+=( -DBUILD_TESTING=OFF )
 
-               if [[ ${ECM_TEST} = optional ]] ; then
-                       cmakeargs+=( 
-DCMAKE_DISABLE_FIND_PACKAGE_Qt${_KFSLOT}Test=ON )
+               if [[ ${_KFSLOT} = 5 && ${ECM_TEST} = optional ]] ; then
+                       cmakeargs+=( -DCMAKE_DISABLE_FIND_PACKAGE_Qt5Test=ON )
                fi
        fi
 

Reply via email to