Quickly Fix that Annoying Bug and Enjoy Your Xmas Party!

Quickly Fix that Annoying Bug and Enjoy Your Xmas Party!

Knock! Knock! Dear software development folks,

Can you feel it? The fairy Christmas air is around the corner. You already had plans for yourself, but suddenly you look around, unfixed bugs are still dancing here and there. Struggling with these uninvited guests might ruin all your mood for a cozy and joyful Christmas night.

Sadly, you can’t avoid the fact that a digital product soon or late will require a session of debugging in its development process. This is a sure thing, ‘cause we’re only human, and the problem here is not about good or bad coders, it’s about the process you follow to fix the bugs. Fixing a bug is most time-consuming when you have to revisit and check the old bugs that you thought you’d moved on from.

So, the 5 steps below are not supposed to teach you how to fix a bug, but to show you a reliable process that can help to save your time for more memorable moments, like Christmas Eve. It’s our very own ability to control how we handle issues.

#Step 1 – Replicate the bug yourself

It’d be better to take some time to replicate the bug yourself then make careful notes of the replication workflow you’ve found. This is what you need to communicate the details with your team.

It’s crucial that you have your own review of the evidence and come to a conclusion. Just like a detective proving a case or a scientist testing a theory, collecting and storing any necessary document to prove the before and after what was broken and what’s now fixed. Besides, another reason for you to not skip this step: You know your way around the codebase more clearly than your teammates do, so your angle will always be different.

If your work results in the same workflow, you will have more evidence to eliminate suspicious scenarios that zeroing in the problem. If not, you have saved your time in the long run by not looking into mechanics that aren’t part of the issue.

#Step 2 – Make sure you truly understand the problem

Assumption is the root of all mess-ups. If you rushly assume what the problem is without truly finding out about it, you’ll surely regret it later when a linked issue arises.

Once again, we’re only humans, I know it’d be hard but please try to step away from the assumptions and just interpret the issue by looking at the facts. And from here, start to match the pieces into a complete picture.

A great number of different mechanics are likely to be involved when you reproduce the bug, so it’s essential to pin down exactly the position of the issue in the code. By doing this, you’ll have a firm answer when your team asks “What was wrong? How bad is it?” This also proves your image and ability.

Although there’s a certain way of replicating the bug from a UI perspective, it isn’t supposed to always help you understand the bug. So in short, avoid running on assumption, even if it happens to be correct.

#Step 3 – Pair-programming

Sometimes things go harder than you’ve expected, if you find yourself struggling more than an hour and not making any progress, stop right there! Bring a colleague, better if you guys are working on the same project, and ask him/her to pair-program the way out of it.

Show him the bug and the process you’ve been carried on, tell him everything you’ve tried and explain to him your view and opinions about the problem. It’s research-based that we’re more likely to come out with surprising ideas while talking something through and having to explain it to someone else. So by co-working with a fellow, you’ll not only have valuable support from him but also a higher chance to bounce the ideas off your head.

At Designveloper, we’re applying this method, and we can assure you it’s totally effective.

#Step 4 – Alright, let’s start fixing

After clearing what the problem is, you and your pair-programmer can now start to work it out.

I think I don’t need to tell you how to recode a bug here, right? As I claimed above, I’m not writing this to teach an outsider how to code. So as a professional, this is the step you can totally handle on your own with your technical knowledge and practical experience. Good luck!

#Step 5 – Break your fix

Bug fixed, well done! But stay meticulous, aren’t you thinking of just pass it through like that? Most coders do the test to make sure their solution actually worked. But testing is a vague concept in itself. It can mean anything from simply proving the bug doesn’t exist anymore to retesting the whole product.

To save yourself from the confusion, let’s try to break the applied fix instead of testing it. Why? Because even with a test suite covered by 100% code, you could still miss an important scenario that could present issues. Trying to break it gives you a more explicit goal and helps you and your team bring the work beyond the limits. And from a developer perspective, you are eliminating all possible weaknesses in the product much more effectively.

To sum up

If you manage to break it, so sorry, now go back to Step 1 and try again.

If it still remained strong and stable, congrats! Now you may feel completely relaxed and continue your plan for the most wonderful time of the year.

 

Photo credits: pexels.com

Truc Thuy Minh


To view or add a comment, sign in

More articles by Hung Vo Hoang Manh

  • Git Concepts and Architecture

    Git Concepts and Architecture

    In this post, let’s examine several key concepts in Git, which will help us to better understand how it works. The…

  • 5 ways to create a logo design that kicks ass

    5 ways to create a logo design that kicks ass

    Ranging from Facebook’s iconic sky blue F to the golden M of McDonald’s, logos that perfectly represent brand…

  • 08 Leading Web Design Trends in 2019

    08 Leading Web Design Trends in 2019

    Maybe most people still don’t realize that 2019 means we’re heading to the last chapter of the decade. Over the past…

  • Farewell, Year of the Dog 2018

    Farewell, Year of the Dog 2018

    Time flies so fast, it’s already been five years since the day Designveloper (DSV) was established, sometimes it feels…

  • DSV’s Journey to the West

    DSV’s Journey to the West

    Welcome to DSV’s Journey to the West (DSV Tây Du Ký), I must inform you before you continue to read: this is not a…

  • How to Create a Basic Plugin by jQuery

    How to Create a Basic Plugin by jQuery

    jQuery is a quite small yet fast JavaScript library that consists of a number of extensible and durable features, and…

  • JavaScript from A to Z

    JavaScript from A to Z

    It is widely believed that one of the very first programming languages that almost every software programmer choose to…

  • 9 Must-be-obeyed Principles in Web Design

    9 Must-be-obeyed Principles in Web Design

    As I said in the previous blog 6 Signs It’s Time to Give Your Website an Overhaul, in this age of data overflowed…

  • The Journey to Become a Coder and How to Survive

    The Journey to Become a Coder and How to Survive

    Imagine me, an ordinary office girl, surely an outsider to codes, programming languages, frameworks, etc. Java? Python?…

  • Top Trending Programming Languages for 2019

    Top Trending Programming Languages for 2019

    I bet every software development company, as well as freelance programmer, wants to keep up with the most emerging and…

    2 Comments

Insights from the community

Others also viewed

Explore topics