Question Page

How do you plan releases? What development methodology does your company follow?

Sandeep Rajan
Patreon Product Lead, Member ExperienceFebruary 22

We leave it to each team to figure out what helps them balance flexibility with clarity to achieve their maximum speed of execution. 

We do our best to have a common language around goals, strategy & measuring progress, but largely leave it to teams to figure out how best to build & ship given their own goals, strategies & roadmap. 

1058 Views
Jacqueline Porter
GitLab Director of Product ManagementNovember 22

Releases can be separate from when the product is made available to customers. Some times, people think of product launches and software releases as needing to be tied together, but in order to maintain agile development and ensure market readinesss, it makes sense to time releases for when your customers will be ready to consume those resources. Typically, I think of planning product launches in these ways:

  1. Customer market readiness - when does the customer need this feature for their workflow?

  2. Monetization - is this feature a driver of revenue for my business? Upsell or licenses? Subscription?

  3. Competitive landscape - are we going to be first to market?

After looking at these dimensions, I will then plan with counterparts like marketing, engineering, and design to ensure we have the proper assets in place for proper releases.

For GitLab's release process check out our handbook: https://about.gitlab.com/handbook/engineering/deployments-and-releases/

332 Views
Sheila Hara
Barracuda Networks Sr. Director, Product ManagementApril 30

Barracuda has a structured approach that blends continuous integration and delivery (CI/CD) with Agile methodologies, using specific release timelines. This setup can offer several advantages, especially in managing complex software development and deployment processes effectively. Here’s a breakdown of how this approach might typically work and how it can be optimized:

  1. Agile Practices: We organize our development activities into sprints, each lasting about 2 weeks. These sprints include regular sprint planning, daily standups, sprint reviews, and retrospectives to ensure continuous improvement and alignment within the team.

  2. Continuous Integration and Delivery: Our CI/CD practices are integral to our development process. Developers commit changes to a shared repository frequently, which triggers automated builds and tests. This helps us maintain a high standard of code quality and ensures that our software can be released at any time.

  3. Release Management: While our CI/CD pipeline keeps our software in a releasable state after each integration, the 2 week release pockets allow us to bundle features into coherent releases. This period also provides time for additional testing, final adjustments, and preparation of release documentation and marketing materials.

  4. Feedback Loops: We heavily rely on feedback from these iterative processes and user input post-release to refine and improve our products. This feedback is crucial for adapting our processes and product offerings to better meet user needs.

411 Views
Abhiroop Basu
Square Product ManagerMay 14

Release planning requires 5 things:

  • Define the goals of the project. What outcomes are you hoping to achieve? Clearly articulate your success metrics

  • Understand your customer needs. Conduct qualitative (surveys, interviews, etc) as well as quantitative (funnel analysis, engagement metrics, etc) research to better understand what you should build.

  • Prioritize your roadmap. Create a roadmap and use a prioritization framework (RICE, Kano) to create your roadmap. Next break down the large scale vision into smaller chunks. Each release should ideally take 2-4 weeks.

  • Launch your first MVP. Use this as an opportunity to gather customer feedback and learn what's missing.

  • Iterate. Continue launching and refining until you reach your targeted goal!

400 Views