Refactoring Rails

This guide will show you how to refactor your code.

By referring to this guide, you will be able to:

1 Refactoring

Never be ashamed of making you code better. On the contrary: recognizing code smells in your old code means that you learnt something in the meantime. Only very inexperienced people think that the code they wrote yesterday is perfect.

Refactoring is

We will use tests to ensure that we do not change the external behavior of the code we are refactoring.

A code smell is a piece of bad code that we recognize.

Read the Ruby version of Fowlers refactoring book to learn both code smells and refactorings:

2 Code Smells

This is the list of code smells from Fields, Harvie, Fowler(2010): Refactoring, Ruby Edition. Addison-Wesley. In chapter 6 to 12 of that book they describe refactorings to handle all these problems and more:

3 Tools for Code Quality

Recognizing code that is problematic and should be refactored is one of the main skills of a developer. Often it is not a black and white situation: there might be several ways of writing a certain piece of code, each with it's own pros and cons.
A tool cannot help you make these decision.

But there is a role for tools in this process: especially when faced with a lot of code there are tools that can help you find places you should look at.

A code metric is a quantitive measure of the quality of a piece of code.

The Gem metric_fu combines some metrics. Install it in your Gemfile, and add a task-file, and run it on the command line metriy_fu. It will generate a report in tmp/metric_fu/output/.

Saikuro is a good place to start reading the report: it measures cyclomatic complexity, or how deep you nest your control structures.

See Rails Cast no 166 for a more detailed introduction to metric_fu.

Another tool to help find spots where you can improve the quality of your code is rails_best_practices. Install the gem, but don't put it in your Gemfile. Just run rails_best_practices -f html in the main directory of your app. The result will be written to ./rails_best_practices_output.html.

4 Futher Reading

/