DEV Community

Cover image for Rails Coverage Tools: Coverband
Andrew Mason
Andrew Mason

Posted on • Updated on • Originally published at andrewm.codes

Rails Coverage Tools: Coverband

Coverband

According to their documentation, Coverband is:

A gem to measure production code usage, showing a counter for the number of times each line of code that is executed. Coverband allows easy configuration to collect and report on production code usage. (...) The primary goal of Coverband is giving deep insight into your production runtime usage of your application code, while having the least impact on performance possible

TL;DR

Coverband gives you insights into what code is being loaded in your Rails application, which you can also think of as code that is being used by the application. This can be a very useful tool for refactoring, and removing code that is no longer used or needed.

Demo

I will be working from this repo. You can look through that code, or you can follow along by using my Rails app template I used to create this project.

The rest of the tutorial will assume you already have a functioning Rails app!

Installation

Add the Coverband gem to your Gemfile. I personally decided to keep it in my development group, because I didn't see any value in having the dashboard available in production.

# Gemfile

gem "coverband", group: :development

# or

group :development do
  gem "coverband"
end
Enter fullscreen mode Exit fullscreen mode

Then run:

bundle install
Enter fullscreen mode Exit fullscreen mode

Configuration

Redis

Coverband stores coverage data in Redis. According to the documentation, the Redis endpoint is looked for in this order:

ENV['COVERBAND_REDIS_URL']
ENV['REDIS_URL']
localhost
Enter fullscreen mode Exit fullscreen mode

You can also specifically set this in a Coverband initializer file. If you are using the template that I’m using then you should be all set, otherwise make sure you are running Redis locally, bundle the redis gem, and your app can access it.

Initializer

Let's configure the gem. Create an initializer file for Coverband, which should look like the following:

# config/coverband.rb

Coverband.configure do |config|
  config.ignore += ["config/application.rb",
                    "config/boot.rb",
                    "config/puma.rb",
                    "bin/*",
                    "config/environments/*",
                    "lib/tasks/*",]
end
Enter fullscreen mode Exit fullscreen mode

These settings just tell Coverband to ignore our specified files and paths.

Route

Now, lets add a route for coverband so we can view the web dashboard:

# config/routes.rb

Rails.application.routes.draw do
  mount Coverband::Reporters::Web.new, at: "/coverband" if Rails.env.development?
end
Enter fullscreen mode Exit fullscreen mode

It is worth noting that if you are running this tool in production, you should protect this route with proper authentication.

Usage

We should be all set to see what Coverband can provide us!

Fire up the Rails server and navigate to localhost:3000/coverband

Alternatively, you can run the following Rake task and static files will be created in coverage/. I would recommend making sure this directory is added to your .gitignore.

rake coverband:coverage
Enter fullscreen mode Exit fullscreen mode

You should now be seeing is Coverband's mountable web interface to easily view Coverband reports.

coverband_1

If we click on a file with 0% coverage, you will see the following message:

This file was never loaded during app runtime or loading (or was loaded before Coverband loaded)!

Basically this mean the code inside the file has not been loaded, and therefore not used.

If we click on a file with partial coverage, you should see something like:

coverband_2

This view will highlight the lines that have been used, and those that haven't. Take care before you start ripping out code though, it's possible that you just haven't exercised that code yet.

In the posts_controller file in my example above, the code inside our new and create methods is not being used. I am going to open up the UI, and create a new post. You will notice that the coverage report looks a little different now:

coverband_3

It is important to exercise some due diligence before removing code that Coverband flags. In the example above, after some investigation I realized I in fact do not need config/spring.rb because I am not using spring in this project. This is the power of this library, the ability to point you towards areas in your codebase that may be safe to remove; however, if I had removed the flagged code in the posts_controller then I would be in some trouble.

Tracking Gems

It is also possible to use Coverband to track gem usage. This is still in experimental stages and not recommended for production according to the docs.

To see it in action, first let's update our initializer:

# config/initializers/coverband.rb

Coverband.configure do |config|
  config.track_gems = true
  config.ignore += ["config/application.rb",
                    "config/boot.rb",
                    "config/puma.rb",
                    "bin/*",
                    "config/environments/*",
                    "lib/tasks/*",]
end

Enter fullscreen mode Exit fullscreen mode

According to the docs:

When tracking gems, it is important that Coverband#start is called before the gems to be tracked are required. The best way to do this is to require coverband before Bundle.require is called

So lets update application.rb to make sure coverband is loaded before Bundler.require is called:

# config/application.rb

require "coverband"
Bundler.require(*Rails.groups)
Enter fullscreen mode Exit fullscreen mode

Restart the Rails server and you should now have a gem tab if you navigate back to localhost:3000/coverband.

coverband_4

This can help give you insight into gems that may be safe to remove.

Tracking Views

There is a config option to watch your views, but it was not working for me on Rails 6.0.2.1 and Ruby 2.7 so I won't go into it now.

See the advanced configuration documentation for more information.

Summary

Coverband is a great tool to help you find code in your Rails app that may be safe to remove. The tool is not perfect though, so take care that the code can actually be safely removed. I personally used this tool on CodeFund's codebase and found some code that could be removed! And who doesn't like deleting code? Definitely recommend adding this tool to your tool belt.

Links

Happy Coding!

Top comments (7)

Collapse
 
etagwerker profile image
Ernesto Tagwerker (he/him)

Great article, Andrew!

I personally decided to keep it in my development group, 
because I didn't see any value in having the dashboard available in production.
Enter fullscreen mode Exit fullscreen mode

I think that there is value in running this tool in production because it doesn't get more real than real, live users using the app. You can see real production usage at the end of a period (e.g. one week) 😃

I wouldn't recommend running it for a long time in production. I'm sure there is a performance hit for running it in production.

Collapse
 
lynx_eyes profile image
Ivo Jesus

I'm probably a bit late to the game.. Yes, you can run in production and although you may take a hit in performance, you can always limit the percentage of calls getting traced. See mayerdan.com/rubynation-production...

Collapse
 
victorhazbun profile image
Victor Hazbun

What is the difference between Coverband and Simplecov?

Collapse
 
andrewmcodes profile image
Andrew Mason

From the docs:

Note: Coverband is not intended for test code coverage, for that we recommended using SimpleCov.

Collapse
 
victorhazbun profile image
Victor Hazbun

Ok, then what is it for?

Thread Thread
 
andrewmcodes profile image
Andrew Mason

to measure production code usage

Collapse
 
sanchezdav profile image
David Sanchez

Awesome post! That gem looks pretty nice! Thanks for sharing man