Source code, additional information, screenshots… available at
eigenclass.org
Release information:
eigenclass.org
You can find a sample code coverage report generated by rcov at
eigenclass.org
If you’re on win32, you can also find a pre-built rcovrt.so (which makes
code coverage analysis >100 times faster) in the above-mentioned pages.
Overview
rcov is a tool for simple code coverage analysis in Ruby. It features:
- fast execution: 20-300 times faster than previous tools
- multiple analysis modes
- fairly accurate coverage information through code linkage inference
using
simple heuristics - XHTML and several kinds of text reports
- easy automation with Rake via a RcovTask
- colorblind-friendliness
What’s new in 0.4.0
See eigenclass.org for the detailed change
summary.
rcov 0.4.0 is really feature-packed, and (hopefully) less buggy than
previous
releases. This can be ascribed in large part to the use of rcov on
itself to
achieve better test coverage. Nearly 100 changesets went into rcov
0.4.0.
Starting with the most obvious changes, the XHTML output looks much
better
now with the new color-scheme. Plain text output formats have also
improved
considerably.
rcov 0.4.0 is much easier to use from external scripts, and invoking
rcov
from your Rakefile takes no effort with the included Rcov::RcovTask; it
can
take as little as:
require 'rcov/rcovtask'
Rcov::RcovTask.new
Really! This creates a task named “rcov” which will run the tests
matching
test/test*.rb and create a XHTML report. And a nice textual report on
stdout). And a clobber_rcov task, which the main clobber target will
depend
on, to delete the former.
However, sometimes that lone Rcov::RcovTask.new will not suffice; this
would
be a more realistic example:
# if you don't like the default description
desc "Analyze code coverage of the unit tests."
Rcov::RcovTask.new do |t|
# change the glob pattern in the next line
t.test_files = FileList['test/test*.rb']
t.rcov_opts << "--sort coverage" # sort by increasing coverage
rate
end
See README.rake in the distribution tarball (or the RDoc documentation,
which
includes it) for more information about Rcov::RcovTask.
Parts of the code have been moved into a reusable library that allows
you to
build on top of rcov’s coverage analysis capabilities. This change
allowed for
much better testing of rcov’s internals, which helped squash many bugs
and add
features while making the overall code look better thanks to some
long-needed
refactoring.
Short summary of user-visible changes
- easy automation via Rake using the bundled Rcov::RcovTask
- better heuristics: supports heredocs at last, including variants your
editor
is probably unable to handle, and =begin/=end comments - –rails option to ignore files under vendor/, enviroment/ and config/
- parts of the runtime exposed and documented for external use
- new color scheme, with alternating shades of the base colors
- -w to set $VERBOSE=true (turns on warnings)
- –text-report and --text-summary
- –sort and --sort-reverse for the summaries and reports
- –threshold and --only-uncovered
- –replace-progname
Backwards incompatible changes
- renamed --text to --text-counts and --rich-text to --text-coverage:
they
were misnamed to begin with - changed the meaning of -t and -T (–text-summary and --text-report)
- $0 is not changed by default for each loaded file anymore; the old
behavior (modulo a small bugfix) can be reproduced with
–replace-progname
Thanks (do tell if I forgot to list your name)
Robert F.:
- helped to refine the color scheme
- very valuable suggestions; a large percentage of the new functionality
in
0.4.0 is a consequence of his requests
Andre N.:
- identified a couple bugs in the heuristics that eluded my testing
Downloading
The last version is available at
eigenclass.org
How do I use it?
Just use rcov to run your program (instead of ruby), and a number of
XHTML
files with the code coverage information will be generated, e.g.
rcov test/*.rb
will execute all the .rb files under test/ and generate the code
coverage report
under coverage/. rcov can also operate in “bogo-profiling mode”
and output the relevant information in alternative formats. Use
rcov -h
for more information.
Sample output
See eigenclass.org (once again) for screenshots.
A sample code coverage report generated by rcov is available at
eigenclass.org
Text reports (also used by default in RcovTasks) resemble
±----------------------------------------------------±------±------±-------+
| File | Lines | LOC | COV |
±----------------------------------------------------±------±------±-------+
|app/controllers/application.rb | 39 | 29 | 31.0% |
|app/helpers/application_helper.rb | 147 | 119 | 23.5% |
|app/models/aggregations/tada.rb | 75 | 45 | 31.1% |
|app/models/aggregations/upcoming.rb | 78 | 48 | 29.2% |
|app/models/article.rb | 109 | 78 | 67.9% |
|app/models/category.rb | 30 | 23 | 60.9% |
|app/models/sidebar.rb | 36 | 27 | 40.7% |
|components/plugins/sidebars/archives_controller.rb | 35 | 27 | 29.6% |
|components/plugins/sidebars/category_controller.rb | 20 | 16 | 50.0% |
|components/plugins/sidebars/delicious_controller.rb | 20 | 16 | 50.0% |
|components/plugins/sidebars/flickr_controller.rb | 20 | 16 | 50.0% |
|components/plugins/sidebars/fortythree_controller.rb | 20 | 16 | 50.0% |
|…s/plugins/sidebars/fortythreeplaces_controller.rb | 20 | 16 | 50.0% |
|components/plugins/sidebars/static_controller.rb | 27 | 24 | 29.2% |
|components/plugins/sidebars/tada_controller.rb | 20 | 16 | 50.0% |
|components/plugins/sidebars/technorati_controller.rb | 20 | 16 | 50.0% |
|components/plugins/sidebars/upcoming_controller.rb | 20 | 16 | 50.0% |
|components/plugins/sidebars/xml_controller.rb | 16 | 13 | 53.8% |
|components/sidebars/sidebar_controller.rb | 110 | 80 | 32.5% |
|lib/html_engine.rb | 29 | 23 | 78.3% |
|lib/login_system.rb | 85 | 34 | 23.5% |
|lib/migrator.rb | 28 | 22 | 40.9% |
|lib/renderfix.rb | 32 | 25 | 16.0% |
|lib/xmlrpc_fix.rb | 13 | 12 | 25.0% |
±----------------------------------------------------±------±------±-------+
|Total | 1754 | 1251 | 60.1% |
±----------------------------------------------------±------±------±-------+
60.1% 42 file(s) 1754 Lines 1251 LOC
This was run with --threshold 80, meaning that only files under 80%
coverage
are shown in the table, but the overall statistics include all analyzed
files.
The textual output with execution count information looks like this:
$ rcov --no-html --text-counts b.rb
./b.rb
|
2
a, b, c = (1…3).to_a |
2
10.times do |
1
a += 1 |
10
20.times do |i| |
10
b += i |
200
b.times do |
200
c += (j = (b-a).abs) > 0 ? j : 0 |
738800
end |
0
end |
0
end |
0
License
rcov is released under the terms of Ruby’s license.
rcov includes xx 0.1.0, which is subject to the following conditions:
ePark Labs Public License version 1
Copyright (c) 2005, ePark Labs, Inc. and contributors
All rights reserved.
Redistribution and use in source and binary forms, with or without
modification,
are permitted provided that the following conditions are met:
- Redistributions of source code must retain the above copyright
notice, this
list of conditions and the following disclaimer. - Redistributions in binary form must reproduce the above copyright
notice,
this list of conditions and the following disclaimer in the
documentation
and/or other materials provided with the distribution. - Neither the name of ePark Labs nor the names of its contributors
may be
used to endorse or promote products derived from this software
without
specific prior written permission.
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS “AS
IS” AND
ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
IMPLIED
WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
LIABLE FOR
ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
DAMAGES
(INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
SERVICES;
LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
AND ON
ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
THIS
SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.