Say Yes to Technical Debt
Technical Debt is usually referred to as something Bad. Most articles on the topic are about how to get rid of technical debt. Having been influenced by such articles, I shunned hacks, features that were poorly designed or features without much test coverage. However, I have been thinking quite the opposite recently. Is debt bad? What effect would the technical debt have on future development projects? How will it affect related features and tasks? If this is a peripheral feature that is not likely to be used in the coming months, maybe a technical debt is okay, and I could use the extra time to move the product further.
Think of technical debt as anything about your code that slows you down over the long term. Hard-to-read code, lack of test automation, duplication, tangled dependencies.
"What is technical debt?" Technical debt is hard to explain, but a picture is worth a thousand words. #programming #softwaredevelopment pic.twitter.com/AG2L3VDuKZ
— Jedd Ahyoung (@Jedd_Ahyoung) January 31, 2017
After Playment launched its annotation platform, we set out to build an onboarding tool for our platform so that we could mitigate the number of users that were dropping off after signups. Product owner wanted us to build a simple onboarding experience for the first time web users. They wanted us to ship the feature real quick so that they could test & iterate over it. We built a quick & dirty feature that required a developer's help to set up the onboarding flow, but it worked. The feature was poorly designed, not very extendible & had few test cases. After having released the feature, we could see that many users were now completing the onboarding flow, earning few bucks & continued to do other tasks on our Platform. The code ended up being untouched for over 6 months till we decided to extend the feature into onboarding experience for projects.
Sample onboarding flow
However, when we wanted to continue the product line we realised it was good that we left it half done because what we intend to do now over the same feature happened to be a much better thing than what we thought we would do, which wasn't possible in hindsight at all. It was right for us to have taken the quick & dirty approach to problem-solving rather than the correct & tedious one.
Technical debt is bad, but (more often than not) optimal.
— Paul Graham (@paulg) April 21, 2017
As developers, we are quick to attacking a problem & trying to find the right approach. We try to cover cases that would likely not arise or if they do they probably far out in the future. At least, this is the truth for most startups. Sure that database query would break if there were 1M entries users, But we probably need to make lot more features so that we can reach that 1M mark.
Tech debt stinks, it slows down development & creates quality issues. It can have a negative impact when scaling up. Refactoring code to reduce tech debt is painful & resource distraction.
At Playment, lead-engineers try to keep a track of tech debt, classify easy fixes to fundamental architecture design flaws. A small percentage of engineering effort goes into lessening tech debt every release. We strive to set expectations that refactoring is part of our job, showcasing excellent refactoring(eg: small demo of the code). At times its fun & feels great after removing large amount dead code.
Tech debt is often a "damned if you do, damned if you don't" problem.
- Survival to Thrival
There is a time and a place to reduce technical debt, but it’s not as crucial as most engineers think.