From: Richard Purdie <richard.purdie@linuxfoundation.org>
To: Khem Raj <raj.khem@gmail.com>, openembedded-core@lists.openembedded.org
Subject: Re: [OE-core] [PATCH] cpio: Run ptests under ptest user
Date: Thu, 04 May 2023 22:16:41 +0100 [thread overview]
Message-ID: <6a5ca0bf10350375f568163e3be93dfeed266d6f.camel@linuxfoundation.org> (raw)
In-Reply-To: <20230429012900.872374-1-raj.khem@gmail.com>
On Fri, 2023-04-28 at 18:29 -0700, Khem Raj wrote:
> Running these tests under root user on musl works ok but it emits
> additional diagnostic
>
> cpio: dir: Cannot change ownership to uid 0, gid 0: Not supported
>
> Ideally its better to run this test suite under non-root user which
> is often how these are run. Moreover, tests work on musl as well.
>
> Signed-off-by: Khem Raj <raj.khem@gmail.com>
> ---
> meta/recipes-extended/cpio/cpio-2.13/run-ptest | 9 +--------
> .../cpio/cpio-2.13/{run-ptest => test.sh} | 0
> meta/recipes-extended/cpio/cpio_2.13.bb | 16 ++++++++++++++++
> 3 files changed, 17 insertions(+), 8 deletions(-)
> mode change 100644 => 100755 meta/recipes-extended/cpio/cpio-2.13/run-ptest
> copy meta/recipes-extended/cpio/cpio-2.13/{run-ptest => test.sh} (100%)
>
> diff --git a/meta/recipes-extended/cpio/cpio-2.13/run-ptest b/meta/recipes-extended/cpio/cpio-2.13/run-ptest
> old mode 100644
> new mode 100755
> index f027574e86..f35a756d6b
> --- a/meta/recipes-extended/cpio/cpio-2.13/run-ptest
> +++ b/meta/recipes-extended/cpio/cpio-2.13/run-ptest
> @@ -1,10 +1,3 @@
> #!/bin/sh
>
> -# Define cpio test work dir
> -WORKDIR=@PTEST_PATH@/tests/
> -
> -# Run test
> -cd ${WORKDIR}
> -./atconfig ./atlocal ./testsuite
> -
> -./testsuite 2>&1 | grep -E '[0-9]{1,3}: ' | sed -e 's/^.....//' -e '/[ok]$/s/^/PASS: /;/FAILED (.*)/s/^/FAIL: /;/skipped (.*)/s/^/SKIP: /;/expected failure/ s/^/PASS: /;/UNEXPECTED PASS/s/^/FAIL: /' -e 's/ok$//g' -e 's/FAILED.*//g' -e 's/skipped.*//g' -e 's/expected failure.*//g' -e 's/UNEXPECTED PASS.*//g'
> +su -c ./test.sh ptest
> diff --git a/meta/recipes-extended/cpio/cpio-2.13/run-ptest b/meta/recipes-extended/cpio/cpio-2.13/test.sh
> similarity index 100%
> copy from meta/recipes-extended/cpio/cpio-2.13/run-ptest
> copy to meta/recipes-extended/cpio/cpio-2.13/test.sh
> diff --git a/meta/recipes-extended/cpio/cpio_2.13.bb b/meta/recipes-extended/cpio/cpio_2.13.bb
> index df5e09cae8..943fa9b3ab 100644
> --- a/meta/recipes-extended/cpio/cpio_2.13.bb
> +++ b/meta/recipes-extended/cpio/cpio_2.13.bb
> @@ -14,6 +14,7 @@ SRC_URI = "${GNU_MIRROR}/cpio/cpio-${PV}.tar.gz \
> file://0001-Use-__alignof__-with-clang.patch \
> file://0001-Wrong-CRC-with-ASCII-CRC-for-large-files.patch \
> file://run-ptest \
> + file://test.sh \
> "
>
> SRC_URI[md5sum] = "389c5452d667c23b5eceb206f5000810"
> @@ -57,9 +58,24 @@ do_install_ptest() {
> install --mode=755 ${B}/tests/atlocal ${D}${PTEST_PATH}/tests/
> install --mode=755 ${B}/tests/genfile ${D}${PTEST_PATH}/tests/
> install --mode=755 ${S}/tests/testsuite ${D}${PTEST_PATH}/tests/
> + install --mode=755 ${WORKDIR}/test.sh ${D}${PTEST_PATH}/test.sh
> sed -i "s#@PTEST_PATH@#${PTEST_PATH}#g" ${D}${PTEST_PATH}/run-ptest
> }
>
> +# ptest.bbclass currently chowns the ptest directory explicitly, so we need to
> +# change permission after that has happened so the ptest user can write a
> +# temporary directory.
> +do_install_ptest_base:append() {
> + chgrp -R ptest ${D}${PTEST_PATH}/
> + chmod -R g+w ${D}${PTEST_PATH}/
> +}
> +
> +# The tests need to run as a non-root user, so pull in the ptest user
> +DEPENDS:append:class-target = "${@bb.utils.contains('PTEST_ENABLED', '1', ' ptest-runner', '', d)}"
> +PACKAGE_WRITE_DEPS += "ptest-runner"
> +
> +RDEPENDS:${PN}-ptest += "ptest-runner"
> +
> PACKAGES =+ "${PN}-rmt"
>
> FILES:${PN}-rmt = "${sbindir}/rmt*"
This seems to break the ptests as it stops returning results:
https://autobuilder.yoctoproject.org/typhoon/#/builders/81/builds/5010
Cheers,
Richard
next prev parent reply other threads:[~2023-05-04 21:16 UTC|newest]
Thread overview: 3+ messages / expand[flat|nested] mbox.gz Atom feed top
2023-04-29 1:29 [PATCH] cpio: Run ptests under ptest user Khem Raj
2023-05-04 21:16 ` Richard Purdie [this message]
2023-05-04 23:30 ` [OE-core] " Khem Raj
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=6a5ca0bf10350375f568163e3be93dfeed266d6f.camel@linuxfoundation.org \
--to=richard.purdie@linuxfoundation.org \
--cc=openembedded-core@lists.openembedded.org \
--cc=raj.khem@gmail.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox