Retrospective: Flutter 2.8 Stable Release
Kevin Chisholm edited this page Dec 28, 2021
·
2 revisions
Date: 16 December 2021
Facilitator: Kevin Chisholm
- Nuritzi Sanchez
- Alexander Thomas
- Godofredo Contreras
- Vijay Menon
- Devon Carew
- Ian Hickson
- Devon Carew
- Todd Volkert
- Khyati Mehta
- Eric Seidel
- Christopher Fujino
- Andrew Brogdon
- Kevin Chisholm
Focus on the actions and behaviors, not the people. Our retrospectives should be a safe place to reflect on what we can do to improve as a team.
All input is valuable, we should never make someone feel as if their thoughts and contributions are not valued.
Work toward defining the issues that can be actioned on to be more successful in the future.
- We released a quality SDK on the expected date.
- No P0 issues to hotfix.
- Our infrastructure and test owners responded rapidly to the chat allowing us to address issues.
- The social team was proactive in keeping customers informed.
- Were able to delay blog post and docs.
- Got them out in time after the release was available.
- We did not properly take into account how long the release would take.
- We had no process to separate the build from the release.
- Documentation is lacking / not prescriptive enough to accurately describe the entire process.
- Release documentation. We have a lot of documentation, but it’s not consolidated into a single source of truth with handoffs and DRIs (directly responsible individuals)
- A lot of this release seemed based on undocumented institutional knowledge.
- Didn’t find info about dot releases and cherrypicking. Not written down anywhere.
- We incorrectly tagged the Dart commit.
- We did not have the Dart commit hash posted in the release engineering doc.
- Missed deadline by 8 hours.
- PM team had to do extra work and expend their social capital.
- We need documentation for the binary signing process.
- We may not have benefited from publishing the Dart SDK release earlier. We had the Dart stable hash on Friday, but did not properly communicate it to the release engineer. As soon as the Dart hash exists, Flutter and Dart release processes are independent, so if we had published it on Monday or Tuesday it wouldn’t have helped.
- Right now we start betas on a certain day and then stable have to be shipped on a certain day. We may need to rethink this and standardize.
- Fixes were needed to the stable bots (they were not the same as commit-bots/beta bots).
- Java version was wrong.
- Properties used to select the correct versions of artifacts were missing. Xcode/Mac/iOS were force updated in between the beta to stable time window
- Web Engine Framework, Framework sdk tests in the engine failed because they used the master version of framework with old version of engine.
- Branch configurations were updated after landing the PR causing multiple purples and several manual retries.
- Build Flutter in advance.
- Should have been done the day before and pushed the morning of.
- Do most of the build and release process in advance; on the day-of, do the tagging / packaging work (<1 hr, and a predictable process).
- How early we can release may be determined by what bugs we need to hotfix.
- Docs need to be updated after the branch push
- What is the delta between the master and stable branch?
- ~6 days
- Create a solid release playbook on the wiki to be followed.
- Should be clear enough that two interns (meaning, two inexperienced people new to the team who have the appropriate permissions) should be able to make a release without supervision while everyone else is on vacation. (It has to be two because you need two people to authorize a release).
- https://github.com/flutter/flutter/wiki/Release-process should be (or point to) that process doc; other pages on the wiki should be up to date also.
- Align beta and stable release processes.
- Practice release dry runs.
- Have people who have never followed the steps before practice the steps, to find where the documentation is missing important details.
- Run retrospectives after every beta and stable release.
- Improve testing infrastructure.
- Better define owners.
- Improve communication.
- Cherry pick owners were not notified of the release times.
- Were not able to resolve issues.
Status | Action Item | Owner |
---|---|---|
In Progress | Create a single source of truth release playbook unifying the Flutter and Dart release processes | Kevin |
In Progress | Rethink timing of releases | Kevin |
In Progress | Identify release calendars and make sure they are easily accessible to everyone who needs to see them | Kevin |
In Progress | Conduct retrospectives after every release | Kevin |
In Progress | Create a release rotation for beta releases | Godofredo |
In Progress | Create meeting for Dart / Flutter EngProd teams and TPM team on release weeks | Kevin |
In Progress | Clean up and consolidate release documentation | TPM |
In Progress | Successfully produce at least 2 betas before our Feb stable to verify that we will be without issues for the Feb stable | Devon / Kevin |
In Progress | Consider the milestone flow on github | Ian / Kevin |
- Home of the Wiki
- Roadmap
- API Reference (stable)
- API Reference (main)
- Glossary
- Contributor Guide
- Chat on Discord
- Design documents
- Code of Conduct
- Issue triage reports (latest)
- Our Values
- Tree hygiene
- Issue hygiene and Triage
- Style guide for Flutter repo
- Project teams
- Contributor access
- What should I work on?
- Popular issues
- Running and writing tests
- Release process
- Flutter Framework Gardener Rotation
- Rolling Dart
- Manual Engine Roll with Breaking Commits
- Updating Material Design Fonts & Icons
- Postmortems and Retrospectives
- Hotfix Documentation Best Practices
- In case of emergency
- Landing Changes With Autosubmit
- Setting up the Framework development environment
- The Framework architecture
- 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
- Managing template image assets
- 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
- Crashes
- more...
- Setting up the Packages development environment
- Plugins and Packages repository structure
- Contributing to Plugins and Packages
- Understanding Packages tests
- Plugin Tests
- Releasing a Plugin or Package
- more...