diff options
author | 2023-07-17 16:14:08 +0200 | |
---|---|---|
committer | 2023-07-17 16:21:01 +0200 | |
commit | ff8c8c0f3f35f889a92ce4eac351151cc6db6b18 (patch) | |
tree | 5ec32d20e8ca6db371f599c99676c43973fb6217 | |
parent | dev-libs/libclc: Add 17.0.0_pre20230717 snapshot (diff) | |
download | gentoo-ff8c8c0f3f35f889a92ce4eac351151cc6db6b18.tar.gz gentoo-ff8c8c0f3f35f889a92ce4eac351151cc6db6b18.tar.bz2 gentoo-ff8c8c0f3f35f889a92ce4eac351151cc6db6b18.zip |
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@gentoo.org>
Co-authored-by: Giuseppe Foti <foti.giuseppe@gmail.com>
-rw-r--r-- | dev-libs/paho-mqtt-c/Manifest | 1 | ||||
-rw-r--r-- | 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 } |