forked from lix-project/lix-website
272 lines
6.5 KiB
JavaScript
272 lines
6.5 KiB
JavaScript
|
var test = require('tape');
|
||
|
var forEach = require('for-each');
|
||
|
|
||
|
var inspect = require('../');
|
||
|
|
||
|
test('bad indent options', function (t) {
|
||
|
forEach([
|
||
|
undefined,
|
||
|
true,
|
||
|
false,
|
||
|
-1,
|
||
|
1.2,
|
||
|
Infinity,
|
||
|
-Infinity,
|
||
|
NaN
|
||
|
], function (indent) {
|
||
|
t['throws'](
|
||
|
function () { inspect('', { indent: indent }); },
|
||
|
TypeError,
|
||
|
inspect(indent) + ' is invalid'
|
||
|
);
|
||
|
});
|
||
|
|
||
|
t.end();
|
||
|
});
|
||
|
|
||
|
test('simple object with indent', function (t) {
|
||
|
t.plan(2);
|
||
|
|
||
|
var obj = { a: 1, b: 2 };
|
||
|
|
||
|
var expectedSpaces = [
|
||
|
'{',
|
||
|
' a: 1,',
|
||
|
' b: 2',
|
||
|
'}'
|
||
|
].join('\n');
|
||
|
var expectedTabs = [
|
||
|
'{',
|
||
|
' a: 1,',
|
||
|
' b: 2',
|
||
|
'}'
|
||
|
].join('\n');
|
||
|
|
||
|
t.equal(inspect(obj, { indent: 2 }), expectedSpaces, 'two');
|
||
|
t.equal(inspect(obj, { indent: '\t' }), expectedTabs, 'tabs');
|
||
|
});
|
||
|
|
||
|
test('two deep object with indent', function (t) {
|
||
|
t.plan(2);
|
||
|
|
||
|
var obj = { a: 1, b: { c: 3, d: 4 } };
|
||
|
|
||
|
var expectedSpaces = [
|
||
|
'{',
|
||
|
' a: 1,',
|
||
|
' b: {',
|
||
|
' c: 3,',
|
||
|
' d: 4',
|
||
|
' }',
|
||
|
'}'
|
||
|
].join('\n');
|
||
|
var expectedTabs = [
|
||
|
'{',
|
||
|
' a: 1,',
|
||
|
' b: {',
|
||
|
' c: 3,',
|
||
|
' d: 4',
|
||
|
' }',
|
||
|
'}'
|
||
|
].join('\n');
|
||
|
|
||
|
t.equal(inspect(obj, { indent: 2 }), expectedSpaces, 'two');
|
||
|
t.equal(inspect(obj, { indent: '\t' }), expectedTabs, 'tabs');
|
||
|
});
|
||
|
|
||
|
test('simple array with all single line elements', function (t) {
|
||
|
t.plan(2);
|
||
|
|
||
|
var obj = [1, 2, 3, 'asdf\nsdf'];
|
||
|
|
||
|
var expected = '[ 1, 2, 3, \'asdf\\nsdf\' ]';
|
||
|
|
||
|
t.equal(inspect(obj, { indent: 2 }), expected, 'two');
|
||
|
t.equal(inspect(obj, { indent: '\t' }), expected, 'tabs');
|
||
|
});
|
||
|
|
||
|
test('array with complex elements', function (t) {
|
||
|
t.plan(2);
|
||
|
|
||
|
var obj = [1, { a: 1, b: { c: 1 } }, 'asdf\nsdf'];
|
||
|
|
||
|
var expectedSpaces = [
|
||
|
'[',
|
||
|
' 1,',
|
||
|
' {',
|
||
|
' a: 1,',
|
||
|
' b: {',
|
||
|
' c: 1',
|
||
|
' }',
|
||
|
' },',
|
||
|
' \'asdf\\nsdf\'',
|
||
|
']'
|
||
|
].join('\n');
|
||
|
var expectedTabs = [
|
||
|
'[',
|
||
|
' 1,',
|
||
|
' {',
|
||
|
' a: 1,',
|
||
|
' b: {',
|
||
|
' c: 1',
|
||
|
' }',
|
||
|
' },',
|
||
|
' \'asdf\\nsdf\'',
|
||
|
']'
|
||
|
].join('\n');
|
||
|
|
||
|
t.equal(inspect(obj, { indent: 2 }), expectedSpaces, 'two');
|
||
|
t.equal(inspect(obj, { indent: '\t' }), expectedTabs, 'tabs');
|
||
|
});
|
||
|
|
||
|
test('values', function (t) {
|
||
|
t.plan(2);
|
||
|
var obj = [{}, [], { 'a-b': 5 }];
|
||
|
|
||
|
var expectedSpaces = [
|
||
|
'[',
|
||
|
' {},',
|
||
|
' [],',
|
||
|
' {',
|
||
|
' \'a-b\': 5',
|
||
|
' }',
|
||
|
']'
|
||
|
].join('\n');
|
||
|
var expectedTabs = [
|
||
|
'[',
|
||
|
' {},',
|
||
|
' [],',
|
||
|
' {',
|
||
|
' \'a-b\': 5',
|
||
|
' }',
|
||
|
']'
|
||
|
].join('\n');
|
||
|
|
||
|
t.equal(inspect(obj, { indent: 2 }), expectedSpaces, 'two');
|
||
|
t.equal(inspect(obj, { indent: '\t' }), expectedTabs, 'tabs');
|
||
|
});
|
||
|
|
||
|
test('Map', { skip: typeof Map !== 'function' }, function (t) {
|
||
|
var map = new Map();
|
||
|
map.set({ a: 1 }, ['b']);
|
||
|
map.set(3, NaN);
|
||
|
|
||
|
var expectedStringSpaces = [
|
||
|
'Map (2) {',
|
||
|
' { a: 1 } => [ \'b\' ],',
|
||
|
' 3 => NaN',
|
||
|
'}'
|
||
|
].join('\n');
|
||
|
var expectedStringTabs = [
|
||
|
'Map (2) {',
|
||
|
' { a: 1 } => [ \'b\' ],',
|
||
|
' 3 => NaN',
|
||
|
'}'
|
||
|
].join('\n');
|
||
|
var expectedStringTabsDoubleQuotes = [
|
||
|
'Map (2) {',
|
||
|
' { a: 1 } => [ "b" ],',
|
||
|
' 3 => NaN',
|
||
|
'}'
|
||
|
].join('\n');
|
||
|
|
||
|
t.equal(
|
||
|
inspect(map, { indent: 2 }),
|
||
|
expectedStringSpaces,
|
||
|
'Map keys are not indented (two)'
|
||
|
);
|
||
|
t.equal(
|
||
|
inspect(map, { indent: '\t' }),
|
||
|
expectedStringTabs,
|
||
|
'Map keys are not indented (tabs)'
|
||
|
);
|
||
|
t.equal(
|
||
|
inspect(map, { indent: '\t', quoteStyle: 'double' }),
|
||
|
expectedStringTabsDoubleQuotes,
|
||
|
'Map keys are not indented (tabs + double quotes)'
|
||
|
);
|
||
|
|
||
|
t.equal(inspect(new Map(), { indent: 2 }), 'Map (0) {}', 'empty Map should show as empty (two)');
|
||
|
t.equal(inspect(new Map(), { indent: '\t' }), 'Map (0) {}', 'empty Map should show as empty (tabs)');
|
||
|
|
||
|
var nestedMap = new Map();
|
||
|
nestedMap.set(nestedMap, map);
|
||
|
var expectedNestedSpaces = [
|
||
|
'Map (1) {',
|
||
|
' [Circular] => Map (2) {',
|
||
|
' { a: 1 } => [ \'b\' ],',
|
||
|
' 3 => NaN',
|
||
|
' }',
|
||
|
'}'
|
||
|
].join('\n');
|
||
|
var expectedNestedTabs = [
|
||
|
'Map (1) {',
|
||
|
' [Circular] => Map (2) {',
|
||
|
' { a: 1 } => [ \'b\' ],',
|
||
|
' 3 => NaN',
|
||
|
' }',
|
||
|
'}'
|
||
|
].join('\n');
|
||
|
t.equal(inspect(nestedMap, { indent: 2 }), expectedNestedSpaces, 'Map containing a Map should work (two)');
|
||
|
t.equal(inspect(nestedMap, { indent: '\t' }), expectedNestedTabs, 'Map containing a Map should work (tabs)');
|
||
|
|
||
|
t.end();
|
||
|
});
|
||
|
|
||
|
test('Set', { skip: typeof Set !== 'function' }, function (t) {
|
||
|
var set = new Set();
|
||
|
set.add({ a: 1 });
|
||
|
set.add(['b']);
|
||
|
var expectedStringSpaces = [
|
||
|
'Set (2) {',
|
||
|
' {',
|
||
|
' a: 1',
|
||
|
' },',
|
||
|
' [ \'b\' ]',
|
||
|
'}'
|
||
|
].join('\n');
|
||
|
var expectedStringTabs = [
|
||
|
'Set (2) {',
|
||
|
' {',
|
||
|
' a: 1',
|
||
|
' },',
|
||
|
' [ \'b\' ]',
|
||
|
'}'
|
||
|
].join('\n');
|
||
|
t.equal(inspect(set, { indent: 2 }), expectedStringSpaces, 'new Set([{ a: 1 }, ["b"]]) should show size and contents (two)');
|
||
|
t.equal(inspect(set, { indent: '\t' }), expectedStringTabs, 'new Set([{ a: 1 }, ["b"]]) should show size and contents (tabs)');
|
||
|
|
||
|
t.equal(inspect(new Set(), { indent: 2 }), 'Set (0) {}', 'empty Set should show as empty (two)');
|
||
|
t.equal(inspect(new Set(), { indent: '\t' }), 'Set (0) {}', 'empty Set should show as empty (tabs)');
|
||
|
|
||
|
var nestedSet = new Set();
|
||
|
nestedSet.add(set);
|
||
|
nestedSet.add(nestedSet);
|
||
|
var expectedNestedSpaces = [
|
||
|
'Set (2) {',
|
||
|
' Set (2) {',
|
||
|
' {',
|
||
|
' a: 1',
|
||
|
' },',
|
||
|
' [ \'b\' ]',
|
||
|
' },',
|
||
|
' [Circular]',
|
||
|
'}'
|
||
|
].join('\n');
|
||
|
var expectedNestedTabs = [
|
||
|
'Set (2) {',
|
||
|
' Set (2) {',
|
||
|
' {',
|
||
|
' a: 1',
|
||
|
' },',
|
||
|
' [ \'b\' ]',
|
||
|
' },',
|
||
|
' [Circular]',
|
||
|
'}'
|
||
|
].join('\n');
|
||
|
t.equal(inspect(nestedSet, { indent: 2 }), expectedNestedSpaces, 'Set containing a Set should work (two)');
|
||
|
t.equal(inspect(nestedSet, { indent: '\t' }), expectedNestedTabs, 'Set containing a Set should work (tabs)');
|
||
|
|
||
|
t.end();
|
||
|
});
|