fbpx
Categories
Technical Debt

Managing technical debt

What is technical debt?

In simple terms, technical debt can be described as time borrowed when writing software.

In other words, we incur technical debt to save time now that we will be paying back in the future.

There are many reasons why we might incur technical debt, and when you are deciding, it will feel like the right choice, and it often is.

Just remember that incurring technical debt is usually a business decision, not a technical one.

Here a few examples of what I am talking about

  • We decide to use an open-source library instead of writing our own code… because we can get to market faster this way.
  • When building an MVP, we don’t spend a lot of time making our code scalable…. because we might not get the traction we expect.
  • you build a non-ADA compliant application… because your clients are not asking for it, yet.
  • You see an improvement, but your boss is pushing hard to meet the deadline, so you open a ticket and hope to get to it later… because, well, deadlines!

Types of technical debt

Technical debt has many shapes, the most common ones to engineers are probably new bugs, code smells, and other code metrics.

The reality, however, is that technical debt is much more complex than that.

Would you consider a lack of documentation as technical debt? (hint: you should).

What about no unit test coverage? is that technical debt? yes, yes it is.

For your purposes, you will need to come up with a good definition of what you consider to be technical debt.

If you are coming up with only a few things on your list, I recommend that you take a look at the presentation titled “Towards an Ontology of Terms on Technical Debt” by the Software Engineering Institute at Carnegie Mellon University.

Their list should work as a good starting point to identify technical debt within your organization.

Should you pay it off?

Now that you know what it is, and you can categorize it, what is the next step?

Well, now you figure out how much of it you pay down. Remember how I mentioned that incurring technical debt is usually a business decision and not a technical one? guess what, paying it down is a business decision as well.

In our case, as engineers dealing with technical debt, we can make a very good business case for spending engineering time paying down technical debt.

Take for example the MVP app we mentioned above. Since we had an aggressive time to market, we pushed hard and got the application out on time.

In the process, lots of things could have been better, but we knowingly incurred technical debt just to get the application out.

Now your user base is growing and your metrics are showing slowdowns in some areas of the application, nothing major yet, but since you are a responsible engineer, you mention it to your product manager, your manager, and your fellow engineers.

You are asked to look at how much work it would be to make the experience better, and you come up with about 6 weeks of work. (did you use our estimation guide, go ahead, take a look, we’ll wait)

While doing the work makes a lot of sense from the technical perspective, after all, we know our application can be better and we know exactly how to get there.

From a business perspective, the story is a different one. Those 6 weeks could mean a lot of positive or negative things such as

  • Missed deadlines for other projects
  • Going over budget
  • Broken promises

or

  • Increased application engagement
  • Renewing the unhappy client complaining about performance
  • Gaining new clients

It all depends on the business, their vision, and the return on investment perceived from paying down the technical debt.

Strive to identify technical debt early, be honest, and open about what it is and why you think it is important to pay it off.

Remember that your business counterparts will not always understand the nuances of the technical details for your proposed solution, so be nice and explain it in simple terms from a business perspective and together with your business partners decide if you will pay it down now or later.

Further reading

Technical debt is a complex topic, if you are interested in knowing more, I recommend following up by reading these great books on the topic

Great books to follow up on technical debt
Icons made by Flat Icons from www.flaticon.com
Categories
Ask a dev manager

I hate estimates, help!

Our first question of the week was more of a statement “I hate estimates, help!”

Lucky for you, there is a lot of help in this area.

let’s start by understanding why you are being asked for estimates, and then move on to some quick types of estimation you can try within your team.

Why estimates?

short answer, decision making.

long answer estimates help the company make decisions by understanding the possible return on investment for any given work.

Estimates answer questions such as

  • should we take on the work? We might not be getting our money’s worth
  • when can other work start? There is only so much you can do
  • can we meet the promise sales already made? – we all love this one
  • should we hire? There is a lot of work to be done, promises made, targets to reach… estimating is a visual input into determining if hiring is needed.
  • when will it be done? Mainly because people just want to know, it feels good to know.

now that you understand the importance, let’s move on to how you can go about simplifying your estimation process

What is your unit of measure?

When asked for an estimate, you are not being asked for story points, or a number of tickets, or engineer hours… You are being asked for a date for your changes to show up in production.

While your answer is a date, how you get to that date is another matter, and it will most likely vary based on your process

Knowing your velocity

The first step is knowing your velocity. Velocity measures the rate at which things make it to production. These “things” can be measured in different ways such as

  • The number of tickets, where all tickets look roughly the same and you count how many tickets you complete on a given period
  • Story points, usually following the Fibonacci sequence to denote relative effort and you count points for a given period
  • Ideal hours, where you are asked to throw a number of hours for development work, then measure how many of those you get through on a given period
  • T-shirt size is another relative estimation technique, where a t-shirt size directly maps to a set number of days you believe it will take to complete

Just pick one that works for you and stick to it. For the rest of this story, I’ll use the the number of tickets just to keep things simple.

Your first estimate

Following with the ticket example, let’s say you get through 10 tickets in one month, this is your velocity (Great work by the way)

You are then asked to estimate a project and after going back and forth on the details, you believe you can break it down into about 20 tickets, so you blurt out “two months”

Is that it? could it be this simple? possibly, all estimates need to have a confidence level. It might be OK to have low confidence in your estimate to begin with.

Confidence levels in estimating

Now that you said two months, are you willing to put two months from today on a contract with monetary contingencies if the date is not met?

Probably not, and the reason is that the confidence level on the estimate is low.

To increase the confidence level on the estimate, you can work your way through questions such as

  • Do I know the start date? most work is not of a “drop everything and do it now” nature. Figure out how much longer before you can start on the new project and adjust your estimate.
  • Do you know your velocity fluctuations? December is usually slow, the summer sees a lot of vacation time, there might be a seasonality to your business to account for. Use this information to update your estimate
  • Was it 20 tickets? take some time and do a Work Breakdown Structure exercise. You will probably end up with more tickets than you started with.

For more ideas on increasing the fidelity of your estimate, take a look at Software Estimation: Demystifying the Black Art (Developer Best Practices)

As a rule of thumb, when providing your estimate, be clear about the current fidelity of it.

Always ask if you should spend any time getting a better fidelity estimate.

Your time is valuable, besides, you can always point your boss to this article and have them help you out 🙂

Go for extra points

Project Software such as TeamGantt allows you to easily visualize project plans.

Go ahead plug in your start and end dates for your tickets and surprise your boss with a beautiful graph

Icons made by Eucalyp from www.flaticon.com