How Developers Can Answer the Dreaded Question: "When Will This Be Done?"
February 10, 2020

Adam Scroggin
CardBoard

Two of the most daunting questions software engineers often hear are: "when will this be done?" and "how much will this cost?" Project managers and clients need to know these answers, but developers don't usually work in the same way where they can deliver certain answers to those questions. They often provide their best guess to those questions, only for the client to be disappointed when the project runs long or costs more than expected. But there is a better approach to budgeting for product updates: user story mapping and forecasting. 

User story mapping is a way for product managers, developers and designers to put structure around product design and create an excellent user experience (UX).

If you are approaching a new product update and need to plan ahead, here are the steps to take.

Step 1. Figure out what you know and what you don't

When first starting a project, have the necessary conversations to get all of the information you can from the client, or whoever is making the request. Ask as many questions as you can to understand goals and expectations. Find out what concerns they have, what their vision for the platform is, and anything else that could be important in the development process. It's fine if there are still some unknowns at this level of the process. 

Step 2. Build a User Story Map

After you have all of the information collected, start building out a user story map. This is a great way to visualize the roadmap of the work you'll have to do. This allows you to break down the product into manageable chunks and not get caught up in the small details. You'll want to include all the different stories and different personas using the product in this map. Then, outline each screen that needs to be 

Step 3. Assign values to your User Story Map

It is common in software development to either use effort estimates (hours/days) or story points to estimate work once it's broken down into a plan. But there could be other approaches that work better for your team. 

■ T-shirt sizing: look at each task and assign an estimation value. For example: small, medium and large. This is a great way to simplify without numbers. Instead, each task gets a size based on how it compares to the other tasks. 

■ Counts: assume each task is roughly the same size. So you count the total number of tasks and multiply by some factor to get the estimate. The reality is a majority of products will average out to a certain number with a little variance if you can break them down into understandable pieces of work.

Step 4. Time to forecast

Now it is time to forecast. This can be done using several different tools, but your best bet is one that runs Monte Carlo simulations to provide a date range of when you will be done and assigns a certainty to each date.

To begin your forecast, start with some key metrics:

■ Start date - when you think you'll begin

■ Low guess - count the number of stories in your user story map

■ High guess - include a contingency for rework, bugs, and risk that materializes

■ How many days are in your sprints? 

■ A low and high guess for how many stories you will get done in a sprint

After you enter this data, the tool can run simulations of the project and collect the different outcomes. You will end up with a histogram of the number of times a simulation finishes on a particular date. You will also get a table with the likelihood of the project finishing on a specific date. This table is a great asset to have when asked that dreaded question: "When will you be finished?" 

Now you have something to budget and plan for. Keep in mind that it's always best to under-promise and over-deliver, so give conservative estimates. We all know things come up in software development, and sometimes things get off track, but forecasting tools take this into account. Your team can continue to update your user story map as you learn more and feed that information into your forecasting tool. 

Just like weather forecasts change, forecasting for your software project will change. Don't give a single date from the onset. Instead, provide a range and update it as things change. Keep the team informed by communicating your forecast. Once your customer has an estimate, you can get to work on the fun stuff — developing the product. 

Adam Scroggin is CEO of CardBoard
Share this

Industry News

February 29, 2024

ManageEngine, the enterprise IT management division of Zoho Corporation, announced the integration between Endpoint Central, its flagship unified endpoint management solution, and Check Point's Harmony Mobile, a leading mobile threat defense solution, to help IT security teams automate the remediation of mobile threats.

February 29, 2024

Stack Overflow and Google Cloud announced a strategic partnership that will deliver new gen AI-powered capabilities to developers through the Stack Overflow platform, Google Cloud Console, and Gemini for Google Cloud.

February 29, 2024

The Cloud Native Computing Foundation® (CNCF®), which builds sustainable ecosystems for cloud native software, announced the graduation of Falco, a cloud native security tool designed for Linux systems and the de facto Kubernetes threat detection engine.

February 28, 2024

JFrog announced a new technology integration with Qwak, a fully managed ML Platform, that brings machine learning models alongside traditional software development processes to streamline, accelerate, and scale the secure delivery of ML applications.

February 28, 2024

ServiceNow, Hugging Face, and NVIDIA, announced the release of StarCoder2, a family of open‑access large language models (LLMs) for code generation that sets new standards for performance, transparency, and cost‑effectiveness.

February 28, 2024

GMO GlobalSign announced the availability of an Issuer for Kubernetes cert-manager.

February 27, 2024

MacStadium announced the launch of its online community to deepen the connections of application developers through knowledge sharing and collaboration.

February 27, 2024

Octopus Deploy announced the acquisition of Codefresh Inc.

February 26, 2024

Intel announced its new Edge Platform, a modular, open software platform enabling enterprises to develop, deploy, run, secure, and manage edge and AI applications at scale with cloud-like simplicity.

February 26, 2024

Tray.io announced AI-augmented API Management, a new Tray Universal Automation Cloud capability that turns any new or existing workflow into a reusable API, significantly decreasing the technical debt associated with the operational effort and costs of traditional API management (APIM).

February 26, 2024

Bitwarden Secrets Manager is now integrated with Ansible Playbook.

February 22, 2024

Check Point® Software Technologies Ltd. introduces Check Point Quantum Force series: an innovative lineup of ten high-performance firewalls designed to meet and exceed the stringent security demands of enterprise data centers, network perimeters, campuses, and businesses of all dimensions.

February 22, 2024

Tabnine announced that Tabnine Chat — the enterprise-grade, code-centric chat application that allows developers to interact with Tabnine AI models using natural language — is now available to all users.

February 22, 2024

Avaamo released Avaamo LLaMB™, a new low-code framework for building generative AI applications in the enterprise safely, securely, and fast.

February 21, 2024

CAST announced the winter release of CAST Imaging, an imaging system for software applications, with significant user experience (UX) enhancements and new features designed to simplify and accelerate processes for engineers who develop, maintain, modernize, complex software applications.