heap-metrics
v1.2.1
Published
Dump heap metrics after test to be tracked over all commits for the life of the branch.
Downloads
39
Maintainers
Readme
Node Heap Metrics
Installation
- npm install heap-metrics
or globally
- npm install -g heap-metrics
Note: see env
and addon
requirements for .travis.yml
builds further below.
Usage
// require statement will enable V8 Heap Profiling
var heapMetrics = require( 'heap_metrics' );
// ---- run some tests ----
// optionally, force final GC before dump (requires --expose_gc)
heapMetrics.ForceGC();
// get metrics and log to console
console.log(heapMetrics.GetHeapMetrics());
// dump metrics to file
heapMetrics.DumpHeapMetrics();
or add to your mocha cli as your final test case. The following script will be available on the path after package install (see below for details)
mochaDumpHeapMetrics.js
Description
Enable and dump Heap Profiler Metrics
to monitor the effects of code changes and dependency updates on heap usage for the life of each branch.
Heap Metrics is a native addon
written in C++ to minimize overhead and intrusion. The implementation makes use of the V8 Heap Profiler included with Node JS. (Official V8 Documentation)
Heap metrics, maintained by the node, are update on V8's garbage collection (GC) Prologue Notifications -- in other words, just before GC -- ensuring peak measurements for the following metrics:
- Heap Used
- Heap Size
- Physical Size
The C++ class is implemented as a singleton. The first script to require( 'heap_metrics' )
will intantiate the object and start heap profiling. All subsequent calls to require() will return the singleton object while profilling is ongoing.
API Description
GetHeapMetrics() returns the following object
{ 'Heap Size Limit': '1,499,136 KB',
'GC Prologue Notifications': 360,
'Heap Used Metrics':
{ 'At Ctor': '5,460 KB',
'At Peak': '21,907 KB',
'At last': '16,791 KB' },
'Heap Size Metrics':
{ 'At Ctor': '15,297 KB',
'At Peak': '39,483 KB',
'At last': '39,483 KB' },
'Physical Size Metrics':
{ 'At Ctor': '10,391 KB',
'At Peak': '36,259 KB',
'At last': '36,259 KB' } }
DumpHeapMetrics() will produce 2 files: 1) heap_metrics.html 2) heap_metrics.csv -- both in $(HOME)/bin
which must exist prior to calling (as of the current, initial release of 1.0.0) - the contents of each are shown below
Optionally - you can then push the metric files -- along with the test results, code coverage, and other metrics -- to Testspace in your CI .yml file (Travis, Circle CI, AppYayor, etc) (requires a free Testspace account)
- testspace test*.xml coverage.xml heap_metrics.html{heap_metrics.csv}
Travis Build Requirements
Starting with Node 4, V8 requires g++ 4.8
to build native addons. Add the following to your .travis.yml
file to update the build environment.
env:
- CXX=g++-4.8
addons:
apt:
sources:
- ubuntu-toolchain-r-test
packages:
- g++-4.8
TDD Mocha Test
The mochaDumpHeapMetrics.js
script has been added to the heap-metrics bin
for convenience and example. On install, npm will symlink the file into prefix/bin for global installs, or ./node_modules/.bin/ for local installs – and will be available on the path.
var heapMetrics = require('heap-metrics'),
expect = require('expect');
describe('DumpHeapMetrics', function () {
it('should return true', function () {
expect((heapMetrics.DumpHeapMetrics())).to.equal(true);
});
});
Testspace Metric Trends
The following timeline charts were produced by pushing changes (over 28 commits) made to the test script Test/dump_heap_metrics.js
to this repository. The test script consumes heap memory which can be easily increased or decreased. The metric files
are pushed from the .travis.yml
file in this repository.
More important than the actual heap numbers are the trends over successive commits, as they hightight any unexpected increases in heap usage. Unexplained jumps are often caused by unintended side effects from code commits and package updates. Unexplained increases can even be a sign of newly introduced memory leaks.
The charts above (unintentionally) show an interesting price point on heap usage (on a Travis server). When the peek used size
reaches the peak physical size
, the physical size decreases dramatically, with the number of GC events nearly doubling.
Testspace Metric Setup
Note: This is a onetime setup for a parent branch only. After using git branch
, pushing test results and the above metric files from your CI -- running the new branch for the first time -- will create a new Space with all metric charts and settings from the parent branch automatically
To setup the metrics shown above, once you've pushed the first set of metric files -- heap_metrics.html
and heap_metrics.cvs
-- to your Testspace Project:
- from the Space that's connected to your repository, select the Metrics tab
- from the Metrics tab, select the
New Metric
button top right. - from the New Metrics dialog, select the metric to create (from the heap_metrics.csv file)
- select the
customize
button - see settings below for the two charts pictured above.