Software Sleuthing – The Act of Being a Detective! by Prabhat Mishra on June 17, 2020 811 views

Software sleuthing or debugging is a process of investigating a problem within a computer program. Since it’s an investigation, it always starts when someone notices or reports the problem.

The problem could be an error or performance issue or it could be a functional anomaly.

For example: 

Problem #1 – A user is getting HTTP 403 Forbidden error even after providing required access permissions.

Problem #2 – A search operation at times takes more than a minute to give a response.

Problem #3 – Account balance being displayed varies from expected balance.

Note: if you are reporting a problem then make sure to include following details on the problem report

i). What were you doing?  

ii). What happened? 

iii). What you were expecting?  

iv). Other evidence like URLs, snapshots, error messages etc. 

This information gives the investigating team a good head start.

Let’s Start the Investigation:

  1. Once you receive the problem report, don’t be in a hurry to fix the problem. It’s worthwhile finding as many defects as possible and fixing them together.
  2. Analyze initial facts provided along with the problem. I would say read it multiple times.
  3. Recreate the issue using the same steps reported.
  4. Build a basic test case just recreating the issue.
  5. Run the test case and document the outcome as investigation facts. 

You might be wondering why to document the investigation facts. It has multiple benefits i) help us draw better & correct conclusions. ii) if you are leaving in the middle of investigation or someone joining you on the investigation can go through it and have a clear understanding. iii) can be produced as evidence or references in times, etc.

  1. Go through the investigation facts and draw conclusions.
  2. Expand the test cases based on our conclusion i.e to cover new suspects.
  3. Rerun test cases and document the outcomes as facts found during investigation.
  4. Repeat steps 6 to 8 until we find the root cause or narrow it down to a specific area.
  5. Once we find the root cause it’s time to think of possible quick and permanent solutions.
  6. Apply the best possible solution. Based on the urgency we may go for double rounds like apply the quickest solution first and later on go for the permanent solution.
  7. Rerun test cases to ensure the solution resolved all the problems.
  8. Once your fix moves to the dev/staging environment test using the same steps reported.

There are several debugging approaches and tools you can use during this process. Like

  • Print Debugging (or tracing)
  • Backtracking
  • Wolf Fencing
  • Incremental development
  • Problem simplification
  • Debuggers

Further Reading:

  1. http://www.cs.cornell.edu/courses/cs312/2006fa/lectures/lec26.html
  2. https://opendsa-server.cs.vt.edu/ODSA/Books/Everything/html/debugmethods.html
  3. http://www.itu.dk/people/slauesen/Papers/DebuggingTechniques.pdf
  4. https://www.pembinatrails.ca/WhatWeOffer/SafetyHealthandEnvironment/Safety/Accident-Reporting/Pages/Accident-Investigations.aspx

Postgresql Incremental Backup Improve Machine Learning Binary Classification using Boosting

About Author

Prabhat Mishra

Senior Developer and Tech Specialist

Prabhat Mishra – a senior developer and tech specialist, always quests for innovative ways to improve productivity and quality in his role. He holds a Master's degree in Computer Applications along with years of robust experience in Micro Services development & implementing the best business values with high quality standards. He believes that “Before software can be reusable, it has to be usable”. With a knack for technology, he persistently works towards upgrading his designing, architectural and software engineering skills.