---
title: Tail Your Test Logs
teaser: How to get the most information out of your Rails logs.
tags: web,ruby,testing,unix
author: Dan Croak
published_on: 2009-09-09
---

Rails' logs contain valuable information. You've probably seen output like the
following:

    Processing PagesController#show (for 127.0.0.1 at 2009-09-09 19:07:29) [GET]
      Parameters: {"id"=>"about"}
    Rendering template within layouts/narrow
    Rendering pages/about
    Rendered shared/_navigation (2.7ms)
    Rendered shared/_flashes (0.8ms)
    Rendered shared/_javascript (1.2ms)
    Completed in 28ms (View: 21, DB: 0) | 200 OK [http://localhost/]

In my case, I ran `script/server`. If you're running Passenger, you might run:

    tail -f log/development.log

## Tail your test log

If I do not understand a functional test failure, I run my tests in one shell
and tail my test log in another. Usually, I'm checking to make sure the
params are correct.

    tail -f log/test.log

## Tail your Cucumber log

[Cucumber](http://cukes.info) is pretty cool. One downside is lack of
information in the backtrace. You can find out more by tailing the log!

    tail -f log/cucumber.log

## There's a lot going on, isn't there

Watching test logs, especially in the Test::Unit/Shoulda world, reminds me:

* how much of the stack gets executed in functional tests
* the quieting, focusing effect that stubbing and spying can have
* stubbing and spying aren't enough when you have to worry about what is
  happening in the view during your functional tests
