-
Notifications
You must be signed in to change notification settings - Fork 1
Writing a golden file test for package:flutter
(This page is referenced by comments in the Flutter codebase.)
-
All tests
- Commit messages in flutter/goldens must reference the associated change in flutter/flutter, in the form of
Goldens for https://github.com/flutter/flutter/issues/123456
- Commit messages in flutter/goldens must reference the associated change in flutter/flutter, in the form of
-
Updated Tests
-
Don't update files, create new ones with an incremented version number.
-
Complete Handling Breaking Changes when updating an existing golden file.
-
Delete obsolete files from flutter/goldens once your PR has landed.
-
-
Flutter Gold Triage
- Visit Flutter Gold to triage golden test results when post-submit testing has completed. The status of these tests can be seen on the Flutter Dashboard.
Write your test as a normal test, using testWidgets
and await tester.pumpWidget
and so on.
Put a RepaintBoundary
widget around the part of the subtree that you want to verify. If you don't, the output will be a 2400x1800 image, since the tests by default use an 800x600 viewport with a device pixel ratio of 3.0.
Add an expectation along the following lines:
await expectLater(
find.byType(RepaintBoundary),
matchesGoldenFile(
'test_name.subtest.subfile.png',
version: 0,
),
);
The first argument is a finder that specifies the widget to screenshot.
The arguments to matchesGoldenFile
are the filename for the screen shot and a version number. For the filename, the part up to the first dot should exactly match the test filename (e.g. if your test is widgets/foo_bar_test.dart
, use foo_bar
). The subtest
part should be unique to this testWidgets
entry, and the part after that should be unique within the testWidgets
entry. This allows each file to have multiple testWidgets
tests each with their own namespace for the images, and then allows for disambiguation within each test in case there are multiple screen shots per test. The version number is used to differentiate historical golden files and is appended to the end of the filename. When we update a golden file, a new file is created rather than updating the old one, and the version number provides distinction between the old and the new, see Updating a Golden File below for more information.
We chose Linux as the host platform upon which we run golden file tests. All of the reference images found in flutter/goldens are generated on Linux. If you don't have a Linux box and need someone to generate the goldens for you, cc @Hixie on your PR. Otherwise, the golden file test will be skipped on local platforms that are not Linux. This is due to slight rendering differences across platforms, as we don't yet have the infrastructure in place to allow the developer to update their golden files on all three supported host platforms.
Once you have written your test, run flutter test --update-goldens test/foo/bar_test.dart
in the flutter
package directory (where the filename is the relative path to your new test). This will update the images in bin/cache/pkg/goldens/packages/flutter/test/
; the directories below that will match the hierarchy of the directories in the test
directory of the flutter
package. Verify that the images are what you expect; update your test and repeat this step until you are happy.
Run flutter test
again, but without the --update-goldens
flag, to verify that the goldens match. If they don't, check that you're using the right filenames, and that they're all unique. It's not uncommon to copy-paste the expectation lines and so accidentally have duplicate golden filenames.
Commit the images to the goldens repo. You do this by going into the bin/cache/pkg/goldens/
directory, which is actually a git checkout of our goldens repo, using git add
for all your new files, using git commit -a
to create a commit (in the commit message, link to the bug you are fixing, if possible, e.g. "Goldens for https://github.com/flutter/flutter/issues/17262"), and then pushing the files to the repo using git push [email protected]:flutter/goldens.git master
.
This updates the goldens repo but does not make the images actually available yet. To make them available, you then update the bin/internal/goldens.version
file in your Flutter repo to the hash of the commit you just pushed to the goldens repo.
Now run flutter test
again, without the --update-goldens
flag, to verify that the goldens match the uploaded images.
If they do, you are ready to submit your PR for review. The reviewer should also verify your golden files, so make sure to point to your goldens repo commit in your PR description. If you find the golden tests fail on some platforms, see the notes above about adding a skip line.
If renderings change, then rather than replacing the golden file in-situ, create new files with new names (incrementing the version number), and update the tests to point to those. Then, add the old file names to the README file.
This allows multiple people to contribute simultaneously without conflicting with each other.
Changes such as these constitute a breaking change, and should follow Handling Breaking Changes. This includes marking your PR with the severe: API break
and will affect goldens
labels, as well as updating the Changelog.
Once your main PR has landed, please come back and delete the obsolete files listed in the README.
Golden file tests for package:flutter
are currently transitioning to use Flutter Gold for baseline and version management of golden files. When this transition is complete, the flutter/goldens repository will no longer be used for testing. If you have questions about Flutter Gold, cc @Piinks on your PR.
You may notice the FlutterGitHubBot remind you to complete triage on Flutter Gold after merging a PR that includes a golden file test.
Once post-submit testing has completed on your change, the status of which can be seen on the Flutter Dashboard, you will see your change and the affected files compiled into a digest on the Flutter Gold dashboard.
Review the digest and the images that were generated, making sure they look as expected. Currently, we generate images for Linux, Mac and Windows platforms. It is common for there to be slight differences between them. The digest of each image will also include a visual diff and a closest match to images it has seen before. If you are pleased with your change, click the checkmark to approve the change and complete triage.
Triage permission is restricted to members of flutter-hackers. For more information, see Contributor Access.
- Home of the Wiki
- Roadmap
- API Reference (stable)
- API Reference (master)
- Glossary
- Contributor Guide
- Chat on Discord
- Code of Conduct
- Issue triage reports
- Our Values
- Tree hygiene
- Issue hygiene and Triage
- Style guide for Flutter repo
- Project teams
- Contributor access
- What should I work on?
- Running and writing tests
- Release process
- Rolling Dart
- Manual Engine Roll with Breaking Commits
- Updating Material Design Fonts & Icons
- Postmortems
- Setting up the Framework development environment
- The Framework architecture
- The flutter tool
- API Docs code block generation
- Running examples
- Using the Dart analyzer
- The flutter run variants
- Test coverage for package:flutter
- Writing a golden-file test for package:flutter
- Setting up the Engine development environment
- Compiling the engine
- Debugging the engine
- Using Sanitizers with the Flutter Engine
- Testing the engine
- The Engine architecture
- Flutter's modes
- Engine disk footprint
- Comparing AOT Snapshot Sizes
- Custom Flutter engine embedders
- Custom Flutter Engine Embedding in AOT Mode
- Flutter engine operation in AOT Mode
- Engine-specific Service Protocol extensions
- Crashes
- Supporting legacy platforms
- Metal on iOS FAQ
- Engine Clang Tidy Linter
- Why we have a separate engine repo
- Reduce Flutter engine size with MLGO
- Setting up the Plugins development environment
- Setting up the Packages development environment
- Plugins and Packages repository structure
- Plugin Tests
- Contributing to Plugins and Packages
- Releasing a Plugin or Package
- Unexpected Plugins and Packages failures