commit:     61b4a51d32692755569d4613dfdf444ee6d8d938
Author:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
AuthorDate: Thu Aug 17 17:41:24 2017 +0000
Commit:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
CommitDate: Thu Aug 17 18:58:09 2017 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=61b4a51d

kde5.eclass: KDE_TEST=forceoptional-recursive reloaded

Searches for test subdirectory pattern in CMakeLists.txt recursively,
enclose it with BUILD_TESTING conditional.

Creates unified diff to easily pick up for cosmetics and submission
upstream.

Re-order unconditional Frameworks tests disabling to produce more
compatible forceoptional-recursive tests.

 eclass/kde5.eclass | 42 +++++++++++++++++++++++++++++++-----------
 1 file changed, 31 insertions(+), 11 deletions(-)

diff --git a/eclass/kde5.eclass b/eclass/kde5.eclass
index b4cfadc9dfc..b48dd4b46b1 100644
--- a/eclass/kde5.eclass
+++ b/eclass/kde5.eclass
@@ -90,6 +90,13 @@ else
        : ${KDE_QTHELP:=false}
 fi
 
+# @ECLASS-VARIABLE: KDE_TESTPATTERN
+# @DESCRIPTION:
+# DANGER: Only touch it if you know what you are doing.
+# By default, matches autotest(s), unittest(s) and test(s) pattern inside
+# cmake add_subdirectory calls.
+: ${KDE_TESTPATTERN:="\(auto|unit\)\?tests\?"}
+
 # @ECLASS-VARIABLE: KDE_TEST
 # @DESCRIPTION:
 # If set to "false", do nothing.
@@ -98,8 +105,10 @@ fi
 # when USE=!test.
 # If set to "forceoptional", remove a Qt5Test dependency and comment test
 # subdirs from the root CMakeLists.txt in addition to the above.
-# If set to "forceoptional-recursive", remove a Qt5Test dependency and comment
-# test subdirs from *any* CMakeLists.txt in addition to the above.
+# If set to "forceoptional-recursive", remove Qt5Test dependencies and make
+# test subdirs according to KDE_TESTPATTERN from *any* CMakeLists.txt in ${S}
+# and below conditional on BUILD_TESTING. This is always meant as a short-term
+# fix and creates ${T}/${P}-tests-optional.patch to refine and submit upstream.
 if [[ ${CATEGORY} = kde-frameworks ]]; then
        : ${KDE_TEST:=true}
 else
@@ -615,11 +624,6 @@ kde5_src_prepare() {
                fi
        fi
 
-       # in frameworks, tests = manual tests so never build them
-       if [[ ${CATEGORY} = kde-frameworks ]] && [[ ${PN} != 
extra-cmake-modules ]]; then
-               cmake_comment_add_subdirectory tests
-       fi
-
        # only build unit tests when required
        if ! use_if_iuse test ; then
                if [[ ${KDE_TEST} = forceoptional ]] ; then
@@ -628,17 +632,33 @@ kde5_src_prepare() {
                        cmake_comment_add_subdirectory autotests test tests
                elif [[ ${KDE_TEST} = forceoptional-recursive ]] ; then
                        punt_bogus_dep Qt5 Test
-                       local d
-                       for d in $(find . -type d -name "autotests" -or -name 
"tests" -or -name "test" -or -name "unittests"); do
-                               pushd ${d%/*} > /dev/null || die
+                       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 \
+                               grep -l 
"^\s*add_subdirectory\s*\(\s*.*${KDE_TESTPATTERN}\s*)\s*\)" {} \;); do
+                               cp ${f} ${f}.old || die "Failed to prepare 
patch origfile"
+                               pushd ${f%/*} > /dev/null || die
                                        punt_bogus_dep Qt5 Test
-                                       cmake_comment_add_subdirectory 
autotests test tests
+                                       sed -i CMakeLists.txt -e \
+                                               "/^#/! 
s/add_subdirectory\s*\(\s*.*${KDE_TESTPATTERN}\s*)\s*\)/if(BUILD_TESTING)\n&\nendif()/"
 \
+                                               || die
                                popd > /dev/null || die
+                               diff -Naur ${f}.old ${f} 1>>${pf}
+                               rm ${f}.old || die "Failed to clean up"
                        done
+                       einfo "Build system was modified by 
KDE_TEST=forceoptional-recursive."
+                       einfo "Unified diff file ready for pickup in:"
+                       einfo "  ${pf}"
+                       einfo "Push it upstream to make this message go away."
                elif [[ ${CATEGORY} = kde-frameworks || ${CATEGORY} = 
kde-plasma || ${CATEGORY} = kde-apps ]] ; then
                        cmake_comment_add_subdirectory autotests test tests
                fi
        fi
+
+       # in frameworks, tests = manual tests so never build them
+       if [[ ${CATEGORY} = kde-frameworks ]] && [[ ${PN} != 
extra-cmake-modules ]]; then
+               cmake_comment_add_subdirectory tests
+       fi
 }
 
 # @FUNCTION: kde5_src_configure

Reply via email to