🛩️ Product groups
This page covers what all contributors (fleeties or not) need to know in order to contribute changes to the core product.
When creating software, handoffs between teams or contributors are one of the most common sources of miscommunication and waste. Like GitLab, Fleet uses product groups to minimize handoffs and maximize iteration and efficiency in the way we build the product.
- Write down philosophies and show how the pieces of the development process fit together on this "🛩️ Product groups" page.
- Use the dedicated departmental handbook pages for 🚀 Engineering and 🦢 Product Design to keep track of specific, rote responsibilities and recurring rituals designed to be read and used only by people within those departments.
Product roadmap
Fleet team members can read Fleet's high-level product goals for the current quarter (confidential Google Sheet).
What are product groups?
Fleet organizes product development efforts into separate, cross-functional product groups that include product designers, developers, and quality engineers. These product groups are organized by business goal, and designed to operate in parallel.
Security, performance, stability, scalability, database migrations, release compatibility, usage documentation (such as REST API and configuration reference), contributor experience, and support escalation are the responsibility of every product group.
At Fleet, anyone can contribute, even across product groups.
Ideas expressed in wireframes, like code contributions, are welcome from everyone, inside or outside the company.
Product group roles
| Role | Responsibilities | 
|---|---|
| Product Designer | Wireframe changes to the product, API, configuration surface, GitOps YAML, CLI, and UI. | 
| Product Owner | Define the product vision, prioritize the roadmap and product backlog, communicate with stakeholders. | 
| Engineering Manager | Oversee sprint progress, plan and coordinate efforts, technical communication with stakeholders, recruit and mentor engineers. | 
| Tech Lead | Oversee day-to-day engineering efforts, assist with user story drafting, support engineers. Capacity is 1/3 support, 2/3 Individual Contributor. | 
| Quality Assurance | Write and conduct test plans for user stories, report new unreleased bugs, test released bug fixes, conduct smoke testing before each release. | 
| Software Engineer | Implement changes to the product, provide technical expertise, research user stories, fix bugs, assist with quality assurance. | 
Current product groups
| Product group | Goal (value for customers and/or community) | Capacity | 
|---|---|---|
| MDM | Increase and exceed maturity in the device management product category. | 88 | 
| Software | Increase and exceed maturity in the software management product category. | 112 | 
| Orchestration | Increase and exceed maturity in the orchestration product category. | 100 | 
| Security & Compliance | Increase and exceed maturity in the security and compliance product category. | 88 | 
* The number of estimated story points this group can take on per-sprint under ideal circumstances, used as a baseline number for planning and prioritizing user stories for drafting. In reality, capacity will vary as engineers are on-call, out-of-office, filling in for other product groups, etc.
MDM group
The goal of the MDM group is to increase and exceed Fleet's product maturity goals in the "MDM" product category.
| Responsibility | Human(s) | 
|---|---|
| Product Designer | Marko Lisica (@marko-lisica) | 
| Product Owner | Marko Lisica (@marko-lisica) | 
| Engineering Manager | George Karr (@georgekarrv) | 
| Tech Lead | Jordan Montgomery (@JordanMontgomery) | 
| Quality Assurance | Gabe Lopez (@PezHub) | 
| Software Engineer | Sarah Gillespie (@gillespi314), Gabe Hernandez (@ghernandez345), Magnus Jensen (@MagnusHJensen) | 
Areas of expertise:
- MDM protocol & configuration
- New device onboarding
- Scripts
- Certificate Authorities (CAs)
- Certificate delivery & renewal
- Setup experience
- OS updates
The Slack channel, kanban release board, and GitHub label for this product group is
#g-mdm.
Software group
The goal of the software group is to increase and exceed Fleet's product maturity goals in the software management category.
| Responsibility | Human(s) | 
|---|---|
| Product Designer | Marko Lisica (@marko-lisica) | 
| Product Owner | Marko Lisica (@marko-lisica) | 
| Engineering Manager | George Karr (@georgekarrv) | 
| Tech Lead | Carlo DiCelico (@cdcme) | 
| Quality Assurance | Janis Watts (@jmwatts) | 
| Software Engineer | Rachel Perkins (@rachelelysia), Jahziel Villasana-Espinoza (@jahzielv), Jonathan Katz (@jkatz01), Martin Angers (@mna) | 
Areas of expertise:
- Software Install / uninstall / patch
- Fleet-maintained apps (FMAs)
- Apple Volume Purchasing Program (VPP) apps
- Google Play apps
- In-house apps (IPAs)
- End user self-service
The Slack channel, kanban release board, and GitHub label for this product group is
#g-software.
Orchestration group
The goal of the orchestration group is to increase and exceed Fleet's product maturity goals in the orchestration category.
| Responsibility | Human(s) | 
|---|---|
| Product Designer | Rachael Shaw (@rachaelshaw) | 
| Product Owner | Rachael Shaw (@rachaelshaw) | 
| Engineering Manager | Sharon Katz (@sharon-fdm) | 
| Tech Lead | Lucas Rodriguez (@lucasmrod) | 
| Quality Assurance | Reed Haynes (@xpkoala) | 
| Software Engineer | Scott Gress (@sgress454), Juan Fernandez (@juan-fdz-hawa), Ian Littman (@iansltx), Konstantin Sykulev (@ksykulev) | 
Areas of expertise:
- Fleetd
- Authn / authz
- Host data ingestion
- Foreign vitals / IdP vitals
- Automations
- Policies
- Queries
- Labels
- GitOps engine
The Slack channel, kanban release board, and GitHub label for this product group is
#g-orchestration.
Security & compliance group
The goal of the security and compliance group is to increase and exceed Fleet's product maturity goals in the security and compliance category.
| Responsibility | Human(s) | 
|---|---|
| Product Designer | Rachael Shaw (@rachaelshaw) | 
| Product Owner | Rachael Shaw (@rachaelshaw) | 
| Engineering Manager | Sharon Katz (@sharon-fdm) | 
| Tech Lead | Victor Lyuboslavsky (@getvictor) | 
| Quality Assurance | Andrey Kizimenko (@AndreyKizimenko) | 
| Software Engineer | Dante Catalfamo (@dantecatalfamo), Jacob Shandling (@jacobshandling), Tim Lee (@mostlikelee) | 
The Slack channel, kanban release board, and GitHub label for this product group is
#g-security-compliance.
Areas of expertise:
- Software inventory ingestion
- CVE/CPE ingestion & matching
- Vulnerability reporting
- CIS benchmarks
- PCI ASV
- Application blocking
- Encryption
Website group
The goal of the website group is to increase and exceed Fleet's product maturity goals for fleetdm.com.
| Responsibility | Human(s) | 
|---|---|
| Product Designer | Mike Thomas (@mike-j-thomas) | 
| Engineering Manager | Luke Heath (@lukeheath) | 
| Product Manager | Eric Shaw (@eashaw) | 
| Quality Assurance | Eric Shaw (@eashaw) | 
| Software Engineer | Eric Shaw (@eashaw) | 
The Slack channel, kanban board, and GitHub label for this product group is
#g-website.
Working groups
Like a product group at Fleet, a working group is an arrangement of people from different functions. What makes a working group unique is that it is tasked with achieving a high-impact business goal fast. A working group disbands when the goal is achieved so Fleet stays fast and avoids unnecessary process.
Working groups are for important work that needs to be done quickly, when asynchronous work would be too slow.
Working groups have their own section in the handbook that includes the name, goal, resources, and contributors. See the commented out section in the handbook for an example.
Items to cover in the section:
- Name of the working group
- Desired business outcomes (goals)
- Link to the working group Slack channel and GitHub project
- Who is involved. This should include who the DRI is.
- Timeline. When will the working group start? When do we think we'll be done by?
Making changes
Fleet's highest product ambition is to create experiences that users want.
To deliver on this mission, we need a clear, repeatable process for turning an idea into a set of cohesively-designed changes in the product.
Learn more about Fleet's philosophy and process for making interface changes to the product, and why we use a wireframe-first approach.
To make a change to Fleet:
- First, write it down- For every customer/prospect request, file a new GitHub issue. Whether the request is the same as an existing request will be determined by the Head of Product Design and a subject matter expert (SME) in the next step.
 
- Then, it will be looked at by Fleet's Head of Product Design and a SME unpack the "why".- For customer/prospect requests to be looked at, they must have a Gong snippet.
 
- Then, it will be prioritized and written up as one or more user stories.
- Then, it will be drafted (planned).
- Next, it will be implemented and released.
Occasionally, a contributor outside of the product groups (open source contributor, member of the Customer Success team, etc.) will implement a change that was prioritized and drafted. On the user story for these changes, add the product group label (e.g. #g-mdm, #g-orchestration, #g-software, #g-security-compliance), the :release label, and notify the product group's Engineer Manager to make sure the changes go through testing (QA) before release.
When an open source contributor proposes a change in the form of a pull request (PR), the PR will be reviewed and then merged or closed.
Planned and unplanned changes
Most changes to Fleet are planned changes. They are prioritized, defined, designed, revised, estimated, and scheduled into a release sprint prior to starting implementation. The process of going from a prioritized goal to an estimated, scheduled, committed user story with a target release is called "drafting", or "the drafting phase".
Occasionally, changes are unplanned. Like a patch for an unexpected bug, or a hotfix for a security issue. Or if an open source contributor suggests an unplanned change in the form of a pull request. These unplanned changes are sometimes OK to merge as-is. But if they change the user interface, the CLI usage, or the REST API, then they need to go through drafting and reconsideration before merging.
But wait, isn't this "waterfall"? Waterfall is something else. Between 2015-2023, GitLab and The Sails Company independently developed and co-evolved similar delivery processes. (What we call "drafting" and "implementation" at Fleet, is called "the validation phase" and "the build phase" at GitLab.)
Experimental features
When a new feature is introduced it may be labeled as experimental. Experimental features are undergoing a rapid incremental improvement and iteration process where new learnings may require breaking changes. When we introduce experimental features, it is important that any API endpoints or configuration surface that may change in the future be clearly labeled as experimental.
- Apply the ~experimentallabel to all associated user stories.
- Set the optional isExperimentalproperty to "yes" in pricing-features-table.yml.
- Make sure all API endpoints and configuration surface documentation includes the following message:
Experimental feature. This feature is undergoing rapid improvement, which may result in breaking changes to the API or configuration surface. It is not recommended for use in automated workflows.
Breaking changes
For product changes that cause breaking API or configuration changes or major impact for users (or even just the impression of major impact!), the company plans migration thoughtfully. If the feature was released as stable (not experimental), the product group and E-group:
- Written: Write a migration guide.
- Tested: Test the migration thoroughly as engineers.
- Gamed out: Pretend we are one or two key customers and try it out as a role play.
- Adapt: If it becomes clear that the plan is insufficient, fix it.
- Communicate: Create a plan for how to proactively communicate the change to customers.
All of the steps above happen prior to any breaking changes to stable features being prioritized for implementation.
API changes
To maintain consistency, ensure perspective, and provide a single pair of eyes in the design of Fleet's REST API and API documentation, there is a single Directly Responsible Individual (DRI). The API design DRI will review and approve any alterations at the pull request stage, instead of making it a prerequisite during drafting of the story. You may tag the DRI in a GitHub issue with draft API specs in place to receive a review and feedback prior to implementation. Receiving a pre-review from the DRI is encouraged if the API changes introduce new endpoints, or substantially change existing endpoints.
No API changes are merged without accompanying API documentation and approval from the DRI. The DRI is responsible for ensuring that the API design remains consistent and adequately addresses both standard and edge-case scenarios. The DRI is also the code owner of the API documentation Markdown file. The DRI is committed to reviewing PRs within one business day. In instances where the DRI is unavailable, the Head of Product will act as the substitute code owner and reviewer.
Changes to tables' schema
Whenever a PR is proposed for making changes to our tables' schema(e.g. to schema/tables/screenlock.yml), it also has to be reflected in our osquery_fleet_schema.json file.
The website team will periodically update the json file with the latest changes. If the changes should be deployed sooner, you can generate the new json file yourself by running these commands:
cd website
./node_modules/sails/bin/sails.js run generate-merged-schemaWhen adding a new table, make sure it does not already exist with the same name. If it does, consider changing the new table name or merge the two tables if it makes sense.
If a table is added to our ChromeOS extension but it does not exist in osquery or if it is a table added by fleetd, add a note that mentions it, as in this example.
Drafting
"Drafting" is the art of defining a change, designing and shepherding it through the drafting process until it is ready for implementation.
The goal of drafting is to deliver software that works every time with less total effort and investment, without making contribution any less fun. By researching and iterating prior to development, we design better product features, crystallize fewer bad, preemptive naming decisions, and achieve better throughput: getting more done in less time.
Fleet's drafting process is focused first and foremost on product development, but it can be used for any kind of change that benefits from planning or a "dry run". For example, imagine you work for a business who has decided to swap out one of your payroll or device management vendors. You will probably need to plan and execute changes to a number of complicated onboarding/offboarding processes.
Drafting process
The DRI for defining and drafting issues for a product group is the product manager, with close involvement from the designer and engineering manager. But drafting is a team effort, and all contributors participate.
A user story is considered ready for implementation once:
- User story issue created
-  Product group label added (e.g. #g-mdm,#g-orchestration,#g-software,#g-security-compliance)
- Changes specified and designed
- Designs revised and settled
- Reviewed and approved during weekly user story review
- All checklists are complete
- Estimated
- Scheduled for development
All user stories intended for the next sprint are estimated by the last estimation session before the sprint begins. This makes sure contributors have adequate time to complete the current sprint and provide accurate estimates for the next sprint.
Writing a good user story
Good user stories are short, with clear, unambiguous language.
- What screen are they looking at?  (As an observer on the host details page…)
- What do they want to do? (As an observer on the host details page, I want to run a permitted query.)
- Don't get hung up on the "so that I can ________" clause. It is helpful, but optional.
- Example: "As an admin I would like to be asked for confirmation before deleting a user so that I do not accidentally delete a user."
Is it actually a story?
User stories are small and independently valuable.
- Is it small enough? Will this task be likely to fit in 1 sprint when estimated?
- Is it valuable enough? Will this task drive business value when released, independent of other tasks?
Defining "done"
To successfully deliver a user story, the people working on it need to know what "done" means.
Every user story has a product and engineering checklist that is completed before the user story is estimated. This populates the user story with the requirements, wireframes, and test plan necessary for the product group to effectively specify, estimate, implement, and test the change. The Product Designer is the DRI for completing the product checklist, and the Engineering Manager (EM) is the DRI for completing the engineering checklist.
When the Product Designer has completed the product checklist, it is moved to the "User story review" column of the drafting board and reviewed during the weekly user story review rituals.
When a user story completes the review process, it is moved to the "Ready to spec" column on the drafting board and assigned to the product group's EM. The EM is responsible for completing the engineering checklist and finalizing the test plan with the QA Engineer before moving to the "Ready to estimate" column.
Providing context
User story issues contain an optional section called "Context".
This section is optional and hidden by default. It can be included or omitted, as time allows. As Fleet grows as an all-remote company with more asynchronous processes across timezones, we will rely on this section more and more.
Here are some examples of questions that might be helpful to answer:
- Why does this change matter more than you might think?
- What else should a contributor keep in mind when working on this change?
- Why create this user story? Why should Fleet work on it?
- Why now? Why prioritize this user story today?
- What is the business case? How does this contribute to reaching Fleet's strategic goals?
- What's the problem?
- What is the current situation? Why does the current situation hurt?
- Who are the affected users?
- What are they doing right now to resolve this issue? Why is this so bad?
These questions are helpful for the product team when considering what to prioritize. (The act of writing the answers has a lot of value!) But these answers can also be helpful when users or contributors (including our future selves) have questions about how best to estimate, iterate, or refine.
Initiate an air guitar session
Anyone in the product group can initiate an air guitar session.
- Create a new air guitar issue. Air guitar issues are always intended to be designed right away. If they can't be, the Head of Product Design notifies the requestor (normally a CSM or AE) via at-mention in the issue.
An air guitar session may be used to design features that won't be shipped.
- If the air guitar is prioritized, it's assigned to a Product Designer who brings it through the drafting process. However, keep in mind that these are conceptual and may or may not proceed to engineering. 
- When the wireframes are approved, assign the requester to the issue, at-mention them to let them know that the wireframes are ready, remove the - :productlabel, and add the appropriate label(s) to move the issue to the requester's board (- :help-customersfor CSMs and- #g-unicornsfor AEs). The requester (CSM or AE) will then bring the wireframes to a call with the customer or prospect to collect feedback. It's up to the requester to record feedback and add Gong snippets to the issue.
- After feedback has been added to the issue, the requester adds the - :productlabel and assigns the issue to the Head of Product Design to determine an outcome:
- Move forward with the formal drafting process leading to engineering.
- Keep it open for future consideration.
- Discard if it is invalidated through the process.
T-shirt sizing (capacity planning)
T-shirt sizes represent a rough estimate on the effort required to complete a task for a given team. Sometimes, T-shirt sizes are used to understand the level-of-effort before the task has gone through drafting.
Estimation points are used if a task has already gone through drafting.
| T-shirt size | Time | Story points | 
|---|---|---|
| XXS | ≤1 day for 1 contributor | 1-3 | 
| XS | ≤1 week for 1 contributor | 3-8 | 
| S | ≤1 sprint for 1 contributor | 8-25 | 
| M | 1 sprint for 2 contributors | 25-50 | 
| L | 1 sprint for 3 contributors | 50-75 | 
| XL | >1 sprint for 3 contributors | >75 | 
Implementing
Developing from wireframes
Please read carefully and pay special attention to UI wireframes.
While Product Designers are responsible for wireframing significant UI changes at Fleet's breakpoints (see breakpoints in the user story template), Fleet relies on Engineers to fill in the gaps and fluidly include all screen widths. If you discovered a gap, please bring the proposed changes as a live prototype to your product group's next design review.
Designs have usually gone through multiple rounds of revisions, but they could easily still be overlooking complexities or edge cases! When you think you've discovered a blocker, here's how to proceed:
For implementation concerns...
Communicate. Leave a comment mentioning the appropriate PM so they can update the user story and estimation to reflect your new understanding of the issue.
For all other concerns...
At Fleet, we prioritize iteration. So before raising the alarm, think through the following:
- Would addressing this add design work and/or delay shipping the feature?
- Will this hurt the first-time user experience if we ship as-is?
- Is this change a "one-way door"?
After these considerations, if you still think you've found a blocker, alert the appropriate PM so that the user story can be brought back for expedited drafting. Otherwise, make a feature request.
Check out GitLab's Iteration handbook section for a deep dive into why we iterate.
Sub-tasks
The simplest way to manage work is to use a single user story issue, then pass it around between contributors/asignees as seldom as possible. But on a case-by-case basis, for particular user stories and teams, it can sometimes be worthwhile to invest additional overhead in creating separate unestimated sub-task issues ("sub-tasks").
A user story is estimated to fit within 1 sprint and drives business value when released, independent of other stories. Sub-tasks are not.
Sub-tasks:
- can be created by anyone
- add extra management overhead and should be used sparingly
- do NOT have nested sub-tasks
- will NOT necessarily, in isolation, deliver any business value
- are always attached to exactly ONE top-level "user story" (which does drive business value)
- are included as links in the parent user story's "definition of done" checklist
- are NOT the best place to post GitHub comments (instead, concentrate conversation in the top-level "user story" issue)
- will NOT be looked at or QA'd by quality assurance
Outages
At Fleet, we consider an outage to be a situation where new features or previously stable features are broken or unusable.
- Occurrences of outages are tracked in the Outages spreadsheet.
- Fleet encourages embracing the inevitability of mistakes and discourages blame games.
- Fleet stresses the critical importance of avoiding outages because they make customers' lives worse instead of better.
Scaling Fleet
Fleet, as a Go server, scales horizontally very well. It’s not very CPU or memory intensive. However, there are some specific gotchas to be aware of when implementing new features. Visit our scaling Fleet page for tips on scaling Fleet as efficiently and effectively as possible.
Load testing
The load testing page outlines the process we use to load test Fleet, and contains the results of our semi-annual load test.
Version support
To provide the most accurate and efficient support, Fleet will only target fixes based on the latest released version. In the current version fixes, Fleet will not backport to older releases.
Community version supported for bug fixes: Latest version only
Community support for support/troubleshooting: Current major version
Premium version supported for bug fixes: Latest version only
Premium support for support/troubleshooting: All versions
Release testing
When a release is in testing, QA should use the Slack channel #help-qa to keep everyone aware of issues found. All bugs found should be reported in the channel after creating the bug first.
When a critical bug is found, the Fleetie who labels the bug as critical is responsible for following the critical bug notification process below.
All unreleased bugs are addressed before publishing a release. Released bugs that are not critical may be addressed during the next release per the standard bug process.
- Release blockers: Product may add the - ~release blockerlabel to user stories to indicate that the story must be completed to publish the next version of Fleet. Bugs are never labeled as release blockers.
- Critical bugs: A critical bug is a bug with the - ~critical buglabel. A critical bug is defined as behavior that:- Blocks the normal use of a workflow
- Prevents upgrades to Fleet
- Causes irreversible damage, such as data loss
- Introduces a security vulnerability
 
Notify the community about a critical bug
We inform customers and the community about critical bugs immediately so they don’t trigger it themselves. When a bug meeting the definition of critical is found, the bug finder is responsible for raising an alarm. Raising an alarm means pinging @here in the #g-mdm, #g-software, #g-orchestration, or #g-security-compliance channel with the filed bug.
If the bug finder is not a Fleetie (e.g., a member of the community), then whoever sees the critical bug should raise the alarm. Note that the bug finder here is NOT necessarily the first person who sees the bug. If you come across a bug you think is critical, but it has not been escalated, raise the alarm!
Once raised, product design confirms whether or not it's critical and defines expected behavior. When outside of working hours for the product design team or if no one from product design responds within 1 hour, then fall back to the #help-p1 channel.
Once the critical bug is confirmed, a priority label is applied and the priority response process begins. Customer Success notifies impacted customers and the community if community features are impacted. If Customer Success is not available, the on-call engineer or infrastructure on-call engineer is responsible for this. If a quick fix workaround exists, that should be communicated as well for those who are already upgraded.
The relevant release page on GitHub is updated to indicate that the release contains a critical bug, as shown on the fleet-v4.45.0 release page.
When a critical bug is identified, we will then follow the patch release process in our documentation.
After a critical bug is fixed, an incident postmortem is scheduled by the EM of the product group that fixed the bug.
Feature fest
To stay in-sync with our customers' needs, Fleet accepts feature requests from customers and community members on a sprint-by-sprint basis.
Features that meet a criteria for prioritization are prioritized at the 🎁🗣 Feature Fest meeting.
Anyone in the company is invited to submit requests or simply listen in on the 🎁🗣 Feature Fest meeting. Folks from the wider community can also request an invite.
Making a request
To make a feature request or advocate for a feature request from a customer or community member, create an issue using the feature request template. If you found that an issue already exists, add the :product label to it.
New requests are reviewed daily by the Head of Product Design and a former IT admin during the "Unpacking the why" call. If the request meets the criteria for prioritization, the request will be added to the upcoming feature fest (~feature fest label). If it doesn't, the request will be put to the side and the requester will be notified.
Fast for Fleeties: Fleeties do not have to wait for "Unpacking the why" to add a request to feature fest. If you think Fleet is missing something and have described in detail what you already tried, it can be moved directly to the 🎁 Feature fest board. Just add the
~feature festlabel.
Criteria for prioritization
To prioritize a new feature, it must meet one of these criteria:
- Bug
- Small UX improvement that isn't quite a bug but it's so small that it's worthwhile
- Contributes to Fleet's Product roadmap (see 🎯 Key results (OKRs) spreadsheet)
- Core: a feature that accentuates and directly assists in the core purpose of the company: to guide people out of the thicket through the gift of openness. It's what differentiates us. How Fleet defined "core".
- Context: a feature that customers consider mission critical for their particular buying situation. Can either be an existing customer request or a prospect request in an order form.
Features that are core to Fleet are prioritized over context (mission critical) features. Mission critical features can be prioritized over core features only if they're a customer promise or a customer request is blocking a migration to Fleet.
If an issue has the ~feature fest label, then it's a new feature request that will be weighed at the next 🎁🗣 Feature Fest meeting.
If an issue has the ~customer request label, then it's a feature request that's already been prioritized. It will have one or more user stories that will be worked on in the current quarter.
If an issue has the :product and story label, then it's a user story that is currently in progress (drafting). The user story will include a link to the original feature request issue.
How feature requests are prioritized
Prioritization of new feature requests happens at the 🎁🗣 Feature Fest meeting.
Before the 🎁🗣 Feature Fest meeting, the Customer renewals DRI adds customer requests to the 🎁🗣 Feature Fest board (~feature fest label) that are a high priority.
Before the meeting, the Feature prioritization DRI adds requests from Fleet's roadmap that contribute to Fleet's quarterly key results (KRs).
At the 🎁🗣 Feature Fest meeting, the Feature prioritization DRI weighs all requests in the inbox. When the team weighs a request, it is immediately prioritized or put to the side (not prioritized).
- A request is prioritized when the Feature prioritization DRI decides it is a priority.
- A request is put to the side when the business perceives competing priorities as more pressing in the immediate moment.
If a feature is not prioritized during a 🎁🗣 Feature Fest meeting, it only means the feature has been rejected at that time. Requestors will be notified by the Feature prioritization DRI, and they can add their request back to the feature fest board (~feature fest label) to bring it back to a future meeting.
If a feature request has an urgent Fleet need and can't wait until the next feature fest, @ mention the Head of Product Design in the
#g-mdm,#g-software,#g-orchestration, or#g-security-compliancechannel with a link to the request's GitHub issue. It's up to the HPD to decide whether it is immediately prioritized to go through drafting or put to the side. If prioritized, the HPD will decide to de-prioritize one or more feature requests to make room in the current design sprint and notify requesters.
After the feature is accepted
After the 🎁🗣 Feature fest meeting, the feature prioritization DRI will clear the 🎁 Feature fest board as follows:
- Prioritized features: Remove the ~feature festlabel, add the~customer requestlabel, create a new user story with the:productlabel, add the original request as parent issue in the user story, add the relevantcustomer-labels, and move the user story to the "Ready" column in the drafting board. The user story will then be assigned to a Product Designer during the "Design sprint kick-off" ritual.
- Put to the side features: Remove ~feature festlabel and notify the requestor.
The product team's commitment to the requester is that the prioritized user story will be delivered or the requester will be notified within 1 business day of the decision to de-prioritize the story.
A story may be de-prioritized when its relative priority falls below new requests and there is not enough room in the upcoming engineering sprint. Since Fleet does not maintain a feature backlog, a story is only prioritized if it seems like it can be shipped in the upcoming 3 week engineering sprint. The relative priority of a story and engineering capacity may change over the course of a design sprint.
- This may be because new higher-priority work (bugs or stories) was prioritized and/or the work in the current engineering sprint took longer than expected.
Just as when a feature request is not accepted in the 🎁🗣 Feature Fest meeting, whenever a feature is de-prioritized after it has been accepted, it only means that the feature has been de-prioritized at this time. It is up to the requester to bring the request back again at another 🎁🗣 Feature Fest meeting.
Quality
The goal of quality assurance is to identify corrections and optimizations before release by verifying;
- Bugs
- Fixes for bugs
- Edge cases
- Error messages
- Developer experience (using the API/CLI)
- Operator experience (looking at logs)
- API response time latency
- UI comprehensibility
- Simplicity, data accuracy, and perceived data freshness
Fleet uses a human-oriented quality assurance (QA) process to make sure the product meets the standards of users and organizations. Automated tests are important, but they can't catch everything. Many issues are hard to notice until a human looks empathetically at the user experience, whether in the user interface, the REST API, or the command line.
You can read our guide to diagnosing issues in Fleet on the debugging page. All bugs in Fleet are tracked by QA as GitHub issues with the "bug" label.
- Bug states: The lifecycle stages of a bug at Fleet correspond to a set of GitHub labels, assignees, and boards.
All bugs
- Bugs opened this week: This filter returns all "bug" issues opened after the specified date. Simply replace the date with a YYYY-MM-DD equal to one week ago. See on GitHub. 
- Bugs closed this week: This filter returns all "bug" issues closed after the specified date. Simply replace the date with a YYYY-MM-DD equal to one week ago. See on Github. 
Inbox
Quickly reproducing bug reports is a priority for Fleet. When a new bug is created using the bug report form, it is in the "inbox" state.  Website bugs (label: #g-website) are triaged by the website group.
At this state, the bug review DRI (QA) is responsible for going through the inbox and documenting reproduction steps, asking for more reproduction details from the reporter, or asking the product team for more guidance. QA has 1 business day to move the bug to the next step (reproduced) or request more information.
For community-reported bugs, this may require QA to gather more information from the reporter. QA should reach out to the reporter if more information is needed to reproduce the issue. Reporters are encouraged to provide timely follow-up information for each report. At one week since last communication QA will close the issue. Reporters are welcome to re-open the closed issue if more investigation is warranted.
Once reproduced, QA documents the reproduction steps in the description and moves it to the reproduced state.
For bugs that may require fixes from a partner (e.g. Apple, Microsoft, etc.), a Fleet issue is always filed. QA should file a support case with the partner and add a screenshot of the support case to the issue. For Apple bugs, @ mention the DRI of Customer support to file an Apple support case.
If the partner responds and confirms that fixes from the partner are required, a screenshot of the response is added to the issue. The bug stays open until the partner confirms the fix is shipped. At that point, QA verifies the fix and closes the issue. If fixes from the partner aren't required, the bug is moved to the reproduced state.
Reproduced
QA has reproduced the issue successfully. It should now be transferred to product design if it is a released bug, or engineering if it is unreleased.
If the bug is missing reproduction steps, it's removed from the drafting board and sent back to the "inbox" state.
Remove the “:reproduce” label, add the following labels:
- The relevant product group (e.g. #g-mdm,#g-orchestration,#g-software,#g-security-compliance). Make your best guess, and product design will change if necessary.
- The ~released buglabel if the bug is in a published version of Fleet, or~unreleased bugif it is not yet published.
- The :incominglabel indicates that it is a new bug to be triaged.
- If this is a released bug, add the :productlabel to place the bug on the product drafting board. If it is an unreleased bug, add the:releaselabel to place it directly on the release board so it is fixed before the next release.
Fast for Fleeties: Fleeties do not have to wait for QA to reproduce the bug. If you've reproduced it outside of the customer's environment, have provided well documented reproduction steps, and it's a bug, it can be moved directly to the reproduced state.
In product drafting
After reproduction, all released bugs go through drafting to validate that it is not expected behavior, it requires a code change to fix, and the bug report is fully populated. During drafting, product design will take one of the following actions:
- Prepare for engineering review and estimation- Specify a fix or a timebox
- Update the issue title, if it no longer matches our understanding of the issue
- Move it to the "Ready to estimate" column of the drafting board
 
- Convert to a feature request- Remove all bug labels
- Leave the issue in the "New requests" column
 
- Assign to a non-engineering team
- Close, if determined to be expected behavior
If a bug meets the criteria for a critical bug, the ~critical bug label is added, and product design follows the critical bug notification process.
In engineering
A bug is in engineering after it has gone through product drafting, has received an estimation, and has been moved to a release board during sprint planning.
Awaiting QA
Bugs will be verified as fixed by QA when they are placed in the "Awaiting QA" column of the relevant product group's sprint board. If the bug is verified as fixed, it is moved to the "Ready for release" column of the sprint board. Otherwise, the remaining issues are noted in a comment, and it is moved back to the "In progress" column of the sprint board.
How to reach the developer on-call
Oncall engineers do not need to actively monitor Slack channels, except when called in by the Community or Customer teams. Members of those teams are instructed to @oncall in #help-engineering to get the attention of the on-call engineer to continue discussing any issues that come up. In some cases, the Community or Customer representative will continue to communicate with the requestor. In others, the on-call engineer will communicate directly (team members should use their judgment and discuss on a case-by-case basis how to best communicate with community members and customers).
The developer on-call rotation
See the internal Google Sheet for the engineers in the rotation.
New developers are added to the on-call rotation by their manager after they have completed onboarding and at least one full release cycle. We aim to alternate the rotation between product groups when possible.
The on-call rotation may be adjusted with approval from the EMs of any product groups affected. Any changes should be made before the start of the sprint so that capacity can be planned accordingly.
Developer on-call responsibilities
First-line response
- Community pull requests.
All PRs from the community are routed through the on-call developer. Follow the process to review a community pull request.
There is a small script to help show community PRs and issues in oncall/oncall.sh.
- Second-line response
- Customer and community support.
Customer Support Engineers are responsible for the first response to Slack messages in the #fleet channel of osquery Slack, and other public Slacks. The Customer Success group is responsible for the first response to messages in private customer Slack channels.
We respond within 1-hour (during business hours) for interactions and ask the on-call developer to address any questions sent their way promptly. When a Customer Support Engineer is unavailable, the on-call developer may sometimes be asked to take over the first response duties. Note that we do not need to have answers within 1 hour -- we need to at least acknowledge and collect any additional necessary information, while researching/escalating to find answers internally. See Escalations for more on this.
Response SLAs help us measure and guarantee the responsiveness that a customer can expect from Fleet. But SLAs aside, when a Fleet customer has an emergency or other time-sensitive situation ongoing, it is Fleet's priority to help them find a solution quickly.
- Customer success meetings The on-call developer is encouraged to attend some of the customer success meetings during the week. Post a message to the :help-customers Slack channel requesting invitations to upcoming meetings.
This has a dual purpose of providing more context for how our customers use Fleet. The developer should actively participate and provide input where appropriate (if not sure, please ask your manager or organizer of the call).
- Documentation for contributors Fleet's documentation for contributors can be found in the Fleet GitHub repo.
The on-call developer is asked to read, understand, test, correct, and improve at least one doc page per week.
Our goal is to ensure accuracy and verify that our deployment guides and tutorials are up to date and work as expected, as well as improve the readability, consistency, and simplicity of our documentation – with empathy towards first-time users.
See Writing for writing guidelines, and don't hesitate to reach out to 🌐 IT & Enablement on Slack for writing support. Outstanding documentation issues use the :improve documentation tag.
- Engineering alerts The on-call developer is responsible for triaging new alerts in the #help-engineering Slack channel, such as failing unit tests. If the on-call developer has the ability to make the fix, they should do so. Otherwise, they should request help from the appropriate team. Filing a bug is also an option if the issue is not urgent.
Escalations
When the on-call developer is unsure of the answer, they should follow this process for escalation.
To achieve quick "first-response" times, you are encouraged to say something like "I don't know the answer and I'm taking it back to the team," or "I think X, but I'm confirming that with the team (or by looking in the code)."
How to escalate:
- Spend 30 minutes digging into the relevant code (osquery, Fleet) and/or documentation (osquery, Fleet). Even if you don't know the codebase (or even the programming language), you can sometimes find good answers this way. At the least, you'll become more familiar with each project. Try searching the code for relevant keywords, or filenames. 
- Create a new thread in the #help-engineering channel tagging the relevant product group and provide the information turned up in your research. Please include possibly relevant links (even if you didn't find what you were looking for there). 
Changing of the guard
The on-call developer changes each week on Mondays.
A Slack reminder should notify the on-call of the handoff. Please do the following:
- The new on-call developer should change the - @oncallalias in Slack to point to them. In the search box, type "people" and select "People & user groups." Switch to the "User groups" tab. Click- @oncall. In the right sidebar, click "Edit Members." Remove the former on-call, and add yourself.
- Hand off newer conversations (Slack threads, issues, PRs, etc.). For more recent threads, the former on-call can unsubscribe from the thread, and the new on-call should subscribe. The former on-call should explicitly share each of these threads and the new on-call can select "Get notified about new replies" in the "..." menu. The former on-call can select "Turn off notifications for replies" in that same menu. It can be helpful for the former on-call to remain available for any conversations they were deeply involved in, so use your judgment on which threads to hand off. Anything not clearly handed off remains the responsibility of the former on-call developer. 
In the Slack reminder thread, the on-call developer includes their retrospective. Please answer the following:
- What were the most common support requests over the week? This can potentially give the new on-call an idea of which documentation to focus their efforts on. 
- Which documentation page did you focus on? What changes were necessary? 
- How did you spend the rest of your on-call week? This is a chance to demo or share what you learned. 
Wireframes
- Showing these principles and ideas, to help remember the pros and cons and conceptualize the above visually.
- Figma: ⚗️ Fleet product project
We have certain design conventions that we include in Fleet. We will document more of these over time.
Design system
The 🧩 "Design System" component library in Figma is the source of truth for components. Components in the product (documented in Storybook) should match the style of components defined in the Figma library. If the frontend component is inconsistent with one in the Figma library, treat that as a bug. As new components are being created, or existing components are being updated, ensure updates are applied to both the Figma Library and Storybook and guidelines are documented in Figma.
Table empty states
Use ---, with color $ui-fleet-black-50 as the default UI for empty columns.
Images
Simple icons (aka any images used in the icon design system component) are exported as SVGs. All other images are exported as PNGs, following the Fleet website image naming conventions.
Form behavior
Pressing the return or enter key with an open form will cause the form to be submitted.
Internal links
For text links that navigate the user to a different page within the Fleet UI, use the $core-blue color and xs-bold styling. You'll also want to make sure to use the underline style for when the user hovers over these links.
External links
For a link that navigates the user to an external site (e.g., fleetdm.com/docs), use the $core-blue color and xs-bold styling for the link's text. Also, place the link-out icon to the right of the link's text.
When including an external link, specify a redirect on fleetdm.com rather than the original link. That way, if the URL changes, we can fix it immediately via a PR to the website and users will not need to upgrade to benefit from the fix. Once the design is settled, make a PR for the redirect as part of preparing the story for development.
Tooltips
All tooltips change the cursor to a question mark on hover. All tooltips have a solid background color.
There are two types of tooltips. The two types of tooltips have some unique styles:
- Tooltips for text (column headers, input titles, inline text) appear when hovering over any text with a dashed underline. These tooltips use left-aligned text. 
- Tooltips for buttons, bubbles, table row elements, and other non-text elements appear when hovering over the element. These tooltips use center-aligned text. These tooltips include a centered arrow. 
Bold text
For copy in the Fleet UI and Fleet documentation, use bold text when referencing UI elements such as buttons, links, column names, form field names, page names, and section names. For an example, check out the bold text in the guide on enforcing disk encryption.
This way, if a user is scanning instructions, the bold text tells them what UI element they should look for.
In the docs, if a UI element is part of a section title (already bold) use double quotes, as shown in the explanation of MDM on/off in "Why this way".
Copy in parentheses (additional information)
When writing copy, consider whether additional information is necessary before adding it as a new sentence or in parentheses. If the information is needed, use parentheses with an incomplete sentence to keep the copy shorter.
Writing the time
When writing the time in the UI using "am" and "pm" abbreviations, write them without space between time and abbreviation, with no punctuation, and use lowercase letters (e.g. Working hours are 8am to 5pm).
Writing error messages
When writing error messages in the UI or CLI, follow these rules:
- If the solution to the error isn't obvious, write a message with the error followed by the solution. For example, "No hosts targeted. Make sure you provide a valid hostname, UUID, osquery host ID, or node key."
- If the solution is obvious when additional info is provided, write a message with the error followed by additional info. For example, "You don’t have permission to run the script. Only users with the maintainer role and above can run scripts."
Fleetctl commands with --hosts or --host flag
When designing CLI experience for commands that target hosts (e.g. fleetctl query or fleetctl mdm run-command when including the --hosts or --host flag), if a non-existing host is specified, use a single error message such as: Error: No hosts targeted. Make sure you provide a valid hostname, UUID, osquery host ID, or node key.
When writing copy for CLI help pages use the following descriptions:
$ fleetctl <command with --hosts/--host flag> -h
OPTIONS
--hosts     Hosts specified by hostname, uuid, osquery_host_id or node_key that you want to target.
--host      Host specified by hostname, uuid, osquery_host_id or node_key that you want to target.Meetings
User story discovery
User story discovery meetings are scheduled as needed to align on large or complicated user stories. Before a discovery meeting is scheduled, the user story must be prioritized for product drafting and go through the design and specification process. When the user story is ready to be estimated, a user story discovery meeting may be scheduled to provide more dedicated, synchronous time for the team to discuss the user story than is available during weekly estimation sessions.
All participants are expected to review the user story and associated designs and specifications before the discovery meeting.
Participants:
- Product Manager
- Product Designer
- Engineering Manager
- Backend Software Engineer
- Frontend Software Engineer
- Product Quality Specialist
Agenda:
- Product Manager: Why this story has been prioritized
- Product Designer: Walk through user journey wireframes
- Engineering Manager: Review specifications and any defined sub-tasks
- Software Engineers: Clarifying questions and implementation details
- Product Quality Specialist: Testing plan
Design reviews
Design reviews are conducted daily between the Head of Product Design (HPD) and contributors (most often Product Designers) proposing changes to Fleet's interfaces, such as the graphical user interface (GUI) or REST API. This fast cadence shortens the feedback loop, makes progress visible, and encourages early feedback. This helps Fleet stay intentional about how the product is designed and minimize common issues like UI inconsistencies or accidental breaking changes to the API. If the HPD can't make it, a Product Designer from a product group attends to give feedback.
Anyone at Fleet can attend as a shadow. Shadows are asked to leave feedback/comments in the agenda doc without interrupting the meeting. This helps the team iterate and move designs to ready for spec faster.
In addition to design reviews, Fleeties or community members can provide feedback asynchronously at any time by finding the GitHub issue (user story) associated with the designs and @ mentioning the assigned Product Designer in the comment section.
Product Designers or other contributors come prepared to this meeting with their proposed changes in a GitHub issue. Usually these are in the form of Figma wireframes, a pull request to the API docs showing changes, or a demo of a prototype.
After the meeting, the contributor applies revisions and attends again the next day or as soon as possible for another go-round. The contributor is responsible for looping in the right engineers, community members, and other subject-matter experts to iterate on and refine upcoming product changes in the best interest of the business.
Here are some tips for making this meeting effective:
- Say the user story out loud to remind participants of what it is.
- Avoid explaining or showing multiple ways it could work. Show the one way you think it should work and let your work speak for itself.
- Make clear whether we're in "final review" or "feedback" mode:- Final review: The contributor is 70% sure the design is 100% done. — Feedback: the design is not ready for final review, but the contributor would like to get early feedback.
 
- For follow-ups, repeat the user story, but show only what has changed or been added since the last review.
- Bring 1 key engineer who has been helping out with the user story, when possible and helpful.
- Read Fleet's best practices for meetings.
User story reviews
User story reviews happen weekly between each product group's Product Designer (PD), Engineering Manager (EM), and Quality Assurance (QA) Engineer. During the call, contributors (PD and EM) present all user stories that are in the "User story review" column. The PD is the DRI for completing all product checklist items before bringing to review. For engineer-initiated stories, the EM is the DRI for completing all engineering checklist items before bringing to review.
The purpose of the review is to familiarize the EM and QA Engineer with the user story, and provide an opportunity to ask questions, clarify requirements, and highlight potential implementation issues. The first draft of the test plan produced by the Product Designer is reviewed and revised as needed during the call. The QA Engineer is the DRI for finalizing the test plan.
The purpose of the user story review is to align product, engineering, and QA on functionality and implementation details. Wireframe reviews occur daily during design reviews where contributors are welcome to join and provide design feedback in the agenda document. However, sometimes there are design changes needed if a gap is discovered or an implementation issue is raised during user story review. If there are design changes, the user story is moved back to the "In progress" column for additional drafting. If there are no design changes, the story remains with the Engineering DRI to complete the drafting process before bringing to estimation. If no Engineering DRI is assigned, the ticket is assigned to the Engineering Manager.
Group weeklies
A chance for deeper, synchronous discussion on topics relevant across product groups like “Frontend weekly”, “Backend weekly”, etc.
Participants: Anyone who wishes to participate.
Sample agenda from frontend weekly
- Discuss common patterns and conventions in the codebase
- Review difficult frontend bugs
- Write engineering-initiated stories
Eng Together
This meeting is to disseminate engineering-wide announcements, promote cohesion across groups within the engineering team, and connect with engineers (and the "engineering-curious") in other departments. Held monthly for one hour.
Participants: Everyone at the company is welcome to attend. All engineers are asked to attend. The subject matter is focused on engineering.
Agenda:
- Announcements
- Engineering KPIs review
- “Tech talks”- At least one member from each product group demos or discusses a technical subject relevant to engineering at Fleet.
- Everyone is welcome to present on a technical topic. Add your name and tech talk subject in the agenda doc included in the Eng Together calendar event.
 
- Social- Structured and/or unstructured social activities
 
New customer promise(s)
The Account Executive (AE) or Customer Success Manager (CSM) schedules this meeting before Fleet commits to one or more new customer promises. It's meant to streamline communication and encourage getting the best product decisions.
If the buyer (aka the "Santa") hasn't reviewed the price in the first order form or we don't have a date attached to the promise(s), then we're not ready for this call.
On the order form, customer promises are represented as customer request issues and not user stories.
Participants: AE or CSM, SC, CEO, CTO, VP of Customer Success, Head of Product Design, and relevant EM (+ temporarily: CRO).
Agenda:
- Review each proposed customer promise on the order form.
- For each customer request, create user stories and T-shirt size them.- If necessary, the EM takes up to 1 business day to gather information necessary to T-shirt size.
 
- Review the release planning roadmap to determine available capacity in upcoming releases.
- Decide which Fleet release can be targeted for each customer promise.
- Update the order form to reflect targeted date of each release.
Development best practices
- Remember the user. What would you do if you saw that error message? 🔴
- Communicate any blockers ASAP in your group Slack channel or standup. 🟠
- Think fast and iterate. 🟢
- If it probably works, assume it's still broken. Assume it's your fault. 🔵
- Speak up and have short toes. Write things down to make them complete. 🟣
Product design conventions
Behind every wireframe at Fleet, there are 3 foundational design principles:
- Use-case first. Taking advantage of top-level features vs. per-platform options allows us to take advantage of similarities and avoid having two different ways to configure the same thing. Start off cross-platform for every option, setting, and feature. If we prove it's impossible, then work backward making it platform-specific. 
- Bridge the gap. Implement enough help text, links, guides, gifs, etc that a reasonably persistent human being can figure it out just by trying to use the UI. Even if that means we have fewer features or slightly lower granularity (we can iterate and add more granularity later), make it easy enough to understand. Whether they're experienced Mac admins people or career Windows folks (even if someone has never used a Windows tool) they should "get it". 
- Control the noise. Bring the needs surface level, tuck away things you don't need by default (when possible, given time). For example, hide Windows controls if there are no Windows devices (based on number of Windows hosts). 
Scrum at Fleet
Fleet product groups employ scrum, an agile methodology, as a core practice in software development. This process is designed around sprints, which last three weeks to align with our release cadence.
New tickets are estimated, specified, and prioritized on the roadmap:
Scrum items
Our scrum boards are exclusively composed of four types of scrum items:
- User stories: These are simple and concise descriptions of features or requirements from the user's perspective, marked with the - storylabel. They keep our focus on delivering value to our customers.
- Sub-tasks: These smaller, more manageable tasks contribute to the completion of a larger user story. Sub-tasks are labeled as - ~sub-taskand enable us to break down complex tasks into more detailed and easier-to-estimate work units. Sub-tasks are always assigned to exactly one user story.
- Timeboxes: Tasks that are specified to complete within a pre-defined amount of time are marked with the - ~timeboxlabel. Timeboxes are research or investigation tasks necessary to move a prioritized user story forward, sometimes called "spikes" in scrum methodology. We use the term "timebox" because it better communicates its purpose. Timeboxes are always assigned to exactly one user story.
- Bugs: Representing errors or flaws that result in incorrect or unexpected outcomes, bugs are marked with the - buglabel. Like user stories and sub-tasks, bugs are documented, prioritized, and addressed during a sprint.
Our sprint boards do not accommodate any other type of ticket. By strictly adhering to these four types of scrum items, we maintain an organized and focused workflow that consistently adds value for our users.
Sprints
Sprints align with Fleet's 3-week release cycle.
On the first day of each release, all estimated issues are moved into the relevant section of the new "Release" board, which has a kanban view per group.
Sprints are managed in GitHub Projects.
Sprint numbering
Sprints are numbered according to the release version. For example, for the sprint ending on June 30th, 2023, on which date we expect to release Fleet v4.34, the sprint is called the 4.34 sprint.
Sprint ceremonies
See the rituals contributor docs for detailed instructions on running each ceremony.
Each sprint is marked by five essential ceremonies:
- Sprint kickoff: On the first day of the sprint, the team, along with stakeholders, selects issues from the 🦢 Drafting board to work on. To move issues to the sprint board, add :releaseand the product group label (#g-mdm,#g-orchestration,#g-software,#g-security-compliance) and remove the 🦢 Drafting project. The team then commits to completing these items within the sprint.
- Daily standup: Every day, the team convenes for updates. During this session, each team member shares what they accomplished since the last standup, their plans until the next meeting, and any blockers they are experiencing. The team briefly reviews the bug Inbox to identify any bugs ready to move forward or that need a QA engineer assigned, the goal is that these bugs are timeboxed for 30m-1hr to reproduce or ask for additional details. Standups should last no longer than fifteen minutes. If additional discussion is necessary, it takes place after the standup with only the required participants.
- Weekly estimation sessions: The team estimates backlog items once a week (three times per sprint). These sessions help to schedule work completion and align the roadmap with business needs. They also provide estimated work units for upcoming sprints. The EM is responsible for the point values assigned to each item and ensures they are as realistic as possible.
- Scrum of scrums: Each product group's Tech Lead, and optionally the EMs, meet once per sprint. This is a coordination technique used to scale scrum for multiple teams working on a large, complex product by having representatives from each team meet regularly to share progress, discuss dependencies, and solve inter-team issues.
- Sprint demo: On the last day of each sprint, all engineering teams and stakeholders come together to review the next release. Engineers are allotted 3-10 minutes to showcase features, improvements, and bug fixes they have contributed to the upcoming release. We focus on changes that can be demoed live and avoid overly technical details so the presentation is accessible to everyone. Features should show what is capable and bugs should identify how this might have impacted existing customers and how this resolution fixed that. (These meetings are recorded and posted publicly to YouTube or other platforms, so participants should avoid mentioning customer names. For example, instead of "Fastly", you can say "a publicly-traded hosting company", or use the customer's codename.)
- Sprint retrospective: Also held on the last day of the sprint, this meeting encourages discussions among the team and stakeholders around three key areas: what went well, what could have been better, and what the team learned during the sprint.
Outside contributions
Anyone can contribute at Fleet, from inside or outside the company. Since contributors from the wider community don't receive a paycheck from Fleet, they work on whatever they want.
Many open source contributions that start as a small, seemingly innocuous pull request come with lots of additional unplanned work down the road: unforeseen side effects, documentation, testing, potential breaking changes, database migrations, and more.
Thus, to ensure consistency, completeness, and secure development practices, no matter where a contribution comes from, Fleet will still follow the standard process for drafting a feature when it comes from the community.
Stubs
The following stubs are included only to make links backward compatible
Endpoint ops group
Please see handbook/company/product-groups/orchestration
Air guitar
Please see handbook/company/initiate-an-air-guitar-session
High priority user stories and bugs
Please see handbook/company/communications/high-priority-user-stories-and-bugs
 
               
                 
                  
 
                           
                           
                           
                           
                           
                           
                           
                           
                           
                           
                           
                           
                           
           
             
                
 Back to top
Back to top 
                   SOC2 Type 2
SOC2 Type 2 
                 
                 
                 
                 
                 
                 
                