From: "Michel Dänzer" <michel.daenzer@mailbox.org>
To: Maxime Ripard <mripard@kernel.org>
Cc: emma@anholt.net, linux-doc@vger.kernel.org,
vignesh.raman@collabora.com, dri-devel@lists.freedesktop.org,
alyssa@rosenzweig.io, jbrunet@baylibre.com, robdclark@google.com,
corbet@lwn.net, khilman@baylibre.com,
sergi.blanch.torne@collabora.com, david.heidelberg@collabora.com,
linux-rockchip@lists.infradead.org,
Daniel Stone <daniels@collabora.com>,
martin.blumenstingl@googlemail.com, robclark@freedesktop.org,
Helen Koike <helen.koike@collabora.com>,
anholt@google.com, linux-mediatek@lists.infradead.org,
matthias.bgg@gmail.com, linux-amlogic@lists.infradead.org,
gustavo.padovan@collabora.com,
linux-arm-kernel@lists.infradead.org,
angelogioacchino.delregno@collabora.com,
neil.armstrong@linaro.org, guilherme.gallo@collabora.com,
linux-kernel@vger.kernel.org, tzimmermann@suse.de
Subject: Re: [PATCH v11] drm: Add initial ci/ subdirectory
Date: Mon, 11 Sep 2023 15:30:55 +0200 [thread overview]
Message-ID: <550454b8-2e2c-c947-92c5-37f0367661c2@mailbox.org> (raw)
In-Reply-To: <5ejq3hjpoy3gxft2jbmoa5m656usetuxcs7g3ezyyiitj67rav@r5jhdz27foat>
On 9/11/23 14:51, Maxime Ripard wrote:
> On Mon, Sep 11, 2023 at 02:13:43PM +0200, Michel Dänzer wrote:
>> On 9/11/23 11:34, Maxime Ripard wrote:
>>> On Thu, Sep 07, 2023 at 01:40:02PM +0200, Daniel Stone wrote:
>>>>
>>>> Secondly, we will never be there. If we could pause for five years and sit
>>>> down making all the current usecases for all the current hardware on the
>>>> current kernel run perfectly, we'd probably get there. But we can't: there's
>>>> new hardware, new userspace, and hundreds of new kernel trees.
>>>
>>> [...]
>>>
>>> I'm not sure it's actually an argument, really. 10 years ago, we would
>>> never have been at "every GPU on the market has an open-source driver"
>>> here. 5 years ago, we would never have been at this-series-here. That
>>> didn't stop anyone making progress, everyone involved in that thread
>>> included.
>>
>> Even assuming perfection is achievable at all (which is very doubtful,
>> given the experience from the last few years of CI in Mesa and other
>> projects), if you demand perfection before even taking the first step,
>> it will never get off the ground.
>
> Perfection and scale from the get-go isn't reasonable, yes. Building a
> small, "perfect" (your words, not mine) system that you can later expand
> is doable.
I mean "perfect" as in every single available test runs, is reliable and gates CI. Which seems to be what you're asking for. The only possible expansion of such a system would be adding new 100% reliable tests.
What is being proposed here is an "imperfect" system which takes into account the reality that some tests are not 100% reliable, and can be improved gradually while already preventing some regressions from getting merged.
>>> How are we even supposed to detect those failures in the first
>>> place if tests are flagged as unreliable?
>>
>> Based on experience with Mesa, only a relatively small minority of
>> tests should need to be marked as flaky / not run at all. The majority
>> of tests are reliable and can catch regressions even while some tests
>> are not yet.
>
> I understand and acknowledge that it worked with Mesa. That's great for
> Mesa. That still doesn't mean that it's the panacea and is for every
> project.
Not sure what you're referring to by panacea, or how it relates to "some tests can be useful even while others aren't yet".
>>> No matter what we do here, what you describe will always happen. Like,
>>> if we do flag those tests as unreliable, what exactly prevents another
>>> issue to come on top undetected, and what will happen when we re-enable
>>> testing?
>>
>> Any issues affecting a test will need to be fixed before (re-)enabling
>> the test for CI.
>
> If that underlying issue is never fixed, at which point do we consider
> that it's a failure and should never be re-enabled? Who has that role?
Not sure what you're asking. Anybody can (re-)enable a test in CI, they just need to make sure first that it is reliable. Until somebody does that work, it'll stay disabled in CI.
>>> It might or might not be an issue for Linus' release, but I can
>>> definitely see the trouble already for stable releases where fixes will
>>> be backported, but the test state list certainly won't be updated.
>>
>> If the stable branch maintainers want to take advantage of CI for the
>> stable branches, they may need to hunt for corresponding state list
>> commits sometimes. They'll need to take that into account for their
>> decision.
>
> So we just expect the stable maintainers to track each and every patches
> involved in a test run, make sure that they are in a stable tree, and
> then update the test list? Without having consulted them at all?
I don't expect them to do anything. See the If at the start of what I wrote.
>>>> By keeping those sets of expectations, we've been able to keep Mesa pretty
>>>> clear of regressions, whilst having a very clear set of things that should
>>>> be fixed to point to. It would be great if those set of things were zero,
>>>> but it just isn't. Having that is far better than the two alternatives:
>>>> either not testing at all (obviously bad), or having the test always be red
>>>> so it's always ignored (might as well just not test).
>>>
>>> Isn't that what happens with flaky tests anyway?
>>
>> For a small minority of tests. Daniel was referring to whole test suites.
>>
>>> Even more so since we have 0 context when updating that list.
>>
>> The commit log can provide whatever context is needed.
>
> Sure, I've yet to see that though.
>
> There's in 6.6-rc1 around 240 reported flaky tests. None of them have
> any context. That new series hads a few dozens too, without any context
> either. And there's no mention about that being a plan, or a patch
> adding a new policy for all tests going forward.
That does sound bad, would need to be raised in review.
> Any concern I raised were met with a giant "it worked on Mesa" handwave
Lessons learned from years of experience with big real-world CI systems like this are hardly "handwaving".
--
Earthling Michel Dänzer | https://redhat.com
Libre software enthusiast | Mesa and Xwayland developer
_______________________________________________
Linux-rockchip mailing list
Linux-rockchip@lists.infradead.org
http://lists.infradead.org/mailman/listinfo/linux-rockchip
next prev parent reply other threads:[~2023-09-11 13:31 UTC|newest]
Thread overview: 23+ messages / expand[flat|nested] mbox.gz Atom feed top
2023-08-11 17:19 [PATCH v11] drm: Add initial ci/ subdirectory Helen Koike
2023-08-22 14:26 ` Daniel Vetter
2023-08-30 9:53 ` Maxime Ripard
2023-08-30 10:58 ` Jani Nikula
2023-08-30 11:37 ` Maxime Ripard
2023-08-30 13:24 ` Helen Koike
2023-08-30 14:44 ` Rob Clark
2023-08-30 14:57 ` Maxime Ripard
2023-08-30 15:14 ` Helen Koike
2023-09-04 7:54 ` Daniel Vetter
2023-09-07 11:40 ` Daniel Stone
2023-09-11 9:34 ` Maxime Ripard
2023-09-11 12:13 ` Michel Dänzer
2023-09-11 12:51 ` Maxime Ripard
2023-09-11 13:30 ` Michel Dänzer [this message]
2023-09-11 14:46 ` Maxime Ripard
2023-09-12 13:16 ` Daniel Stone
2023-09-14 9:54 ` Maxime Ripard
2023-09-14 22:39 ` Rob Clark
2023-09-15 15:08 ` Daniel Stone
2023-09-18 21:35 ` Helen Koike
2023-09-19 9:53 ` Maxime Ripard
2023-09-19 9:48 ` Maxime Ripard
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=550454b8-2e2c-c947-92c5-37f0367661c2@mailbox.org \
--to=michel.daenzer@mailbox.org \
--cc=alyssa@rosenzweig.io \
--cc=angelogioacchino.delregno@collabora.com \
--cc=anholt@google.com \
--cc=corbet@lwn.net \
--cc=daniels@collabora.com \
--cc=david.heidelberg@collabora.com \
--cc=dri-devel@lists.freedesktop.org \
--cc=emma@anholt.net \
--cc=guilherme.gallo@collabora.com \
--cc=gustavo.padovan@collabora.com \
--cc=helen.koike@collabora.com \
--cc=jbrunet@baylibre.com \
--cc=khilman@baylibre.com \
--cc=linux-amlogic@lists.infradead.org \
--cc=linux-arm-kernel@lists.infradead.org \
--cc=linux-doc@vger.kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-mediatek@lists.infradead.org \
--cc=linux-rockchip@lists.infradead.org \
--cc=martin.blumenstingl@googlemail.com \
--cc=matthias.bgg@gmail.com \
--cc=mripard@kernel.org \
--cc=neil.armstrong@linaro.org \
--cc=robclark@freedesktop.org \
--cc=robdclark@google.com \
--cc=sergi.blanch.torne@collabora.com \
--cc=tzimmermann@suse.de \
--cc=vignesh.raman@collabora.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