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]
-=-=-=-=-=-=-=-=-=-=-=-

Reply via email to