Logo

dev-resources.site

for different kinds of informations.

8 Things I've Learned Working in a Legacy Codebase

Published at
9/16/2021
Categories
webdev
codenewbie
lessons
todayilearned
Author
abbeyperini
Author
11 person written this
abbeyperini
open
8 Things I've Learned Working in a Legacy Codebase

My first dev job threw me into a huge legacy codebase. My last big ticket involved getting a modern library to work within the deprecated UI framework it uses. After that journey, I wanted to share some tips I've learned along the way.

(1) Learn the codebase by fixing bugs.

A cockroach sits at a table in the Krusty Krab, happily eating a Krabby Patty
Ideally your company will have good documentation, but often legacy codebases are the ones that used to be maintained by that one developer who left. Reading through the entire codebase to get up to speed may be nigh impossible. I've found fixing bugs is a great way to get to know your app's "personality" while getting more familiar with its workflows. Even just reading backlog tickets gives you an idea of the company's priorities, abbreviations, and what the users want fixed.

(2) Tutorials and reference materials may be hard to find.

This is especially true if any of the packages, libraries, or tools in the codebase have been deprecated. Get familiar with the versions of what you have installed. Include the version in your Googling. Even if you can find tutorials, your app may be written in a different design pattern. Plus, a lot of tutorials act like the app is built around the tool they're demonstrating. Getting something to work inside an established, opinionated app is a whole new ballgame. Don't be afraid to try literally any idea that occurs to you.

(3) You'll want to lean on people who have more experience with the app.

This doesn't just mean other devs. QA, data science, and project managers who have worked on the app for years will know things that will help you immensely. When I get stuck trying to find where a bug is coming from, I'll often ask them "Is there a workflow that could affect this that I'm missing?" Sometimes, knowing how a feature was implemented will give you an idea of why a bug has only started happening now, was just reported, or not a priority to fix.

(4) Always check to see if someone has solved the problem previously before writing a whole new way to solve it.

Lean on utilities and code previously written. If you're not adding in a new type of data, the interactions with the database you're trying to implement probably already exist. Don't forget to look at workflows outside of the one you're currently trying to fix. Previous developers were only looking at their tickets not yours.

(5) Try not to ever duplicate code.

Get familiar with your codebase's utilities and import methods so you can use the already written code you need anywhere in the codebase. No need to add complexity or have to change things in multiple places. A legacy codebase that has already had plenty of developers on it probably has more than one example of both. Plus, they may have known about a quirk in the system you don't.

(6) On the flip side, lots of utilities means lots of abstraction.

A seagull and crab discuss the crab's mysterious journey in a small row boat, ending with
Source: http://www.poorlydrawnlines.com/comic/your-story/

Functions that rely on the established utilities can become very dense to read from start to finish. It's ok to only have a high level understanding of what a utility does. If you ever need to implement it in another place or something has gone horribly wrong within it, that's the time to dig deep into how it works.

(7) If you don't have an answer for how you'd improve it, don't complain about it.

You don't know the time constraints that developer was under or if they were told to go in a direction they didn't personally agree with. If you do have an answer, discuss with your team whether that's a priority you can dedicate time to. If it's a small ticket or something you can break into small tickets, you can use those passion projects as rewards for completing the bugs that really challenged you or didn't challenge you at all.

(8) "Let's limit the scope of this." is your new motto.

You want to try to affect as few workflows as possible. A legacy codebase is usually pretty stable and something people are counting on to work. Sweeping reform is tempting, but often your job is just to patch up the small holes.

lessons Article's
30 articles in total
Favicon
Career Lessons Learned from Mistakes
Favicon
International drivers license Italy
Favicon
Discover Top Drumkit Lessons with Expert Drumkit Teacher in Brisbane
Favicon
20 things i wish i learned before college
Favicon
Worst Hire - my lessons
Favicon
Lessons That Forever Changes My Software Engineering Career
Favicon
The Single Most Important Lesson I’ve Learned Working As A Software Engineer For 5+ Years
Favicon
Exploring the Universe: How Cosmic Perspectives Unlock the Secrets of Life
Favicon
I built a tech startup and it failed. This is what I learned. 1/3
Favicon
6 lessons from a technical founder
Favicon
CTO last day: reflections, mistakes, and some learnings
Favicon
Things I learned.
Favicon
Lessons from a student hackathon
Favicon
8 Things I've Learned Working in a Legacy Codebase
Favicon
Lessons I have learnt from Project Management
Favicon
What I learned from CREATIVITY, PIXAR Director's Book
Favicon
My non-dev side project got me 700 subscribers & 4000+ traffic
Favicon
Hacktoberfest 2020: Lessons learned as Maintainer
Favicon
I fell through my bed the other day
Favicon
3 lessons from 3 years on joining startups as a Software Engineer
Favicon
Lessons learnt in year three as a software engineer
Favicon
That blank stare
Favicon
6 Lessons learned from upgrading a Rails app
Favicon
Lessons learned from surviving an application attack
Favicon
Things I’ve learned in a skeleton crew
Favicon
5 lessons I've learned during my first year as a Software Engineer
Favicon
Remove a commit from history in Git – local and remote
Favicon
7 years as a developer - lessons learned
Favicon
If you want to ship a side project, start with unlearning the best practices
Favicon
2018 FIFA World Cup: Three Key Lessons for Web and Mobile Developers

Featured ones: