QA/Platform/Graphics

From MozillaWiki
Jump to navigation Jump to search

Summary

This page holds important information related to testing and quality assurance for Gecko's graphics code.

Metrics:

Get Involved

Here are some ways you can help the Graphics team (and Mozilla):

Activities

Current Activities

  • Betabreakers runs sanity tests of major changes at least once during each new Aurora version
  • One & Done is used to enable volunteers to participate in sanity testing
  • Triage is done daily from 10am to 11am Pacific to ensure effective resolution of critical issues, each day focusing on a different category of issues.

Triage

Get Involved

Want to help with or learn about triage? Contact me!

Help Wanted

Once per week, typically on Monday, we review bug reports tagged with help-wanted older than 30 days to ensure these issue are still relevant and on track to resolution.

How to Triage:

  1. Select a bug from this list
  2. Review the bug to make sure you understand the bug report and the information needed to move it forward
  3. Attempt to reproduce the bug
  4. If you can reproduce the bug, attempt to find a regression window either manually or using mozregression
  5. Update the bug report with any new information you can provide
  6. If you can't reproduce the issue or don't understand the issue, move on to the next bug report

Whenever updating a bug report be sure to add a comment explaining the change.

Incoming

Once per week, typically on Tuesday, we review bug reports that were reported more than 30 days ago but have yet to be triaged by the Graphics team.

How to Triage

  1. Select a bug from this list (it's best sort by most recent changed first)
  2. Review the information in the bug and make sure you understand the issue
  3. If the bug is a feature request, add the feature keyword and move on to the next bug
  4. Request for information from the report if there is information missing (regression window, steps to reproduce, minimized testcase, screenshots, system information, etc)
  5. If you can reproduce the issue as described then update the bug and escalate it to a graphics developer
  6. If you cannot reproduce the issue, ask a developer or the reporter if the bug is still valid
  7. Be sure to add the gfx-noted tag to the whiteboard field once triaged
  8. Move on to the next bug report if you can

Top Crashes

Once per week, typically on Wednesday, we review our top crash reports to ensure these issues have bug reports on track toward resolution.

How to Triage

Note: Whenever updating a bug report be sure to add a comment explaining the change.

  1. Review the reports above
  2. If you see a graphics crash that doesn't have a bug report, file a bug report for it
  3. If you see a graphics crash with an associated bug ID, open the bug report and update the statistics for the bug
  4. If the crash is escalating and is now in top-crash territory, add the topcrash keyword and nominate the bug to track
  5. If the crash is declining and is no longer in top-crash territory, remove the topcrash keyword
  6. Repeat the process for each crash you find in the list

Cold Crashes

Once per week, typically on Thursday, we review crash bug reports we have on file that have not been updated in more than 30 days to ensure these issues are still relevant and on track to resolution.

How to Triage:

  1. Load this list of bugs and sort by most recent changed
  2. Open the first bug report and review the information
  3. Check if there are anymore crash reports by clicking the signature link
  4. If there are no more crash reports, close the bug
  5. If there are still bug reports, update the statistics in the bug report and see if you can reproduce
  6. If you can't reproduce, ask the reporter for new information
  7. If you can reproduce, ask the developer what information is needed to move the bug forward
  8. Update the bug with any new information and move on to the next bug report

Cold Trackers

One per week, typically on Friday, we review tracked bug reports that have not been updated in more than 30 days to ensure these issues are still relevant and on track to resolution.

How to Triage:

  1. Select a bug from this list (sort by most recent changed)
  2. Review the information in the bug report
  3. Try to deduce if the bug is still relevant through testing, reviewing linked reports, or asking people involved on the bug
  4. If the bug is still relevant, update the status/tracking flags, and needinfo flag the developer for a status update
  5. If the bug is no longer relevant, update the status flags and close the bug report
  6. Once you've updated the bug move on to the next bug report

Cold Regressions

One per week we review old regression bug reports that have not been updated in more than 42 days to ensure these issues are still relevant and on track to resolution.

How to Triage

1. Select a bug from this list and review the information in the report

2. Make sure each bug has the following information:

  • a regression window (see step 4 if it doesn't)
  • [gfx-noted] in the whiteboard field
  • Has Regression Window and Has STR flags set to the correct value
  • 'status-firefox flags set to the correct values (old versions can be cleared, new versions can be set to ? if unknown)

3. Use the needinfo? flag and ask the bug reporter to test if the bug still occurs in the current Firefox Nightly

4. (Optional) See if you can reproduce the bug yourself and add a comment to the bug describing your test environment and result. If you're able to reproduce the bug use Mozregression to find the regression window. Be sure to use the needinfo:? flag to bring the bug to my attention (ashughes).

Past Activities

Top Issues

Blockers

No results.

0 Total; 0 Open (0%); 0 Resolved (0%); 0 Verified (0%);


Crashes

Full Query
ID Summary Status Last change time
1711801 Crashes at gpusGenerateCrashLog with graphics kernel error '0xfffffff9/-7' REOPENED 2024-04-04T20:53:17Z
1711802 Crashes at gpusGenerateCrashLog with graphics kernel error '0xfffffffc/-4' REOPENED 2024-04-04T20:52:45Z
1711804 Crashes at gpusGenerateCrashLog with graphics kernel error '0xe00002c2' REOPENED 2024-04-04T20:51:59Z
1713230 Crashes at gpusGenerateCrashLog with customized graphics kernel errors '0x1be385f9' and '0x067900fc' REOPENED 2024-04-04T20:52:21Z
1714235 Crashes at gpusGenerateCrashLog with graphics hardware errors '0x00000813', '0x00000803', '0x00008013', '0x00000003' and '0x00008003' REOPENED 2024-04-04T20:53:03Z
1715689 Intermittent gfx/layers/apz/test/mochitest/test_group_double_tap_zoom-2.html | application crashed [@ webrender::frame_builder::FrameBuilder::build] NEW 2025-06-16T19:53:49Z
1783212 macOS Crash in [@ pthread_kill | abort | gpusKillClientExt] NEW 2025-05-01T20:37:16Z
1833951 Crash in [@ mozilla::layers::ImageBridgeChild::InitForContent] with "Failed to start ImageBridgeChild thread!" NEW 2025-06-09T12:21:27Z
1838649 Crashes often when scrolling on gitlab merge request NEW 2024-04-04T21:06:53Z
1843348 Crash in [@ core::result::unwrap_failed | webrender::renderer::upload::copy_into_staging_buffer] NEW 2025-05-28T19:08:31Z
1900134 Crash in [@ IPCError-content | GPUProcessKill] NEW 2025-04-25T06:51:06Z
1908798 Crash in [@ IPCError-browser | GPUProcessKill] NEW 2025-04-24T20:53:21Z

12 Total; 12 Open (100%); 0 Resolved (0%); 0 Verified (0%);


Features

Full Query
ID Summary Status Last change time
703217 Implement image() from CSS Image Values and Replaced Content Module Level 4 NEW 2022-10-11T00:04:16Z
790640 add Media Fragments for images (spatial dimensions) NEW 2023-02-16T08:13:30Z
952539 WebGL should support efficiently uploading a subrect of a canvas to a texture NEW 2024-08-14T10:25:46Z
1152974 Enable by default DEAA (Anti-aliasing) for Linux NEW 2023-08-11T18:19:59Z
1200864 Skip DrawElements buffer validation when we have robust_buffer_access NEW 2023-03-24T17:36:32Z
1223880 Implement initial-letter (from CSS Inline Layout Module Level 3) NEW 2025-06-06T12:59:02Z
1233569 Deprecate RGB8 from being renderable in WebGL 1 NEW 2022-10-11T17:53:19Z
1237489 [webvr] Add basic MOZ_texture_from_element to enable creating a texture from an arbitrary element NEW 2022-10-11T17:55:16Z
1244513 webm videos should be color corrected UNCONFIRMED 2022-10-11T17:59:31Z
1264543 [meta] Out-of-process compositing NEW 2024-09-22T12:02:05Z
1282074 Support very large canvases NEW 2024-11-05T11:22:06Z
1302685 [meta] Support OpenType Font Variations (Variable fonts) NEW 2025-03-31T14:31:28Z
1309309 Report memory used by ANGLE in about:memory as its own block? NEW 2022-10-11T18:39:33Z
1350292 Memory allocated by WebGL in WebGLBuffer::BufferData is not tracked in about:memory (detected by DMD in heap-unclassified) NEW 2024-03-05T08:06:06Z
1367003 Page slow to load when scrolling up and down. NEW 2022-10-11T19:19:15Z
1371101 Run color, border-color, and background-color animations off the main thread NEW 2024-04-03T03:21:39Z
1371108 WebGL: Make default back buffer default to 8x8 AA when available UNCONFIRMED 2022-10-11T19:21:50Z
1371627 GL_EXT_draw_buffers extension not supported UNCONFIRMED 2022-10-11T19:22:13Z
1371836 Provide a performance object for the WebGL canvas NEW 2022-10-11T19:22:42Z
1374710 GLBlitHelper should cache the various shaders NEW 2025-04-05T10:08:55Z
1381098 imageBitmap should provide an api to pull out raw pixel data (unmodified) without having to draw it to a canvas or a renderBuffer. This should be able to run in a webworker UNCONFIRMED 2023-08-07T12:24:48Z
1391345 Some emoji on the emojione demo page don't show up NEW 2022-10-11T19:36:02Z
1392080 Feature request : ɴᴘᴀᴘɪ being phased out : please provide an alternative for direct Vulkan/Direct3ᴅ12 access for viewing stereoscopic videos ! UNCONFIRMED 2023-07-27T18:52:44Z
1402293 Implement support for High Efficiency Image File Format (HEIF) NEW 2025-03-01T11:34:00Z
1403299 Support rendering fonts via FreeType on Windows NEW 2024-07-25T05:06:45Z
1403933 Support standard swizzle in D3D11 texture NEW 2022-10-11T19:45:25Z
1412350 Support Color Management on Android NEW 2024-05-31T01:24:55Z
1428954 Support encoding .ico files with multiple sizes NEW 2022-10-11T21:09:36Z
1443863 Implement support for AV1 Still Image File Format (AVIF) NEW 2025-03-02T15:12:52Z
1461360 [meta] Cross-platform dependencies for pinch-zooming on desktop NEW 2023-04-23T08:13:11Z
1476861 Implement FillRoundedRect for DrawTargetSkia ASSIGNED 2022-10-11T21:48:00Z
1477078 Implement PushClipRoundedRect for DrawTargetSkia ASSIGNED 2022-10-11T21:48:11Z
1480894 Implement wide-gamut support on Canvas NEW 2022-10-11T21:51:27Z
1516362 Selecting text using background-clip: text should probably change the text color NEW 2022-10-11T22:20:40Z
1522397 Displayed content in active tab doesn't adapt to screen resolution changes when connecting/disconnecting external monitor NEW 2023-05-24T13:32:17Z
1532721 Re-enable D2D on Qualcomm devices when able NEW 2024-06-19T14:13:44Z
1536809 Add support for Canvas 2D "desynchronized" construction attribute UNCONFIRMED 2025-04-28T23:33:47Z
1539075 Implement support for JPEG XL (image/jxl) ASSIGNED 2025-06-06T20:45:47Z
1547612 Use Lanczos method for upscaling images for different zoom levels NEW 2023-01-14T09:05:28Z
1605234 [meta] Support elastic overscroll on desktop NEW 2025-03-11T08:36:23Z

40 Total; 40 Open (100%); 0 Resolved (0%); 0 Verified (0%);


New Issues

Full Query
ID Summary Last change time
1968138 On Windows 11, scroll bars disappear and don't come back on hover 2025-06-17T02:05:30Z
1968186 scrollbar keeps scrolling to the end if you hold left click in the place you want to scroll 2025-05-24T01:46:47Z
1968315 WebGPU canvas is always alpha-blended with page background on macOS 2025-05-30T07:07:58Z
1968440 can't copy title text field on Emby forum 2025-06-02T23:17:43Z
1968657 Firefox 139, flickering window with a video, if it comes off the edge of the screen 2025-06-17T22:29:58Z
1968827 Memory leak in gpu process while uploading video to youtube(start at 138.*) 2025-06-17T22:41:50Z
1968860 gfx/angle/checkout/src/image_util/loadimage.cpp: 2 * sanity check in wrong place 2025-06-19T00:43:21Z
1969247 Add a setting for a minimum scrollbar width 2025-05-29T13:42:06Z
1969390 createImageBitmap(Blob) decodes images on the main thread 2025-06-19T16:11:53Z
1969605 Streaming video playback stuttering for seconds at a time on Intel GPU after update 2025-06-05T17:09:14Z
1969722 Firefox freezes after start up 2025-06-18T12:01:57Z
1969758 The I beam is obnoxiously huge and there is no fix that I can find. 2025-06-17T12:05:02Z
1970290 Scrolling laggy While Video Content Above 1080p playing 2025-06-04T04:47:06Z
1970335 lightningchart.com - FPS real-monitoring is lower compared to Chrome at 4k resolution 2025-06-18T15:54:08Z
1970345 Twitch flickering after Nvidia Driver update 2025-06-19T16:14:38Z
1970418 Cleartype settings are ignored on Windows 7 RC builds with Firefox 115 ESR or GDI mode 2025-06-19T16:24:01Z
1970629 [Linux] Touchpad kinetic scrolling's inertia logic is incorrect on vertical tabs 2025-06-10T02:59:36Z
1970715 JavaScript alert() and confirm() steal the mouse pointer and focus from other applications 2025-06-11T20:51:35Z
1970829 Graphical corruption with Intel Arc dGPUs 2025-06-14T03:25:11Z
1971042 High Shared GPU memory use reported in Task Manager 2025-06-15T14:44:49Z
1971077 Firefox Fullscreen causes severe stutters and crashing of Games on other monitor (AMD) 2025-06-22T13:43:30Z
1971159 GPU Process Memory Leak: Excess Memory Retained After Tab Closure 2025-06-15T14:45:45Z
1971162 popover top layer exit animations don't work 2025-06-17T08:11:50Z
1971164 popover backdrop entry animations don't work 2025-06-17T08:06:31Z
1971253 jitter scrolling with layout.disable-pixel-alignment=true (specifically images?) 2025-06-20T09:18:53Z
1971372 Unable to control checkbox with space bar 2025-06-17T13:43:34Z
1971582 Font Fingerprinting protection doesn't work with "Allow pages to choose their own fonts, instead of your selections above" 2025-06-17T20:15:07Z
1971673 CSS custom property using currentcolor requires spaces between var()s 2025-06-12T05:42:00Z
1971762 freebsd 14.2 firefox nvidia freeze 2025-06-16T19:57:23Z
1971867 Firefox resizes to fill screen after sleep, but does not switch to "full screen" mode 2025-06-17T22:44:41Z
1971912 Clipboard text not getting sent to Firefox through VNC 2025-06-20T09:39:27Z
1972370 font-family: "monospace" (with quotes) renders digits and whitespace incorrectly 2025-06-16T17:32:20Z
1972864 NVIDIA RTX Video Super Resolution (VSR) is not activating in Firefox (neither stable 139.0.4 nor Beta 140.0b9). The specific WEBRENDER_SUPER_RESOLUTION_NVIDIA feature does not appear in Firefox's about:support Decision Log. 2025-06-18T15:44:09Z
1973152 Mobile version of wikipedia does not respect the font config set in Firefox about:config 2025-06-20T12:47:57Z
1973184 Rendering artefacts with linear gradient 2025-06-20T10:50:54Z
1973267 Incongruous font rendering for zh-TW when Noto Sans CJK TC used with Microsoft Jhenghei fallbacks on Windows 2025-06-21T12:06:59Z
1973316 With RFP enabled, spaces are too wide and numbers gray on some sites 2025-06-21T00:18:37Z

37 Total; 37 Open (100%); 0 Resolved (0%); 0 Verified (0%);


Understanding the Problem Space

First order of business for my transition to the Graphics team is to understand the problem space so I can understand the immediate needs of the team and make the best impact I can in the shortest amount of time.

What are the key problems/challenges facing the Graphics team in terms of quality?
  • discrepancy in environments between testers and release users
  • discoverability of bugs pre-release
  • ?...
Where can QA add value/support to the Graphics team?
  • improving pre-release discoverability of bugs
  • closing the gap between tester and release systems
  • helping with bug triage, particularly with bugs hiding in general components
  • representation in crashkill
  • improving code coverage and/or identifying gaps in code coverage
  • identifying ways to improve participation in the graphics team (events, projects, One & Done, etc)
  • documentation of tools, testing processes, etc
  • building out the lab in Toronto
  • continuing to drive Betabreakers testing every 6 weeks
  • verifying bug fixes (what does this look like)?
  • profiling areas of risk (eg. troublesome configs)
  • conducting root cause analysis for regressions
  • understanding problems outside of our control (eg. driver resets)
  • feature testing and upcoming priorities (e10s, Windows 10, El Capitain, Android, B2G, etc)
What does QA need to know to be effective?
  • key components of an actionable Graphics bug
  • fundamentals/technologies that should be learned
  • how to distinguish a graphics crash from a non-graphics crash with a graphics signature
  • meetings, mailing lists, bugzilla components to watch, blogs, IRC channels to join, etc
  • who is each member of the team (incl. contributors) and what do they do
  • where does graphics code reside in the tree?
  • what role does Unified Telemetry in graphics quality?
  • what are the prefs to enable/disable different functionalities?
  • we need a database of known-troublesome hardware/driver configurations to inform testing, hardware acquisitions, and blocklisting
Understanding the Stability
  • How do we identify a graphics crash?
    • by signature: gfx, layers, D2D, D3D, ?...
    • by topmost filename: gfx, ?...
    • by driver (DLL, version, ?...)
    • by device/vendor ID?...
    • ?...
  • How do we prioritize graphics crashes?
    • Overall topcrashes in release > beta > aurora > nightly
    • Gfx crashes in release > beta > aurora > nightly
    • Explosive crashes in release > beta > aurora > nightly
  • What tools do we have at our disposal to investigate crashes?
    • Bughunter for investigating crashes correlated to a URL
    • KaiRo's reports for identifying crashes that are new or escalating quickly
    • Socorro for getting detailed information about crash reports
  • What information is needed to make a crash actionable by developers?
    • Correlations to particular hardware, driver, add-on, 3rd-party software, or library
    • ?...
Participation
  • Sanity checking via One & Done
  • Meetups to connect testers/users with devs
  • Testdays to teach people about graphics testing
  • Documentation and translation of documentation
  • Engaging on community spaces (Discourse, Reddit, Facebook, Twitter, etc)
Telemetry
  • COMPOSITE_TIME: time in CompositorParent::CompositeToTarget dispatching draw calls and calling SwapBuffers, but not texture upload (ie. complete composition)