Code coverage report for lib/console.js

Statements: 91.49% (43 / 47)      Branches: 75% (9 / 12)      Functions: 87.5% (7 / 8)      Lines: 91.49% (43 / 47)      Ignored: none     

All files » lib/ » console.js
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96    896   896 942     942 1   941 44   941         941 941 941 941 941 941     941 941 8469 8469       896 9893       896     896 15603       896     896 22           896 5       896 6 6 1   5 5       896     9 9 9 9 9       896               896 896      
(function () { 'use strict';
 
const util = require('util');
 
function Console(stdout, stderr) {
  Iif (!(this instanceof Console)) {
    return new Console(stdout, stderr);
  }
  if (!stdout || typeof stdout.write !== 'function') {
    throw new TypeError('Console expects a writable stream instance');
  }
  if (!stderr) {
    stderr = stdout;
  }
  var prop = {
    writable: true,
    enumerable: false,
    configurable: true
  };
  prop.value = stdout;
  Object.defineProperty(this, '_stdout', prop);
  prop.value = stderr;
  Object.defineProperty(this, '_stderr', prop);
  prop.value = new Map();
  Object.defineProperty(this, '_times', prop);
 
  // bind the prototype functions to this Console instance
  var keys = Object.keys(Console.prototype);
  for (var v = 0; v < keys.length; v++) {
    var k = keys[v];
    this[k] = this[k].bind(this);
  }
}
 
Console.prototype.log = function() {
  this._stdout.write(util.format.apply(this, arguments) + '\n');
};
 
 
Console.prototype.info = Console.prototype.log;
 
 
Console.prototype.warn = function() {
  this._stderr.write(util.format.apply(this, arguments) + '\n');
};
 
 
Console.prototype.error = Console.prototype.warn;
 
 
Console.prototype.dir = function(object, options) {
  this._stdout.write(util.inspect(object, util._extend({
    customInspect: false
  }, options)) + '\n');
};
 
 
Console.prototype.time = function(label) {
  this._times.set(label, Date.now());
};
 
 
Console.prototype.timeEnd = function(label) {
  var time = this._times.get(label);
  if (!time) {
    throw new Error('No such label: ' + label);
  }
  var duration = Date.now() - time;
  this.log('%s: %dms', label, duration);
};
 
 
Console.prototype.trace = function trace() {
  // TODO probably can to do this better with V8's debug object once that is
  // exposed.
  var err = new Error();
  err.name = 'Trace';
  err.message = util.format.apply(this, arguments);
  Error.captureStackTrace(err, trace);
  this.error(err.stack);
};
 
 
Console.prototype.assert = function(expression) {
  if (!expression) {
    var arr = Array.prototype.slice.call(arguments, 1);
    require('assert').ok(false, util.format.apply(this, arr));
  }
};
 
 
module.exports = new Console(process.stdout, process.stderr);
module.exports.Console = Console;
 
}());