On Tue, Nov 2, 2021 at 11:55 AM Peter Kjellerstedt <peter.kjellerst...@axis.com> wrote: > > > -----Original Message----- > > From: Khem Raj <raj.k...@gmail.com> > > Sent: den 1 november 2021 02:00 > > To: Richard Purdie <richard.pur...@linuxfoundation.org> > > Cc: Peter Kjellerstedt <peter.kjellerst...@axis.com>; Patches and > > discussions about the oe-core layer <openembedded- > > c...@lists.openembedded.org> > > Subject: Re: [OE-core] [PATCHv3 3/3] insane.bbclass: Add a check for > > directories that are expected to be empty > > > > On Sun, Oct 31, 2021 at 8:54 AM Richard Purdie > > <richard.pur...@linuxfoundation.org> wrote: > > > > > > On Fri, 2021-10-29 at 23:29 +0200, Peter Kjellerstedt wrote: > > > > The empty-dirs QA check verifies that all directories specified in > > > > QA_EMPTY_DIRS are empty. It is possible to specify why a directory is > > > > expected to be empty by defining QA_EMPTY_DIRS_RECOMMENDATION:<path>, > > > > which will then be included in the error message if the directory is > > > > not empty. If it is not specified for a directory, then "but it is > > > > expected to be empty" will be used. > > > > > > > > Signed-off-by: Peter Kjellerstedt <peter.kjellerst...@axis.com> > > > > --- > > > > > > > > PATCHv2: No changes. > > > > PATCHv3: No changes. > > > > > > > > meta/classes/insane.bbclass | 33 ++++++++++++++++++++++++++++++++- > > > > meta/conf/documentation.conf | 2 ++ > > > > 2 files changed, 34 insertions(+), 1 deletion(-) > > > > > > > > diff --git a/meta/classes/insane.bbclass b/meta/classes/insane.bbclass > > > > index 1e2f1b768a..1675adf6ac 100644 > > > > --- a/meta/classes/insane.bbclass > > > > +++ b/meta/classes/insane.bbclass > > > > @@ -37,7 +37,7 @@ ERROR_QA ?= "dev-so debug-deps dev-deps debug-files > > > > arch pkgconfig la \ > > > > configure-gettext perllocalpod shebang-size \ > > > > already-stripped installed-vs-shipped ldflags > > > > compile-host-path \ > > > > install-host-path pn-overrides unknown-configure-option \ > > > > - useless-rpaths rpaths staticdev \ > > > > + useless-rpaths rpaths staticdev empty-dirs \ > > > > " > > > > # Add usrmerge QA check based on distro feature > > > > ERROR_QA:append = "${@bb.utils.contains('DISTRO_FEATURES', 'usrmerge', > > > > ' usrmerge', '', d)}" > > > > @@ -50,6 +50,21 @@ ALL_QA = "${WARN_QA} ${ERROR_QA}" > > > > > > > > UNKNOWN_CONFIGURE_WHITELIST ?= "--enable-nls --disable-nls > > > > --disable-silent-rules --disable-dependency-tracking > > > > --with-libtool-sysroot --disable-static" > > > > > > > > +# This is a list of directories that are expected to be empty. > > > > +QA_EMPTY_DIRS ?= " \ > > > > + /dev/pts \ > > > > + /media \ > > > > + /proc \ > > > > + /run \ > > > > + /tmp \ > > > > + ${localstatedir}/run \ > > > > + ${localstatedir}/volatile \ > > > > +" > > > > +# It is possible to specify why a directory is expected to be empty by > > > > defining > > > > +# QA_EMPTY_DIRS_RECOMMENDATION:<path>, which will then be included in > > > > the error > > > > +# message if the directory is not empty. If it is not specified for a > > > > directory, > > > > +# then "but it is expected to be empty" will be used. > > > > + > > > > def package_qa_clean_path(path, d, pkg=None): > > > > """ > > > > Remove redundant paths from the path for display. If pkg isn't > > > > set then > > > > @@ -885,6 +900,22 @@ def package_qa_check_unlisted_pkg_lics(package, d, > > > > messages): > > > > "listed in LICENSE" % (package, ' > > > > '.join(unlisted))) > > > > return False > > > > > > > > +QAPKGTEST[empty-dirs] = "package_qa_check_empty_dirs" > > > > +def package_qa_check_empty_dirs(pkg, d, messages): > > > > + """ > > > > + Check for the existence of files in directories that are expected > > > > to be > > > > + empty. > > > > + """ > > > > + > > > > + pkgd = oe.path.join(d.getVar('PKGDEST'), pkg) > > > > + for dir in (d.getVar('QA_EMPTY_DIRS') or "").split(): > > > > + empty_dir = oe.path.join(pkgd, dir) > > > > + if os.path.exists(empty_dir) and os.listdir(empty_dir): > > > > + recommendation = (d.getVar('QA_EMPTY_DIRS_RECOMMENDATION:' > > > > + dir) or > > > > + "but it is expected to be empty") > > > > + msg = "%s installs files in %s, %s" % (pkg, dir, > > > > recommendation) > > > > + oe.qa.add_message(messages, "empty-dirs", msg) > > > > + > > > > def package_qa_check_encoding(keys, encode, d): > > > > def check_encoding(key, enc): > > > > sane = True > > > > diff --git a/meta/conf/documentation.conf b/meta/conf/documentation.conf > > > > index 80ad8e10d5..45cd01374a 100644 > > > > --- a/meta/conf/documentation.conf > > > > +++ b/meta/conf/documentation.conf > > > > @@ -345,6 +345,8 @@ PYPI_SRC_URI[doc] = "The URI to use to fetch from > > > > pypi, default uses pythonhoste > > > > > > > > #Q > > > > > > > > +QA_EMPTY_DIRS[doc] = "A list of directories that are expected to be > > > > empty." > > > > +QA_EMPTY_DIRS_RECOMMENDATION[doc] = "This specifies a recommendation > > > > for a directory why it must be empty, which will be included in the > > > > error message if the directory is not empty." > > > > QMAKE_PROFILES[doc] = "Specifies your own subset of .pro files to be > > > > built for use with qmake." > > > > > > > > > > This triggered: > > > > > > ERROR: apt-2.2.4-r0 do_package_qa: QA Issue: apt installs files in > > > /var/volatile, but it is expected to be empty [empty-dirs] > > > ERROR: apt-2.2.4-r0 do_package_qa: Fatal QA errors were found, failing > > > task. > > > > > > https://autobuilder.yoctoproject.org/typhoon/#/builders/119/builds/915/steps/12/logs/stdio > > > > > > > meta-openembedded layers report a few too see > > https://autobuilder.yoctoproject.org/typhoon/#/builders/88/builds/1675 > > I have sent a patch series to openembedded-devel now that should cover > these.
FWIW there are few more failures found https://errors.yoctoproject.org/Errors/Build/135082/ I am looking at iptraf-ng and monkey > > > > > > > Cheers, > > > > > > Richard > > //Peter >
-=-=-=-=-=-=-=-=-=-=-=- Links: You receive all messages sent to this group. View/Reply Online (#157836): https://lists.openembedded.org/g/openembedded-core/message/157836 Mute This Topic: https://lists.openembedded.org/mt/86687486/21656 Group Owner: openembedded-core+ow...@lists.openembedded.org Unsubscribe: https://lists.openembedded.org/g/openembedded-core/unsub [arch...@mail-archive.com] -=-=-=-=-=-=-=-=-=-=-=-