* [PATCH v3 1/2] ell: add ptests
@ 2024-08-01 8:22 Martin Hundebøll
2024-08-01 8:22 ` [PATCH v3 2/2] ofono: " Martin Hundebøll
2024-08-02 12:36 ` [OE-core] [PATCH v3 1/2] ell: " Ross Burton
0 siblings, 2 replies; 6+ messages in thread
From: Martin Hundebøll @ 2024-08-01 8:22 UTC (permalink / raw)
To: openembedded-core; +Cc: Martin Hundebøll
Depends on openssl-native and xxd-native to allow generating
certificates used for testing.
Create the ${B}/unit dir as that seems to be missing with the automake
patches used for building tests separately from running them.
In order to build the test cases, both --enable-tests and
--enable-maintainer-mode must be passed to configure.
A few unit tests looks for files in ../ell-0.67/unit (i.e. $(top_srcdir)
in automake) when running. Instead of playing games with symlinks or
install paths, the "correct" path is just (re)defined in CFLAGS.
Skip a few tests that require additional kernel modules to be enabled.
Test execution time is about 10 seconds.
Signed-off-by: Martin Hundebøll <martin@geanix.com>
---
.../distro/include/ptest-packagelists.inc | 1 +
meta/recipes-core/ell/ell_0.67.bb | 24 ++++++++++++++++---
meta/recipes-core/ell/files/run-ptest | 23 ++++++++++++++++++
3 files changed, 45 insertions(+), 3 deletions(-)
create mode 100644 meta/recipes-core/ell/files/run-ptest
diff --git a/meta/conf/distro/include/ptest-packagelists.inc b/meta/conf/distro/include/ptest-packagelists.inc
index e3ab7e862925..a655439f5ebe 100644
--- a/meta/conf/distro/include/ptest-packagelists.inc
+++ b/meta/conf/distro/include/ptest-packagelists.inc
@@ -15,6 +15,7 @@ PTESTS_FAST = "\
cpio \
diffstat \
diffutils \
+ ell \
ethtool \
expat \
expect \
diff --git a/meta/recipes-core/ell/ell_0.67.bb b/meta/recipes-core/ell/ell_0.67.bb
index 6b0ebbe62113..ee9aa73d2908 100644
--- a/meta/recipes-core/ell/ell_0.67.bb
+++ b/meta/recipes-core/ell/ell_0.67.bb
@@ -10,9 +10,27 @@ SECTION = "libs"
LICENSE = "LGPL-2.1-only"
LIC_FILES_CHKSUM = "file://COPYING;md5=fb504b67c50331fc78734fed90fb0e09"
-DEPENDS = "dbus"
+DEPENDS = "dbus openssl-native xxd-native"
-inherit autotools pkgconfig
+inherit autotools pkgconfig ptest
-SRC_URI = "https://mirrors.edge.kernel.org/pub/linux/libs/${BPN}/${BPN}-${PV}.tar.xz"
+SRC_URI = " \
+ https://mirrors.edge.kernel.org/pub/linux/libs/${BPN}/${BPN}-${PV}.tar.xz \
+ file://run-ptest \
+"
SRC_URI[sha256sum] = "97942e8cefb130b632496e5485242f3f374f3b8846800fb74fffd76dc2a0c726"
+
+EXTRA_OECONF += "--enable-tests --enable-maintainer-mode"
+CFLAGS += "-UUNITDIR -DUNITDIR="\\"./unit/\\"""
+
+do_compile:prepend() {
+ mkdir -p ${B}/unit
+}
+
+do_install_ptest() {
+ install -m755 -Dt ${D}${PTEST_PATH} $(find ${B}/unit -executable -type f)
+ install -Dt ${D}${PTEST_PATH}/unit \
+ ${S}/unit/dbus.conf \
+ ${S}/unit/settings.test \
+ $(find ${B}/unit -name \*.pem -type f)
+}
diff --git a/meta/recipes-core/ell/files/run-ptest b/meta/recipes-core/ell/files/run-ptest
new file mode 100644
index 000000000000..5b3acdd98b8a
--- /dev/null
+++ b/meta/recipes-core/ell/files/run-ptest
@@ -0,0 +1,23 @@
+#!/bin/sh
+
+ret_val=0
+
+for test in test-*; do
+ case "$test" in
+ test-pem | test-key)
+ if ! [ -d /sys/module/pkcs8_key_parser ]; then
+ echo "SKIP: $test"
+ continue
+ fi
+ ;;
+ esac
+
+ if "./$test" >> ell_test.log 2>&1; then
+ echo "PASS: $test"
+ else
+ echo "FAIL: $test"
+ ret_val=1
+ fi
+done
+
+exit $ret_val
--
2.45.2
^ permalink raw reply related [flat|nested] 6+ messages in thread
* [PATCH v3 2/2] ofono: add ptests
2024-08-01 8:22 [PATCH v3 1/2] ell: add ptests Martin Hundebøll
@ 2024-08-01 8:22 ` Martin Hundebøll
2024-08-02 12:39 ` [OE-core] " Ross Burton
2024-08-02 12:36 ` [OE-core] [PATCH v3 1/2] ell: " Ross Burton
1 sibling, 1 reply; 6+ messages in thread
From: Martin Hundebøll @ 2024-08-01 8:22 UTC (permalink / raw)
To: openembedded-core; +Cc: Martin Hundebøll
Install and run the unit tests already provided by ofono. Test execution
time is about a second.
Signed-off-by: Martin Hundebøll <martin@geanix.com>
---
Change since v2:
* disable basic mux test that requires phonesim service to connect to
Change since v1:
* add missing run-ptest file
.../distro/include/ptest-packagelists.inc | 1 +
.../ofono/ofono/run-ptest | 25 +++++++++++++++++++
meta/recipes-connectivity/ofono/ofono_2.9.bb | 12 ++++++++-
3 files changed, 37 insertions(+), 1 deletion(-)
create mode 100644 meta/recipes-connectivity/ofono/ofono/run-ptest
diff --git a/meta/conf/distro/include/ptest-packagelists.inc b/meta/conf/distro/include/ptest-packagelists.inc
index a655439f5ebe..ad117c1bcc76 100644
--- a/meta/conf/distro/include/ptest-packagelists.inc
+++ b/meta/conf/distro/include/ptest-packagelists.inc
@@ -54,6 +54,7 @@ PTESTS_FAST = "\
lzo \
m4 \
nettle \
+ ofono \
opkg \
popt \
python3-atomicwrites \
diff --git a/meta/recipes-connectivity/ofono/ofono/run-ptest b/meta/recipes-connectivity/ofono/ofono/run-ptest
new file mode 100644
index 000000000000..99a79376382a
--- /dev/null
+++ b/meta/recipes-connectivity/ofono/ofono/run-ptest
@@ -0,0 +1,25 @@
+#!/bin/sh
+
+ret_val=0
+
+for test in test-*; do
+ case "$test" in
+ test-mux)
+ # the basic mux test requires a phonesim server process
+ # to connect to
+ args="-s /testmux/basic"
+ ;;
+ *)
+ args=""
+ ;;
+ esac
+
+ if "./$test" $args >> ofono_test.log 2>&1; then
+ echo "PASS: $test"
+ else
+ echo "FAIL: $test"
+ ret_val=1
+ fi
+done
+
+exit $ret_val
diff --git a/meta/recipes-connectivity/ofono/ofono_2.9.bb b/meta/recipes-connectivity/ofono/ofono_2.9.bb
index 26cb9bb7ffb7..6b641a6e854d 100644
--- a/meta/recipes-connectivity/ofono/ofono_2.9.bb
+++ b/meta/recipes-connectivity/ofono/ofono_2.9.bb
@@ -10,10 +10,11 @@ DEPENDS = "dbus glib-2.0 udev mobile-broadband-provider-info ell"
SRC_URI = "\
${KERNELORG_MIRROR}/linux/network/${BPN}/${BP}.tar.xz \
file://ofono \
+ file://run-ptest \
"
SRC_URI[sha256sum] = "9d2612925a23a7fb668f297a044b5ea136215cc399ecc3f127135c8f2a9845f9"
-inherit autotools pkgconfig update-rc.d systemd gobject-introspection-data
+inherit autotools pkgconfig update-rc.d systemd gobject-introspection-data ptest
INITSCRIPT_NAME = "ofono"
INITSCRIPT_PARAMS = "defaults 22"
@@ -28,11 +29,20 @@ PACKAGECONFIG[bluez] = "--enable-bluetooth, --disable-bluetooth, bluez5"
EXTRA_OECONF += "--enable-test --enable-external-ell"
+do_compile_ptest() {
+ oe_runmake buildtest-TESTS
+}
+
do_install:append() {
install -d ${D}${sysconfdir}/init.d/
install -m 0755 ${UNPACKDIR}/ofono ${D}${sysconfdir}/init.d/ofono
}
+do_install_ptest() {
+ install -m755 -Dt ${D}${PTEST_PATH} $(find ${B}/unit -executable -type f)
+ install -m644 -Dt ${D}${PTEST_PATH}/unit ${B}/unit/test-provision.db
+}
+
PACKAGES =+ "${PN}-tests"
FILES:${PN} += "${systemd_unitdir}"
--
2.45.2
^ permalink raw reply related [flat|nested] 6+ messages in thread
* Re: [OE-core] [PATCH v3 1/2] ell: add ptests
2024-08-01 8:22 [PATCH v3 1/2] ell: add ptests Martin Hundebøll
2024-08-01 8:22 ` [PATCH v3 2/2] ofono: " Martin Hundebøll
@ 2024-08-02 12:36 ` Ross Burton
2024-08-02 12:51 ` Richard Purdie
1 sibling, 1 reply; 6+ messages in thread
From: Ross Burton @ 2024-08-02 12:36 UTC (permalink / raw)
To: Martin Hundebøll; +Cc: openembedded-core@lists.openembedded.org
On 1 Aug 2024, at 09:22, Martin Hundeb?ll via lists.openembedded.org <martin=geanix.com@lists.openembedded.org> wrote:
> diff --git a/meta/recipes-core/ell/ell_0.67.bb b/meta/recipes-core/ell/ell_0.67.bb
> index 6b0ebbe62113..ee9aa73d2908 100644
> --- a/meta/recipes-core/ell/ell_0.67.bb
> +++ b/meta/recipes-core/ell/ell_0.67.bb
> @@ -10,9 +10,27 @@ SECTION = "libs"
> LICENSE = "LGPL-2.1-only"
> LIC_FILES_CHKSUM = "file://COPYING;md5=fb504b67c50331fc78734fed90fb0e09"
>
> -DEPENDS = "dbus"
> +DEPENDS = "dbus openssl-native xxd-native"
This should be conditional on ptest, right?
> +EXTRA_OECONF += "--enable-tests --enable-maintainer-mode"
Make this conditional on ptest too?
> +do_compile:prepend() {
> + mkdir -p ${B}/unit
> +}
This sounds like a broken Makefile.am that has a bad assumption in.
> +do_install_ptest() {
> + install -m755 -Dt ${D}${PTEST_PATH} $(find ${B}/unit -executable -type f)
> + install -Dt ${D}${PTEST_PATH}/unit \
> + ${S}/unit/dbus.conf \
> + ${S}/unit/settings.test \
> + $(find ${B}/unit -name \*.pem -type f)
> +}
As the test scripts are built with libtool, it’s best to use libtool —mode=install to install them.
Ross
^ permalink raw reply [flat|nested] 6+ messages in thread
* Re: [OE-core] [PATCH v3 2/2] ofono: add ptests
2024-08-01 8:22 ` [PATCH v3 2/2] ofono: " Martin Hundebøll
@ 2024-08-02 12:39 ` Ross Burton
0 siblings, 0 replies; 6+ messages in thread
From: Ross Burton @ 2024-08-02 12:39 UTC (permalink / raw)
To: martin@geanix.com; +Cc: openembedded-core@lists.openembedded.org
> On 1 Aug 2024, at 09:22, Martin Hundeb?ll via lists.openembedded.org <martin=geanix.com@lists.openembedded.org> wrote:
> +do_install_ptest() {
> + install -m755 -Dt ${D}${PTEST_PATH} $(find ${B}/unit -executable -type f)
> + install -m644 -Dt ${D}${PTEST_PATH}/unit ${B}/unit/test-provision.db
> +}
As as ell: the binaries are built with libtool, so use libtool —mode=install to install them.
Ross
^ permalink raw reply [flat|nested] 6+ messages in thread
* Re: [OE-core] [PATCH v3 1/2] ell: add ptests
2024-08-02 12:36 ` [OE-core] [PATCH v3 1/2] ell: " Ross Burton
@ 2024-08-02 12:51 ` Richard Purdie
2024-08-03 21:07 ` Alexandre Belloni
0 siblings, 1 reply; 6+ messages in thread
From: Richard Purdie @ 2024-08-02 12:51 UTC (permalink / raw)
To: ross.burton, Martin Hundebøll
Cc: openembedded-core@lists.openembedded.org
On Fri, 2024-08-02 at 12:36 +0000, Ross Burton via
lists.openembedded.org wrote:
> On 1 Aug 2024, at 09:22, Martin Hundeb?ll via lists.openembedded.org
> <martin=geanix.com@lists.openembedded.org> wrote:
> > diff --git a/meta/recipes-core/ell/ell_0.67.bb b/meta/recipes-
> > core/ell/ell_0.67.bb
> > index 6b0ebbe62113..ee9aa73d2908 100644
> > --- a/meta/recipes-core/ell/ell_0.67.bb
> > +++ b/meta/recipes-core/ell/ell_0.67.bb
> > @@ -10,9 +10,27 @@ SECTION = "libs"
> > LICENSE = "LGPL-2.1-only"
> > LIC_FILES_CHKSUM =
> > "file://COPYING;md5=fb504b67c50331fc78734fed90fb0e09"
> >
> > -DEPENDS = "dbus"
> > +DEPENDS = "dbus openssl-native xxd-native"
>
> This should be conditional on ptest, right?
>
> > +EXTRA_OECONF += "--enable-tests --enable-maintainer-mode"
>
> Make this conditional on ptest too?
>
> > +do_compile:prepend() {
> > + mkdir -p ${B}/unit
> > +}
>
> This sounds like a broken Makefile.am that has a bad assumption in.
>
> > +do_install_ptest() {
> > + install -m755 -Dt ${D}${PTEST_PATH} $(find ${B}/unit -
> > executable -type f)
> > + install -Dt ${D}${PTEST_PATH}/unit \
> > + ${S}/unit/dbus.conf \
> > + ${S}/unit/settings.test \
> > + $(find ${B}/unit -name \*.pem -type f)
> > +}
>
> As the test scripts are built with libtool, it’s best to use libtool
> —mode=install to install them.
Thanks for the review Ross. There was also a failure in automated
testing on the autobuilder:
https://autobuilder.yoctoproject.org/typhoon/#/builders/81/builds/6864/steps/12/logs/stdio
The arm tests haven't run yet in that build.
Cheers,
Richard
^ permalink raw reply [flat|nested] 6+ messages in thread
* Re: [OE-core] [PATCH v3 1/2] ell: add ptests
2024-08-02 12:51 ` Richard Purdie
@ 2024-08-03 21:07 ` Alexandre Belloni
0 siblings, 0 replies; 6+ messages in thread
From: Alexandre Belloni @ 2024-08-03 21:07 UTC (permalink / raw)
To: Richard Purdie
Cc: ross.burton, Martin Hundebøll,
openembedded-core@lists.openembedded.org
On 02/08/2024 13:51:45+0100, Richard Purdie wrote:
> On Fri, 2024-08-02 at 12:36 +0000, Ross Burton via
> lists.openembedded.org wrote:
> > On 1 Aug 2024, at 09:22, Martin Hundeb?ll via lists.openembedded.org
> > <martin=geanix.com@lists.openembedded.org> wrote:
> > > diff --git a/meta/recipes-core/ell/ell_0.67.bb b/meta/recipes-
> > > core/ell/ell_0.67.bb
> > > index 6b0ebbe62113..ee9aa73d2908 100644
> > > --- a/meta/recipes-core/ell/ell_0.67.bb
> > > +++ b/meta/recipes-core/ell/ell_0.67.bb
> > > @@ -10,9 +10,27 @@ SECTION = "libs"
> > > LICENSE = "LGPL-2.1-only"
> > > LIC_FILES_CHKSUM =
> > > "file://COPYING;md5=fb504b67c50331fc78734fed90fb0e09"
> > >
> > > -DEPENDS = "dbus"
> > > +DEPENDS = "dbus openssl-native xxd-native"
> >
> > This should be conditional on ptest, right?
> >
> > > +EXTRA_OECONF += "--enable-tests --enable-maintainer-mode"
> >
> > Make this conditional on ptest too?
> >
> > > +do_compile:prepend() {
> > > + mkdir -p ${B}/unit
> > > +}
> >
> > This sounds like a broken Makefile.am that has a bad assumption in.
> >
> > > +do_install_ptest() {
> > > + install -m755 -Dt ${D}${PTEST_PATH} $(find ${B}/unit -
> > > executable -type f)
> > > + install -Dt ${D}${PTEST_PATH}/unit \
> > > + ${S}/unit/dbus.conf \
> > > + ${S}/unit/settings.test \
> > > + $(find ${B}/unit -name \*.pem -type f)
> > > +}
> >
> > As the test scripts are built with libtool, it’s best to use libtool
> > —mode=install to install them.
>
> Thanks for the review Ross. There was also a failure in automated
> testing on the autobuilder:
>
> https://autobuilder.yoctoproject.org/typhoon/#/builders/81/builds/6864/steps/12/logs/stdio
>
> The arm tests haven't run yet in that build.
It failed to build on arm64:
https://autobuilder.yoctoproject.org/typhoon/#/builders/82/builds/6689/steps/11/logs/stdio
>
> Cheers,
>
> Richard
>
>
>
> -=-=-=-=-=-=-=-=-=-=-=-
> Links: You receive all messages sent to this group.
> View/Reply Online (#202907): https://lists.openembedded.org/g/openembedded-core/message/202907
> Mute This Topic: https://lists.openembedded.org/mt/107661617/3617179
> Group Owner: openembedded-core+owner@lists.openembedded.org
> Unsubscribe: https://lists.openembedded.org/g/openembedded-core/unsub [alexandre.belloni@bootlin.com]
> -=-=-=-=-=-=-=-=-=-=-=-
>
--
Alexandre Belloni, co-owner and COO, Bootlin
Embedded Linux and Kernel engineering
https://bootlin.com
^ permalink raw reply [flat|nested] 6+ messages in thread
end of thread, other threads:[~2024-08-03 21:07 UTC | newest]
Thread overview: 6+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2024-08-01 8:22 [PATCH v3 1/2] ell: add ptests Martin Hundebøll
2024-08-01 8:22 ` [PATCH v3 2/2] ofono: " Martin Hundebøll
2024-08-02 12:39 ` [OE-core] " Ross Burton
2024-08-02 12:36 ` [OE-core] [PATCH v3 1/2] ell: " Ross Burton
2024-08-02 12:51 ` Richard Purdie
2024-08-03 21:07 ` Alexandre Belloni
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox