AVA no longer uses this fork. The repository is retained for posterity.
Stringify any JavaScript value.
- Supports all built-in JavaScript types
- Blazingly fast (similar performance to v8's
JSON.stringifyand significantly faster than Node'sutil.format) - Plugin system for extending with custom types (i.e.
ReactTestComponent)
$ npm install @ava/pretty-formatvar prettyFormat = require('pretty-format');
var obj = { property: {} };
obj.circularReference = obj;
obj[Symbol('foo')] = 'foo';
obj.map = new Map();
obj.map.set('prop', 'value');
obj.array = [1, NaN, Infinity];
console.log(prettyFormat(obj));Result:
Object {
"property": Object {},
"circularReference": [Circular],
"map": Map {
"prop" => "value"
},
"array": Array [
1,
NaN,
Infinity
],
Symbol(foo): "foo"
}Object, Array, ArrayBuffer, DataView, Float32Array, Float64Array, Int8Array, Int16Array, Int32Array, Uint8Array, Uint8ClampedArray, Uint16Array, Uint32Array, arguments, Boolean, Date, Error, Function, Infinity, Map, NaN, null, Number, RegExp, Set, String, Symbol, undefined, WeakMap, WeakSet
console.log(prettyFormat(object));
console.log(prettyFormat(object, options));Options:
callToJSON
Type:boolean, default:true
CalltoJSON()on passed object.indent
Type:number, default:2
Number of spaces for indentation.maxDepth
Type:number, default:Infinity
Print only this number of levels.min
Type:boolean, default:false
Print without whitespace.plugins
Type:array, default:[]
Plugins (see the next section).printFunctionName
Type:boolean, default:true
Print function names or just[Function].escapeRegex
Type:boolean, default:false
Escape special characters in regular expressions.highlight
Type:boolean, default:false
Highlight syntax for terminal (works only withReactTestComponentandReactElementplugins.theme
Type:object, default:{tag: 'cyan', content: 'reset'...}
Syntax highlight theme.
Uses ansi-styles colors +resetfor no color.
Available types:tag,content,propandvalue.
Pretty format also supports adding plugins:
var fooPlugin = {
test: function(val) {
return val && val.hasOwnProperty('foo');
},
print: function(val, print, indent) {
return 'Foo: ' + print(val.foo);
}
};
var obj = { foo: { bar: {} } };
prettyFormat(obj, {
plugins: [fooPlugin]
});
// Foo: Object {
// "bar": Object {}
// }var prettyFormat = require('pretty-format');
var reactTestPlugin = require('pretty-format/plugins/ReactTestComponent');
var reactElementPlugin = require('pretty-format/plugins/ReactElement');
var React = require('react');
var renderer = require('react-test-renderer');
var jsx = React.createElement('h1', null, 'Hello World');
prettyFormat(renderer.create(jsx).toJSON(), {
plugins: [reactTestPlugin, reactElementPlugin]
});
// <h1>
// Hello World
// </h1>