commit:     ff8c8c0f3f35f889a92ce4eac351151cc6db6b18
Author:     Florian Schmaus <flow <AT> gentoo <DOT> org>
AuthorDate: Mon Jul 17 14:14:08 2023 +0000
Commit:     Florian Schmaus <flow <AT> gentoo <DOT> org>
CommitDate: Mon Jul 17 14:21:01 2023 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=ff8c8c0f

dev-libs/paho-mqtt-c: wait for broker ports in src_test

Closes: https://bugs.gentoo.org/909552
Closes: https://github.com/gentoo/gentoo/pull/31922
Signed-off-by: Florian Schmaus <flow <AT> gentoo.org>
Co-authored-by: Giuseppe Foti <foti.giuseppe <AT> gmail.com>

 dev-libs/paho-mqtt-c/Manifest                  |  1 +
 dev-libs/paho-mqtt-c/paho-mqtt-c-1.3.12.ebuild | 52 +++++++++++++++++++++-----
 2 files changed, 44 insertions(+), 9 deletions(-)

diff --git a/dev-libs/paho-mqtt-c/Manifest b/dev-libs/paho-mqtt-c/Manifest
index 1804bd73b21b..aaf25ad26fc3 100644
--- a/dev-libs/paho-mqtt-c/Manifest
+++ b/dev-libs/paho-mqtt-c/Manifest
@@ -1,2 +1,3 @@
+DIST paho-mqtt-c-1.3.12-live.tar.gz 3642676 BLAKE2B 
c20e3bb1b4eae30b268639d30c1e4d72f6759850bef2dc13de424debb7a0785a5ba083af094e28cb80814df519831ac0e1da27d8aa4958361724aabea92c03e5
 SHA512 
af0f52944c46fe7874203b3b359d8fb8935d5bd6b394045138624b96130c6b756045fb3b486e224b7e55b3cb478197b8a049bbeb01ff7e3d16d0d3f12c521110
 DIST paho-mqtt-c-1.3.12.tar.gz 3622938 BLAKE2B 
9eb7bca0367a3001f00122f2056b60ddf3633e0304661a424821c3e2b3370d65e09c51c62f90bb89f0e4ce291640e71ae0d3b093fe600efb87aa3744e431cafe
 SHA512 
3152b557a8ab7c9b9c80277283e0f5e9965ce4c2ebbdaef0f238908d49e6fa1281aa72932ea112a836144b79656e4abe6e0cbd93840429a52e501a2c6b12d313
 DIST paho.mqtt.testing.tar.gz 175845 BLAKE2B 
02c284c4e1cfe91bb87735e8fc61f206c3e93adf18c567ff330ae8d1c2bd04b7aa079ba3961610b7c9cc7e22340be000bf56772d5c39d1bc4d1b406bf564da66
 SHA512 
8328c6a010d76cf62ee2007a849acb61b84cf2dc058525bc967661984fdf26407dd52da83a3f2acda56e3c5d309301ea2a8ed264466d0fb933994dd248dbbe8d

diff --git a/dev-libs/paho-mqtt-c/paho-mqtt-c-1.3.12.ebuild 
b/dev-libs/paho-mqtt-c/paho-mqtt-c-1.3.12.ebuild
index f1713fe8f0c1..a7d86494e837 100644
--- a/dev-libs/paho-mqtt-c/paho-mqtt-c-1.3.12.ebuild
+++ b/dev-libs/paho-mqtt-c/paho-mqtt-c-1.3.12.ebuild
@@ -9,11 +9,13 @@ inherit cmake python-any-r1 toolchain-funcs
 
 MY_TEST_UTILS="paho.mqtt.testing"
 MY_TEST_COMMIT="577f955352e41205c554d44966c2908e90026345"
+MY_LIVE_COMMIT="7db21329301b1f527c925dff789442db3ca3c1e7"
 
 DESCRIPTION="An Eclipse Paho C client library for MQTT for Windows, Linux and 
MacOS."
 HOMEPAGE="https://eclipse.org/paho";
 SRC_URI="
        https://github.com/eclipse/paho.mqtt.c/archive/refs/tags/v${PV}.tar.gz 
-> ${P}.tar.gz
+       https://github.com/eclipse/paho.mqtt.c/archive/${MY_LIVE_COMMIT}.tar.gz 
-> ${P}-live.tar.gz
        
https://github.com/eclipse/${MY_TEST_UTILS}/archive/${MY_TEST_COMMIT}.tar.gz -> 
${MY_TEST_UTILS}.tar.gz
 "
 
@@ -36,6 +38,17 @@ S="${WORKDIR}/paho.mqtt.c-${PV}"
 
 BUILD_DIR="${S}_build"
 
+src_prepare(){
+       cmake_src_prepare
+       if use test; then
+               # removing old certs
+               rm -r "${S}"/test/ssl || die
+               mv "${WORKDIR}"/paho.mqtt.c-"${MY_LIVE_COMMIT}"/test/ssl 
"${S}"/test/ssl || die
+
+               mv "${WORKDIR}/${MY_TEST_UTILS}-${MY_TEST_COMMIT}" 
"${WORKDIR}/${MY_TEST_UTILS}" || die
+       fi
+}
+
 src_configure(){
        local mycmakeargs=(
                -DPAHO_BUILD_SHARED=TRUE
@@ -45,12 +58,6 @@ src_configure(){
                -DPAHO_ENABLE_TESTING="$(usex test "TRUE" "FALSE")"
        )
        cmake_src_configure
-       if use test; then
-               mv "${WORKDIR}"/"${MY_TEST_UTILS}"-"${MY_TEST_COMMIT}" 
"${WORKDIR}"/"${MY_TEST_UTILS}" || die
-               # a subdir in test
-               mv "${WORKDIR}"/"${MY_TEST_UTILS}" "${BUILD_DIR}"/test/ || die
-               cp "${S}"/test/*.py "${BUILD_DIR}"/test/ || die
-       fi
 }
 
 src_test() {
@@ -59,9 +66,36 @@ src_test() {
                return
        fi
 
-       ${EPYTHON} 
"${BUILD_DIR}"/test/"${MY_TEST_UTILS}"/interoperability/startbroker.py -c \
-                          
"${BUILD_DIR}"/test/"${MY_TEST_UTILS}"/interoperability/localhost_testing.conf &
+       cd "${WORKDIR}/${MY_TEST_UTILS}/interoperability" || die
 
-       ${EPYTHON} "${BUILD_DIR}"/test/mqttsas.py &
+       ${EPYTHON} startbroker.py -c localhost_testing.conf \
+                          > "${T}/testbroker.log" &
+       local -r startbroker_pid=$!
+
+       ${EPYTHON} "${S}"/test/mqttsas.py \
+                          > "${T}/testmqttsas.log" &
+       local -r mqttsas_pid=$!
+
+       local port ports
+       ports=(1883 1888{3..8})
+
+       for port in ${ports[@]}; do
+               einfo "Waiting for TCP port ${port} to become available"
+               if timeout 30 bash -c \
+                               'until printf "" >/dev/tcp/${0}/${1} 2>> 
"${T}/portlog"; do sleep 1; done' \
+                               localhost "${port}"; then
+                       continue
+               fi
+
+               kill ${startbroker_pid} ${mqttsas_pid}
+               die "Timeout waiting for port ${port} to become available"
+       done
+
+       local myctestargs=(
+               -j 1
+               --timeout 600
+       )
        cmake_src_test
+
+       kill ${startbroker_pid} ${mqttsas_pid} || die
 }

Reply via email to