Phase 0: What should happen before product development

“How should we get started?” is a question we got used to listening to.

“Let’s find out together!” is the answer we got used to answering.

There’s no magic recipe in Product Development. Each business strives in different circumstances, and quality is about making the best out of each context. That’s why, when potential clients knock on Pixelmatters’ door and want to start fast, they hear many questions from us first.

Without understanding the business and the current Product, going fast will lead to a dead-end street. For a product to succeed, we should play for the long run by starting small and iterating quickly. That’s why Phase 0 is essential.

What happens in Phase 0?

From a few days to a couple of months, it will role out a bit like a Sherlock Holmes movie. There’s a mystery to solve — where should we start here?

To determine what should be worked on first, we begin by assigning a smaller cross-functional team consisting of a Product Owner, a Designer, and an Engineer - probably constituted by senior people across the company - that may or may not be a part of the team later on. Depending on the context, this smaller cross-functional team constitution may vary, and we may have other senior roles involved for a short period of time. The rest of the team joins later once there’s a defined path for what’s ahead in the coming weeks/months — for example, the remaining Engineers that were not a part of Phase 0.

In parallel to determining priorities with this team, we kick off another part of Phase 0 — clarifying the path and building alignment with the client. The rest of the team that will build the Product - isn’t involved at this point because of efficiency - the goal is to onboard them once the plan is clearer. After all, Sherlock Holmes only has Watson by his side the entire time for a reason - too many people would only slow him down in such an exploratory phase.

As the purpose of Phase 0 is to build alignment on what can be a potential MVP or initial iteration, the first step is to understand the following:

At this stage, the Product Owner often leads the efforts in close collaboration with peers from Design and Engineering as they’re still identifying the main opportunities and planning the initial requirements. It’s also a period of divergence where multiple ideas and alternatives are discussed. After all, this is a collaboration, and clients expect to hear our advice on how to move forward! 🚀

Once there is a high-level understanding of the business, the Product, and the main goals are identified, it’s time to get our hands dirty and start converging.

From first conversations to groundwork

This is where Design and Engineering take over, collaborating with each other and with the Product as we dig deeper into what’s needed before the rest of the team that will be a part of the project joins.

The work we do here can take many shapes and forms depending on what comes out of the first conversations - the most common scenarios are:

  1. The client knows the direction and the potential solutions, and Phase 0 is used to craft a couple of ways to get there;
  2. The client doesn’t know the direction or potential solutions but knows the problem at hand and needs our help during Phase 0.

We might adapt the depth and focus of our work depending on the scenario, but our necessity to understand the user needs from a technological standpoint doesn’t change.

A few exercises we can conduct on the Design side:

On the Engineering side, the focus relies mainly on making the first critical decisions to get things going:

Conclusion

The initial discovery stage is crucial to success in a Sherlock Holmes mystery. The same applies to Product Development. Phase 0 gives us the necessary context to fully understand the Product, align expectations, and define the initial working points. Investing in this Phase 0 will allow us to position ourselves better to help you solve the essential mysteries that stand in the way of growing your business.

Bruno Teixeira
Head of Product