Earlier this week I shared that I’m beginning a new software project with two main objectives:

  • I want to create a software service that people will use
  • I want to experiment with using new processes and technologies

I want to clarify here that I would consider even five consistent users of a service I’m supporting to be a successful project. In fact, honing in on a service tailored for five people sounds like a great initial objective. Let’s distill project objectives even further:

  • I want to create and operate a software service for five consistent users
  • Along the way, I want to experiment with new processes and technologies

Now that I’ve made my objectives even more clear, it’s time for one of my favorite pre-project rituals: the pre-mortem.

Many software projects end up going over schedule or over budget. When this happens, it’s prudent to carry out a post-mortem to look for the root causes of failure. This is helpful to avoid making the same mistakes again in the future. With the less conventional pre-mortem, we take things further by asking the same difficult questions before the project ever begins, identifying in advance the risks or obstacles that are most likely to cause the project to fail. This is usually valuable information to keep in mind as you’re executing a project.

Today I’ll kick off the project pre-mortem by asking, what does failure look like for this project? I can quickly envision a few different ways that this project might fail:

  • I could spend too much time building a service that no one will use
  • I could fail to find any idea for a service that people will use
  • I could fail to deliver on a validated idea
  • I could fail to market effectively to my niche

Already this is interesting. Let’s break down each of these risks.

Unproven Services

The first point is a repeat of the conversation we had in the last update about unvalidated assumptions. It’s unfortunately quite common for software entrepreneurs to start their journey by investing time into building a product, only then to begin searching for customers willing to pay for it. My goal to build a user base of five consistent users will be difficult to accomplish if I spend time building something that no one will consistently use.

I can mitigate this risk by refusing to define a product up front. I’ll focus the vast majority of my early energy on this project on understanding the needs of niche markets and validating service ideas. Through performing experiments and collecting feedback, I can force each idea to stand on its own before investing undue time and energy into making it a reality.

I might simply never strike gold (at least, gold for at least five people). Is this really possible though? Although the search will likely be discouraging at times, it simply doesn’t seem possible for sustained effort to come up completely fruitless. There are certainly myriad unsolved problems and underserved niche markets in existence. I need to keep this in mind any time that I feel set back or overwhelmed.

Exploding Scope

Another very likely culprit if this project were to fail would be to take on more work than I can feasibly deliver. Engineers in general are notorious for underestimating how much effort it will take to accomplish creative technical tasks.

In my experience, the solution to this problem has been a combination of iteration, realism, and ruthless prioritization. I want to pare the scope of a deliverable down to the absolute minimum amount of work required to be successful so that I have enough time to deliver on it with a high standard of quality. As my loving wife often says, anything worth doing is worth doing right.

As I’m planning my work over the course of the project, I need to be careful not to build more than what is necessary. Each new feature should be aggressively compared with alternatives to ensure that I’m always performing the most valuable work at any given time. In this way, I can ensure that I’m continuously driving towards the primary goal of serving real users without deviating.

Missing the Market

To successfully onboard users, I need to establish an effective channel of communication tailored specifically to my niche. I can create an incredible product for a willing market, but if I can’t find them, or if I fail to communicate the value of my service in a convincing way, then my project will fail.

It’s useful to have access to a starter audience that I can continue to grow, but there’s no guarantee that I’ll land on this niche. Whenever I’m evaluating a market, I need to look for any channels available to communicate with its members. When designing a software product, I need to consider how to effectively communicate its value to the target market.

Pre-Mortem Results

From this shortlist, I can derive four keys to my project’s success:

  • Validating every idea and assumption to avoid wasting time
  • Minimizing scope and aggressively prioritizing to avoid wasting time
  • Staying determined when the search for value is difficult
  • Considering plans for marketing before committing to development

It’s clearly important that we use words like “spend” and “invest” when we’re discussing time, as time is by far our most precious and limited resource.

I mentioned in the last update that I plan to begin by exploring a niche roleplaying market where I already have an audience. My next steps will revolve around market research, taking ideas from many sources and experiences into account. One in particular, the book A Playful Production Process by Richard Lemarchand, aligns well with my keys to project success and outlines a process for prototyping games that I’ll break down in the next update.