2019-01-28 20:51:12 +03:00
|
|
|
# ANGLE Wrangling
|
|
|
|
|
|
|
|
As an ANGLE Sheriff. Your job is to:
|
|
|
|
|
2020-04-20 23:20:12 +03:00
|
|
|
1. Keep the [ANGLE Try Waterfall](https://ci.chromium.org/p/chromium/g/tryserver.chromium.angle/builders) in good
|
2019-04-08 22:50:30 +03:00
|
|
|
working order.
|
2022-02-28 18:57:03 +03:00
|
|
|
1. Control and monitor the [ANGLE auto-rollers](#the-auto-rollers).
|
2019-01-28 20:51:12 +03:00
|
|
|
1. Keep the [ANGLE Standalone Testers](README.md) in good working order.
|
2020-04-01 06:59:18 +03:00
|
|
|
1. Keep the [SwANGLE Try Waterfall](https://luci-milo.appspot.com/p/chromium/g/tryserver.chromium.swangle/builders) in good
|
|
|
|
working order.
|
2020-10-02 23:56:52 +03:00
|
|
|
1. Monitor and respond to ANGLE's [Perf alerts](https://groups.google.com/u/0/a/chromium.org/g/angle-perf-alerts)
|
2019-01-28 20:51:12 +03:00
|
|
|
|
2019-04-08 22:50:30 +03:00
|
|
|
If you're not an ANGLE team member, you can contact us on the public ANGLE project
|
|
|
|
[Google group](https://groups.google.com/forum/#!forum/angleproject).
|
2019-01-28 20:51:12 +03:00
|
|
|
|
2021-12-06 21:04:14 +03:00
|
|
|
**Note**: Please review and if needed update the [wrangler schedule].
|
|
|
|
|
2020-03-16 21:11:33 +03:00
|
|
|
**Note**: It's highly recommend that all wranglers install the [Chromium Flake Linker][Flaker]
|
|
|
|
extension for inspecting bot builds. It'll save you a lot of time.
|
|
|
|
|
2021-09-29 00:07:20 +03:00
|
|
|
**Note**: If you need to suppress test failures (e.g. to keep an auto-roller unblocked), see
|
2021-10-02 01:42:29 +03:00
|
|
|
[Handling Test Failures](../doc/TestingAndProcesses.md).
|
2021-09-29 00:07:20 +03:00
|
|
|
|
2020-03-16 21:11:33 +03:00
|
|
|
[Flaker]: https://chrome.google.com/webstore/detail/flake-linker/boamnmbgmfnobomddmenbaicodgglkhc
|
|
|
|
|
2021-12-06 21:04:14 +03:00
|
|
|
[wrangler schedule]: https://rotations.corp.google.com/rotation/5080504293392384
|
|
|
|
|
2020-03-16 23:46:18 +03:00
|
|
|
## Task 1: Monitor ANGLE CI and Try Testers
|
2019-01-28 20:51:12 +03:00
|
|
|
|
2022-02-15 18:50:27 +03:00
|
|
|
Your first job is to keep the ANGLE builders green and unblocked.
|
2019-01-28 20:51:12 +03:00
|
|
|
|
2022-02-15 18:50:27 +03:00
|
|
|
There are two consoles for ANGLE continuous integration builders:
|
2021-03-22 21:29:34 +03:00
|
|
|
|
2022-02-15 18:50:27 +03:00
|
|
|
1. Standalone ANGLE: https://ci.chromium.org/p/angle/g/ci/console
|
|
|
|
1. Chromium + ANGLE integration: https://ci.chromium.org/p/chromium/g/chromium.angle/console
|
2021-03-22 21:29:34 +03:00
|
|
|
|
2022-02-15 18:50:27 +03:00
|
|
|
We expect these waterfalls to be perfectly green at all times. As of writing
|
|
|
|
several builders are red or flaky. Oart of your job as wrangler is to
|
|
|
|
eliminate all sources of breaks and flakiness. We can fix flakiness by
|
|
|
|
suppressing tests that are not worth fixing, reverting problematic CLs, or
|
|
|
|
finding other solutions.
|
2019-01-28 20:51:12 +03:00
|
|
|
|
2022-02-15 18:50:27 +03:00
|
|
|
When you encouter red builds or flakiness, please [file an ANGLE bug]
|
|
|
|
(http://anglebug.com/new) and set the label: `Hotlist-Wrangler`.
|
2019-01-28 20:51:12 +03:00
|
|
|
|
2022-02-15 18:50:27 +03:00
|
|
|
[Click here to see a ANGLE wrangler bug hot list.][WranglerBugs]
|
|
|
|
|
|
|
|
In addition to the CI builders, we have a console for try jobs on the ANGLE CV (change verifier):
|
|
|
|
|
|
|
|
* https://ci.chromium.org/ui/p/angle/g/try/builders
|
2019-01-28 20:51:12 +03:00
|
|
|
|
2022-02-15 18:50:27 +03:00
|
|
|
Some failures are expected on this waterfall as developers test WIP changes.
|
|
|
|
Please watch for persistent sources of flakiness and failure and take action
|
|
|
|
as appropriate by filing bugs, reverting CLs, or taking other action.
|
2019-01-28 20:51:12 +03:00
|
|
|
|
2022-02-15 18:50:27 +03:00
|
|
|
[WranglerBugs]:https://bugs.chromium.org/p/angleproject/issues/list?q=Hotlist%3DWrangler&can=2
|
|
|
|
|
|
|
|
If you find a point of failure that is unrelated to ANGLE, please [file a
|
|
|
|
Chromium bug](http://crbug.com/new). Set the bug label
|
|
|
|
`Hotlist-PixelWrangler`. Ensure you cc the current ANGLE and Chrome GPU
|
|
|
|
wranglers, which you can find by consulting
|
|
|
|
[build.chromium.org](https://ci.chromium.org/p/chromium/g/main/console).
|
|
|
|
For more information see [Filing Chromium Bug Reports](#filing-chromium-bug-reports) below.
|
2019-01-28 20:51:12 +03:00
|
|
|
|
2022-02-15 18:50:27 +03:00
|
|
|
Also follow [Chromium bugs in the `Internals>GPU>ANGLE` component][ChromiumANGLEBugs]
|
|
|
|
to be alerted to reports of ANGLE-related breakage in Chrome.
|
2021-06-16 22:03:20 +03:00
|
|
|
|
|
|
|
[ChromiumANGLEBugs]:https://bugs.chromium.org/p/chromium/issues/list?q=component%3AInternals%3EGPU%3EANGLE&can=2
|
|
|
|
|
2022-02-15 18:50:27 +03:00
|
|
|
**NOTE: When all builds seem to be purple or otherwise broken:**
|
|
|
|
|
|
|
|
This could be a major infrastructure outage. File a high-priority bug using
|
|
|
|
[g.co/bugatrooper](http://g.co/bugatrooper).
|
2019-01-28 20:51:12 +03:00
|
|
|
|
2021-06-16 22:03:20 +03:00
|
|
|
### Filing Chromium Bug Reports
|
|
|
|
|
2022-02-15 18:50:27 +03:00
|
|
|
The GPU Pixel Wrangler is responsible for *Chromium* bugs. Please file
|
|
|
|
Chromium issues with the Label `Hotlist-PixelWrangler` for bugs outside of
|
|
|
|
the ANGLE project.
|
2019-01-28 20:51:12 +03:00
|
|
|
|
2021-06-16 22:03:20 +03:00
|
|
|
*IMPORTANT* info to include in Chromium bug reports:
|
2019-01-28 20:51:12 +03:00
|
|
|
|
2021-06-16 22:03:20 +03:00
|
|
|
* Links to all first failing builds (e.g. first windows failure, first mac failure, etc).
|
2019-01-28 20:51:12 +03:00
|
|
|
* Related regression ranges. See below on how to determine the ANGLE regression range.
|
|
|
|
* Relevant error messages.
|
2021-06-16 22:03:20 +03:00
|
|
|
* Set the **Components** to one or more value, such as (start typing "Internals" and you'll see choices):
|
|
|
|
* `Internals>GPU` for general GPU bugs
|
|
|
|
* `Internals>GPU>Testing` for failures that look infrastructure-related
|
|
|
|
* `Internals>GPU>ANGLE` for ANGLE-related Chromium bugs
|
|
|
|
* `Internals>Skia` for Skia-specific bugs
|
|
|
|
* Cc relevant sheriffs or blame suspects, as well as yourself or the current ANGLE Wrangler.
|
|
|
|
* Set the `Hotlist-PixelWrangler` Label.
|
2019-01-28 20:51:12 +03:00
|
|
|
|
2022-02-15 18:50:27 +03:00
|
|
|
### How to determine the ANGLE regression range on Chromium bots:
|
2019-01-28 20:51:12 +03:00
|
|
|
|
|
|
|
1. Open the first failing and last passing builds.
|
|
|
|
1. For test failures: record `parent_got_angle_revision` in both builds.
|
|
|
|
1. For compile failures record `got_angle_revision`.
|
2022-02-15 18:50:27 +03:00
|
|
|
1. Create a regression link with this URL template:
|
2019-04-10 17:28:41 +03:00
|
|
|
`https://chromium.googlesource.com/angle/angle.git/+log/<last passing revision>..<first failing revision>`
|
2019-01-28 20:51:12 +03:00
|
|
|
|
2021-08-27 07:54:54 +03:00
|
|
|
## <a name="the-auto-rollers"></a>Task 3: The Auto-Rollers
|
2019-01-28 20:51:12 +03:00
|
|
|
|
2019-04-08 22:50:30 +03:00
|
|
|
The [ANGLE auto-roller](https://autoroll.skia.org/r/angle-chromium-autoroll) automatically updates
|
|
|
|
Chrome with the latest ANGLE changes.
|
2019-01-28 20:51:12 +03:00
|
|
|
|
2019-04-10 17:28:41 +03:00
|
|
|
1. **Roller health**: You will be cc'ed on all rolls. Please check failed rolls to verify there is no blocking
|
2019-04-08 22:50:30 +03:00
|
|
|
breakage.
|
2019-04-10 17:28:41 +03:00
|
|
|
1. **Chrome Branching**: You are responsible for pausing the roller 24h before branch days, and resuming afterwards.
|
2019-04-08 22:50:30 +03:00
|
|
|
See the [Chrome Release Schedule](https://chromiumdash.appspot.com/schedule).
|
2019-01-28 20:51:12 +03:00
|
|
|
|
2021-08-27 07:54:54 +03:00
|
|
|
We also use additional auto-rollers to roll third party libraries, and Chromium, into ANGLE once per day:
|
2019-04-10 17:28:41 +03:00
|
|
|
|
2019-10-25 18:27:00 +03:00
|
|
|
* [SwiftShader into ANGLE](https://autoroll.skia.org/r/swiftshader-angle-autoroll)
|
2021-01-06 22:33:26 +03:00
|
|
|
* [vulkan-deps into ANGLE](https://autoroll.skia.org/r/vulkan-deps-angle-autoroll)
|
2020-12-09 21:29:55 +03:00
|
|
|
* [VK-GL-CTS into ANGLE](https://autoroll.skia.org/r/vk-gl-cts-angle-autoroll?tab=status)
|
2021-08-27 07:54:54 +03:00
|
|
|
* [Chromium into ANGLE](https://autoroll.skia.org/r/chromium-angle-autoroll)
|
2019-04-10 17:28:41 +03:00
|
|
|
|
2020-04-15 01:44:32 +03:00
|
|
|
Please ensure these rollers are also healthy and unblocked. You can trigger manual rolls using the
|
2021-08-27 07:54:54 +03:00
|
|
|
dashboards to land high-priority changes, for example Chromium-side test expectation updates or
|
|
|
|
suppressions. When a roll fails, stop the roller, determine if the root cause is a problem with
|
|
|
|
ANGLE or with the upstream repo, and file an issue with an appropriate next step.
|
2020-04-10 01:20:30 +03:00
|
|
|
|
2019-12-03 19:34:38 +03:00
|
|
|
The autoroller configurations live in the [skia/buildbot repository](https://skia.googlesource.com/buildbot/)
|
2021-06-16 22:03:20 +03:00
|
|
|
in the [autoroll/config](https://skia.googlesource.com/buildbot/+/main/autoroll/config) folder.
|
2019-12-03 19:34:38 +03:00
|
|
|
|
2021-01-06 22:33:26 +03:00
|
|
|
**NOTE: vulkan-deps consists of several related Vulkan dependencies:**
|
|
|
|
|
|
|
|
vulkan-deps houses Vulkan-Tools, Vulkan-Loader, Vulkan-ValidationLayers, Vulkan-Headers and other
|
|
|
|
related repos. If the roll fails, you will have to determine the correct upstream repo and file
|
|
|
|
an issue upstream. For more info on vulkan-deps see the
|
2021-06-16 22:03:20 +03:00
|
|
|
[README](https://chromium.googlesource.com/vulkan-deps/+/refs/heads/main/README.md).
|
2021-01-06 22:33:26 +03:00
|
|
|
|
2021-09-29 00:07:20 +03:00
|
|
|
Occasionally, a vulkan-deps AutoRoll CL will get an error in the `presubmit` bot. For example,
|
|
|
|
see: https://chromium-review.googlesource.com/c/angle/angle/+/3198390 where the
|
|
|
|
`export_targets.py` script had trouble with the `loader_windows.h` file. The `export_targets.py`
|
|
|
|
script sometimes has difficulty with headers. If you cannot see an obvious problem, create a CL
|
|
|
|
that adds the header to `IGNORED_INCLUDES` in `export_targets.py`.
|
|
|
|
|
2019-01-28 20:51:12 +03:00
|
|
|
## Task 4: ANGLE Standalone Testing
|
|
|
|
|
|
|
|
See more detailed instructions on by following [this link](README.md).
|
2020-04-01 06:59:18 +03:00
|
|
|
|
|
|
|
## Task 5: Monitor SwANGLE CI and Try Testers
|
|
|
|
|
2022-02-15 18:50:27 +03:00
|
|
|
The most important task here is to keep the 2 SwANGLE bots on the ANGLE CV healthy:
|
2020-04-01 06:59:18 +03:00
|
|
|
[linux-swangle-try-tot-angle-x64](https://luci-milo.appspot.com/p/chromium/builders/try/linux-swangle-try-tot-angle-x64)
|
|
|
|
and
|
|
|
|
[win-swangle-try-tot-angle-x86](https://luci-milo.appspot.com/p/chromium/builders/try/win-swangle-try-tot-angle-x86).
|
2022-02-15 18:50:27 +03:00
|
|
|
As well as the 2 SwANGLE bots used for ANGLE rolls on Chromium CV,
|
2020-04-01 06:59:18 +03:00
|
|
|
[linux-swangle-try-x64](https://luci-milo.appspot.com/p/chromium/builders/try/linux-swangle-try-x64)
|
|
|
|
and
|
|
|
|
[win-swangle-try-x86](https://luci-milo.appspot.com/p/chromium/builders/try/win-swangle-try-x86).
|
|
|
|
|
|
|
|
Same instructions as for [Task 1](#task-1_monitor-angle-ci-and-try-testers) apply here.
|
|
|
|
Some failures on these bots may be due to SwiftShader changes, however.
|
|
|
|
The possible ways to handle these failures are:
|
|
|
|
1. If possible, suppress the failing tests in ANGLE, opening a bug to investigate these later.
|
|
|
|
1. If it is clear that an ANGLE CL caused a regression,
|
|
|
|
consider whether reverting it or suppressing the failures is a better course of action.
|
|
|
|
1. If a SwiftShader CL is suspected, and the breakage is too severe to be suppressed,
|
|
|
|
(a lot of tests fail in multiple suites),
|
|
|
|
it is possible to revert the responsible SwiftShader roll into Chromium
|
|
|
|
and open a SwiftShader [bug](http://go/swiftshaderbugs). SwiftShader rolls into Chromium
|
|
|
|
should fail afterwards, but if the bad roll manages to reland,
|
|
|
|
the [autoroller](https://autoroll.skia.org/r/swiftshader-chromium-autoroll) needs to be stopped.
|
|
|
|
|
|
|
|
A lower priority task here is to keep healthy all the SwANGLE
|
|
|
|
[CI](https://luci-milo.appspot.com/p/chromium/g/chromium.swangle/builders) and
|
|
|
|
[Try](https://luci-milo.appspot.com/p/chromium/g/tryserver.chromium.swangle/builders) bots.
|
2020-10-02 23:56:52 +03:00
|
|
|
|
|
|
|
## Task 6: Monitor and respond to ANGLE's perf alerts
|
|
|
|
|
|
|
|
Any large regressions should be triaged with a new ANGLE bug linked to any suspected CLs that may
|
|
|
|
have caused performance to regress. If it's a known/expected regression, the bug can be closed as
|
|
|
|
such. The tests are very flaky right now, so a WontFix resolution is often appropriate.
|