coverage.json
contains a report object, which is a hash where keys are file names (absolute
paths), and values are coverage data for that file (the result of
json.stringify(collector.fileCoverageFor(filename))
) Each entry consists of:
-
path
- The path to the file. This is an absolute path, and should be the same as the key in the report object. -
s
- Hash of statement counts, where keys as statement IDs. -
b
- Hash of branch counts, where keys are branch IDs and values are arrays of counts. For an if statement, the value would have two counts; one for the if, and one for the else. Switch statements would have an array of values for each case. -
f
- Hash of function counts, where keys are function IDs. -
fnMap
- Hash of functions where keys are function IDs, and values are{name, line, loc, skip}
, wherename
is the name of the function,line
is the line the function is declared on, andloc
is theLocation
of the function declaration (just the declaration, not the entire function body - see 'Location Objects' below.) Ifskip
is present and true, then this indicates that this function was ignored by a### instabul ignore ... ###
pragma. Note that if a function is not ignored theskip
field will be missing entirely. -
statementMap
- Hash where keys are statement IDs, and values areLocation
objects for each statement. TheLocation
for a function definition is really an assignment, and should include the entire function. In addition to the normal location object fields, astatementMap
entry can also have an optionalskip
field. -
branchMap
- Hash where keys are branch IDs, and values are{line, type, locations}
objects.line
is the line the branch starts on.type
is the type of the branch (e.g. "if", "switch").locations
is an array ofLocation
objects, one for each possible outcome of the branch. Note for anif
statement where there is noelse
clause, there will still be twolocations
generated. Istanbul does not generate coverage for thedefault
case of a switch statement ifdefault
is not explicitly present in the source code.locations
for an if statement are always 0-length and located at the start of theif
(even the location for the "else"). For aswitch
statement,locations
start at the start of thecase
statement and go to the end of the line before the next case statement (note Istanbul does nothing clever here if acase
is missing abreak
.) Each location inlocations
can also optionally have askip: true
field to indicate that this branch was ignored.
IDs used in the fnMap, statementMap, and branchMap are sequential integers, starting at 1.
Location objects are a {start: {line, column}, end: {line, column}}
object that describes
the start and end of a piece of code. Note that line
is 1-based, but column
is 0-based.