From b38eae896f1b15d3d4f544f467d9e1c0c858a011 Mon Sep 17 00:00:00 2001 From: Trent Mick Date: Fri, 26 Jun 2020 22:18:40 -0700 Subject: [PATCH] Fix test suite failure in node v14 due to util.inspect change with circular refs In https://github.com/nodejs/node/pull/27685 (part of node v14), how objects with circular references are stringified with `util.inspect` changed. --- test/cycles.test.js | 24 +++++++++++++++++++----- test/log.test.js | 2 +- 2 files changed, 20 insertions(+), 6 deletions(-) diff --git a/test/cycles.test.js b/test/cycles.test.js index 3f1cda6d..293de788 100644 --- a/test/cycles.test.js +++ b/test/cycles.test.js @@ -1,5 +1,5 @@ /* - * Copyright (c) 2012 Trent Mick. All rights reserved. + * Copyright 2020 Trent Mick. * * Make sure cycles are safe. */ @@ -27,7 +27,6 @@ outstr.end = function (c) { this.emit('end'); }; -// these are lacking a few fields that will probably never match var expect = [ { @@ -67,24 +66,39 @@ var log = new Logger({ }); test('cycles', function (t) { + var rec; + outstr.on('end', function () { output.forEach(function (o, i) { // Drop variable parts for comparison. delete o.hostname; delete o.pid; delete o.time; - // Hack object/dict comparison: JSONify. + + // In change https://github.com/nodejs/node/pull/27685 (part of + // node v14), how objects with circular references are stringified + // with `util.inspect` changed. + if (Number(process.versions.node.split('.')[0]) >= 14) { + expect[i].msg = expect[i].msg.replace( + // JSSTYLED + /{ bang: 'boom', KABOOM: \[Circular\] }/, + ' { bang: \'boom\', KABOOM: [Circular *1] }' + ); + } + t.equal(JSON.stringify(o), JSON.stringify(expect[i]), - 'log item ' + i + ' matches'); + 'log record ' + i + ' matches'); }); t.end(); }); var obj = { bang: 'boom' }; - obj.KABOOM = obj; + obj.KABOOM = obj; // This creates a circular reference. + log.info('bango', obj); log.info('kaboom', obj.KABOOM); log.info(obj); + outstr.end(); t.ok('did not throw'); }); diff --git a/test/log.test.js b/test/log.test.js index ace863c2..55906513 100644 --- a/test/log.test.js +++ b/test/log.test.js @@ -1,5 +1,5 @@ /* - * Copyright (c) 2012 Trent Mick. All rights reserved. + * Copyright 2020 Trent Mick. * * Test the `log.trace(...)`, `log.debug(...)`, ..., `log.fatal(...)` API. */