Learning Center Articles Introducing Debug Trainer: Desktop Edition!

Introducing Debug Trainer: Desktop Edition!

June 23 2021

Share

Introducing Debug Trainer: Desktop Edition

Note: If you want to skip all the explanation and go straight to trying out the app, here’s the latest release page. Grab the .dmg file if you’re a Mac user, the .AppImage file if you’re on Linux, and the .msi file if you’re on Windows.

Last year, we created the debug_trainer npm package to help students practice debugging without having to wait for bugs to show up in their day-to-day programming.

The idea was that Debug Trainer would:

  1. introduce random bugs into your code
  2. give you hints about where they are and how to solve them if you get stuck
  3. remove the bugs and tell you what they were if you get really stuck so that you have an easier time spotting them in the future

The resulting program works, but as a command line program, it can be a lot for students who are new to the command line. So this year we ported the bug-making code to a desktop application, courtesy of the Tauri platform!

It’s got all the same functionality in a much nicer and easier-to-use package, plus a bunch of extra tips and hints. Check it out!

The part of the Debug Trainer app where you tell it what to do; a page asking “What file should I put the bugs in?” and “How many bugs should I put in the file?”

The main page of the Debug Trainer app; text reads “I put 3 bugs into testFile.js; can you figure out where they are?”, and then shows a set of step-by-step instructions for figuring it out.

Features

General Debugging Tips

If you’re having trouble, there’s a page with a whole bunch of general tips and tricks for debugging.

the Debug Trainer app on the “Debugging Tips” tab with a tip about printing out all of the variables in your code to make sure you know what they are

Bug-Specific Hints

If you’re want some extra info about the specific bug(s) you’re looking for; it can tell you either the type of bug (for example “I removed the word return somewhere in this file”), or the line that the bug was introduced on.

the Debug Trainer app on the “Bug Hints” tab with one hint showing that says “removed a `}` from the beginning of the line”

General Encouragement

This one may seem silly, but, hey, debugging can be stressful and demoralizing, and it was really fun to write. If you just need some general encouragement, there’s a tab for that!

the Debug Trainer app on the “Encouragement” tab with some text that says “I believe in you” with a bunch of emoji around it

Complete Explanation of the Bug(s) Once You’re Done

Whether you manage to figure them out yourself or not, at the end, Debug Trainer will give you a full explanation of every bug it introduced.

the very last part of the app, showing what all of the bugs were. In this example, the app explains that it “removed a `}` from the beginning of the line on line 3”, and shows “before” and “after” versions of line 3

Wrap-Up

That’s it! A program for getting practice debugging your own code as many times in a row as you want in a safe way without waiting for bugs to happen to you. It’s all open-source, so you can check out the code at github.com/kickstartcoding/debug_trainer_app, leave bug reports or feature requests at the GitHub issues page, and download the latest version on the latest release page (grab the .dmg file if you’re a Mac user, the .AppImage file if you’re on Linux, and the .msi file if you’re on Windows).

Hope you like it! If all goes as planned, we’ve got some posts coming to talk more about how it was working with the Tauri platform, and how the app decides what bugs to introduce under the hood. Stay tuned!

Mark Stewart

Mark is a software developer and teacher. In his work he tries to write decent code, support diversity and social justice in tech, and energetically frown at people who use the word "disruption" more than they use the word "ethical”.

Outside of work, he hikes, attempts to commit to musical instruments, feels feelings about things, and silently guesses who uses Tumblr based on their word and spelling choices.