All of lore.kernel.org
 help / color / mirror / Atom feed
From: "Daniel P. Berrangé" <berrange@redhat.com>
To: Thomas Huth <thuth@redhat.com>
Cc: qemu-devel@nongnu.org,
	"Philippe Mathieu-Daudé" <philmd@linaro.org>,
	"Alex Bennée" <alex.bennee@linaro.org>,
	"Thomas Huth" <huth@tuxfamily.org>
Subject: Re: [PATCH v2 30/31] tests/functional: skip tests if assets are not available
Date: Thu, 12 Dec 2024 15:02:33 +0000	[thread overview]
Message-ID: <Z1r7CeI7TuHQXvAI@redhat.com> (raw)
In-Reply-To: <0185be25-32f7-436b-b8e6-2e55c1cd0e18@redhat.com>

On Thu, Dec 12, 2024 at 03:14:53PM +0100, Thomas Huth wrote:
> On 11/12/2024 18.26, Daniel P. Berrangé wrote:
> > If downloading of assets has been disabled, then skip running a
> > test if the assets it has registered are not already downloaded.
> > 
> > Signed-off-by: Daniel P. Berrangé <berrange@redhat.com>
> > ---
> >   tests/functional/qemu_test/asset.py    |  8 +++++++-
> >   tests/functional/qemu_test/testcase.py | 11 +++++++++++
> >   2 files changed, 18 insertions(+), 1 deletion(-)
> > 
> > diff --git a/tests/functional/qemu_test/asset.py b/tests/functional/qemu_test/asset.py
> > index c5d3e73c4b..39832b2587 100644
> > --- a/tests/functional/qemu_test/asset.py
> > +++ b/tests/functional/qemu_test/asset.py
> > @@ -65,6 +65,12 @@ def _check(self, cache_file):
> >       def valid(self):
> >           return self.cache_file.exists() and self._check(self.cache_file)
> > +    def fetchable(self):
> > +        return not os.environ.get("QEMU_TEST_NO_DOWNLOAD", False)
> > +
> > +    def available(self):
> > +        return self.valid() or self.fetchable()
> > +
> >       def _wait_for_other_download(self, tmp_cache_file):
> >           # Another thread already seems to download the asset, so wait until
> >           # it is done, while also checking the size to see whether it is stuck
> > @@ -103,7 +109,7 @@ def fetch(self):
> >                              self.cache_file, self.url)
> >               return str(self.cache_file)
> > -        if os.environ.get("QEMU_TEST_NO_DOWNLOAD", False):
> > +        if not self.fetchable():
> >               raise Exception("Asset cache is invalid and downloads disabled")
> >           self.log.info("Downloading %s to %s...", self.url, self.cache_file)
> > diff --git a/tests/functional/qemu_test/testcase.py b/tests/functional/qemu_test/testcase.py
> > index 7bece8738a..6c67a9459c 100644
> > --- a/tests/functional/qemu_test/testcase.py
> > +++ b/tests/functional/qemu_test/testcase.py
> > @@ -184,6 +184,14 @@ def scratch_file(self, *args):
> >       def log_file(self, *args):
> >           return str(Path(self.outputdir, *args))
> > +    def assets_available(self):
> > +        for name, asset in vars(self.__class__).items():
> > +            if name.startswith("ASSET_") and type(asset) == Asset:
> > +                if not asset.available():
> > +                    self.log.debug(f"Asset {asset.url} not available")
> > +                    return False
> > +        return True
> > +
> >       def setUp(self, bin_prefix):
> >           self.assertIsNotNone(self.qemu_bin, 'QEMU_TEST_QEMU_BINARY must be set')
> >           self.arch = self.qemu_bin.split('-')[-1]
> > @@ -209,6 +217,9 @@ def setUp(self, bin_prefix):
> >           self.machinelog.setLevel(logging.DEBUG)
> >           self.machinelog.addHandler(self._log_fh)
> > +        if not self.assets_available():
> > +            self.skipTest('One or more assets is not available')
> 
> So if a test_*.py file consists of multiple subtests, this will now skip all
> of them if just the asset of one subtest is missing?

Yep, I kept it simple. Often multiple assets all come from the same
server (eg kernel + initrd), and the same assets are used across
multiple tests.

> Could we maybe handle this test skipping in the new archive_extract() and
> uncompress() functions instead, so that only the related subtests will be
> skipped? (We still might need another wrapper function in testcase for the
> spots that still call .fetch() on the assets directly, though)

I'm not sure its worth the effort to ensure we don't leave gaves in places
that need skipping.

We still intend that this skipping scenario is highly undesirable at all,
and want to try to ensure it never actually triggers. ie we want cache
working in GitLab CI, so that we almost never need to download anything.

Most likely place to see skips is for developers locally if they're
runing tests for the first time, or haven't done it for a long while.

With regards,
Daniel
-- 
|: https://berrange.com      -o-    https://www.flickr.com/photos/dberrange :|
|: https://libvirt.org         -o-            https://fstop138.berrange.com :|
|: https://entangle-photo.org    -o-    https://www.instagram.com/dberrange :|



  reply	other threads:[~2024-12-12 15:04 UTC|newest]

Thread overview: 64+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2024-12-11 17:26 [PATCH v2 00/31] tests/functional: various improvements wrt assets/scratch files Daniel P. Berrangé
2024-12-11 17:26 ` [PATCH v2 01/31] tests/functional: remove many unused imports Daniel P. Berrangé
2024-12-11 19:31   ` Thomas Huth
2024-12-12  9:12     ` Daniel P. Berrangé
2024-12-11 17:26 ` [PATCH v2 02/31] tests/functional: resolve str(Asset) to cache file path Daniel P. Berrangé
2024-12-11 17:26 ` [PATCH v2 03/31] tests/functional: remove duplicated 'which' function impl Daniel P. Berrangé
2024-12-11 17:26 ` [PATCH v2 04/31] tests/functional: simplify 'which' implementation Daniel P. Berrangé
2024-12-11 19:32   ` Thomas Huth
2024-12-11 20:50   ` Richard Henderson
2024-12-11 17:26 ` [PATCH v2 05/31] tests/functional: drop 'tesseract_available' helper Daniel P. Berrangé
2024-12-12  6:57   ` Thomas Huth
2024-12-12  9:35     ` Daniel P. Berrangé
2024-12-11 17:26 ` [PATCH v2 06/31] tests/functional: introduce some helpful decorators Daniel P. Berrangé
2024-12-12  7:01   ` Thomas Huth
2024-12-11 17:26 ` [PATCH v2 07/31] tests/functional: switch to new test skip decorators Daniel P. Berrangé
2024-12-11 17:26 ` [PATCH v2 08/31] tests/functional: drop 'has_cmd' and 'has_cmds' helpers Daniel P. Berrangé
2024-12-12  7:12   ` Thomas Huth
2024-12-11 17:26 ` [PATCH v2 09/31] tests/functional: add helpers for building file paths Daniel P. Berrangé
2024-12-12  9:01   ` Thomas Huth
2024-12-11 17:26 ` [PATCH v2 10/31] tests/functional: switch over to using self.log_file(...) Daniel P. Berrangé
2024-12-11 17:26 ` [PATCH v2 11/31] tests/functional: switch over to using self.build_file(...) Daniel P. Berrangé
2024-12-12  9:42   ` Thomas Huth
2024-12-12  9:52     ` Daniel P. Berrangé
2024-12-11 17:26 ` [PATCH v2 12/31] tests/functional: switch over to using self.data_file(...) Daniel P. Berrangé
2024-12-11 17:26 ` [PATCH v2 13/31] tests/functional: switch over to using self.scratch_file() Daniel P. Berrangé
2024-12-12  9:33   ` Thomas Huth
2024-12-11 17:26 ` [PATCH v2 14/31] tests/functional: switch over to using self.socket_dir(...) Daniel P. Berrangé
2024-12-12  9:36   ` Thomas Huth
2024-12-11 17:26 ` [PATCH v2 15/31] tests/functional: remove redundant 'rmtree' call Daniel P. Berrangé
2024-12-11 17:26 ` [PATCH v2 16/31] tests/functional: move archive handling into new archive.py file Daniel P. Berrangé
2024-12-12  9:38   ` Thomas Huth
2024-12-11 17:26 ` [PATCH v2 17/31] tests/functional: move uncompress handling into new uncompress.py file Daniel P. Berrangé
2024-12-12  9:43   ` Thomas Huth
2024-12-11 17:26 ` [PATCH v2 18/31] tests/functional: add common zip_extract helper Daniel P. Berrangé
2024-12-12  9:49   ` Thomas Huth
2024-12-11 17:26 ` [PATCH v2 19/31] tests/functional: add common deb_extract helper Daniel P. Berrangé
2024-12-12  9:54   ` Thomas Huth
2024-12-11 17:26 ` [PATCH v2 20/31] tests/functional: let cpio_extract accept filenames Daniel P. Berrangé
2024-12-12  9:57   ` Thomas Huth
2024-12-11 17:26 ` [PATCH v2 21/31] tests/functional: add a generalized archive_extract Daniel P. Berrangé
2024-12-12 10:19   ` Thomas Huth
2024-12-11 17:26 ` [PATCH v2 22/31] tests/functional: add 'archive_extract' to QemuBaseTest Daniel P. Berrangé
2024-12-12 10:22   ` Thomas Huth
2024-12-11 17:26 ` [PATCH v2 23/31] tests/functional: convert tests to new archive_extract helper Daniel P. Berrangé
2024-12-12 10:34   ` Thomas Huth
2024-12-12 10:44     ` Daniel P. Berrangé
2024-12-11 17:26 ` [PATCH v2 24/31] tests/functional: add a generalized uncompress helper Daniel P. Berrangé
2024-12-12 10:36   ` Thomas Huth
2024-12-11 17:26 ` [PATCH v2 25/31] tests/functional: add 'uncompress' to QemuBaseTest Daniel P. Berrangé
2024-12-12 10:43   ` Thomas Huth
2024-12-11 17:26 ` [PATCH v2 26/31] tests/functional: convert tests to new uncompress helper Daniel P. Berrangé
2024-12-12 11:03   ` Thomas Huth
2024-12-11 17:26 ` [PATCH v2 27/31] tests/functional: drop back compat imports from utils.py Daniel P. Berrangé
2024-12-12 11:04   ` Thomas Huth
2024-12-11 17:26 ` [PATCH v2 28/31] tests/functional: replace 'run_cmd' with subprocess helpers Daniel P. Berrangé
2024-12-12 11:11   ` Thomas Huth
2024-12-11 17:26 ` [PATCH v2 29/31] tests/functional: remove now unused 'run_cmd' helper Daniel P. Berrangé
2024-12-12 11:12   ` Thomas Huth
2024-12-11 17:26 ` [PATCH v2 30/31] tests/functional: skip tests if assets are not available Daniel P. Berrangé
2024-12-12 14:14   ` Thomas Huth
2024-12-12 15:02     ` Daniel P. Berrangé [this message]
2024-12-13  9:10       ` Thomas Huth
2024-12-11 17:26 ` [PATCH v2 31/31] tests/functional: ignore errors when caching assets, except for 404 Daniel P. Berrangé
2024-12-13  9:13   ` Thomas Huth

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=Z1r7CeI7TuHQXvAI@redhat.com \
    --to=berrange@redhat.com \
    --cc=alex.bennee@linaro.org \
    --cc=huth@tuxfamily.org \
    --cc=philmd@linaro.org \
    --cc=qemu-devel@nongnu.org \
    --cc=thuth@redhat.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 an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.