A Comprehensive Guide To Debugging Rails

Feedback systems for finding errors in your web application.

The most important tool a musician owns is not their instrument; it's their mirror. Observable physical issues precede degradations in sound, and the saxophonist practicing "blind" may never notice that a misplacement of their thumb over a key caused the grating tone that has tormented them - and their neighbours - for months.

Code problem identification, which is the essence of debugging, benefits similarly from the use of observation, but its mirrors, peering instead into a software process, take the form of logs, debuggers, alerts, OS-level tools, and the instrumentation you design and insert into your codebase.

For three months I've jotted down every mirror I glance at when tending to Oxbridge Notes as part of my efforts to create documentation that will enable another programmer to take my place. This article therefore focuses on the mirrors available to a programmer like me, a web developer working with legacy code in Ruby on Rails, Javascript, Git, OS X, and Heroku. The specifics differ to the extent that your stack deviates from mine, but any web developer should find some measure of value in these techniques.

I've marked the sections I believe contain the information least often seen in other similar guides.

I'd like to credit Ed Tee at GigSounder and Richard Conway for help with proof-reading and feedback, and to thank Hacker Retreat Berlin for providing me with brilliant programming mentors and teachers.


More Articles: Click here for full archive

Introduction to Paid Advertising

Where I try to convince you that advertising isn't always an annoyance (and that you shouldn't be afraid of ad blockers)


Email Marketing

The relevant laws, some growth-hackery tips, and suggestions about good emails to send


Why Bother With Cucumber Testing?

The disadvantages of using Cucumber and its widespread use as a poor man's integration test.