From f23d8c8e305d27c8323547731b335d2900e03239 Mon Sep 17 00:00:00 2001 From: Wilco Fiers Date: Wed, 24 Nov 2021 17:45:49 +0100 Subject: [PATCH] fix(core): Incomplete fallback was missing, and could cause infinite loop (#3302) --- build/configure.js | 12 ++--- .../helpers/incomplete-fallback-msg.js | 15 +++--- .../helpers/incomplete-fallback-msg.js | 47 +++++++++++++++++-- 3 files changed, 55 insertions(+), 19 deletions(-) diff --git a/build/configure.js b/build/configure.js index cec2b60744..1dfc2c7d6d 100644 --- a/build/configure.js +++ b/build/configure.js @@ -148,16 +148,10 @@ function buildRules(grunt, options, commons, callback) { } function getIncompleteMsg(summaries) { - var result = {}; - summaries.forEach(function(summary) { - if ( - summary.incompleteFallbackMessage && - doTRegex.test(summary.incompleteFallbackMessage) - ) { - result = doT.template(summary.incompleteFallbackMessage).toString(); - } + var summary = summaries.find(function(summary) { + return typeof summary.incompleteFallbackMessage === 'string'; }); - return result; + return summary ? summary.incompleteFallbackMessage : ''; } function replaceFunctions(string) { diff --git a/lib/core/reporters/helpers/incomplete-fallback-msg.js b/lib/core/reporters/helpers/incomplete-fallback-msg.js index 02678c7b6e..53d1d96553 100644 --- a/lib/core/reporters/helpers/incomplete-fallback-msg.js +++ b/lib/core/reporters/helpers/incomplete-fallback-msg.js @@ -3,10 +3,13 @@ * This mechanism allows the string to be localized. * @return {String} */ -function incompleteFallbackMessage() { - return typeof axe._audit.data.incompleteFallbackMessage === 'function' - ? axe._audit.data.incompleteFallbackMessage() - : axe._audit.data.incompleteFallbackMessage; + export default function incompleteFallbackMessage() { + let { incompleteFallbackMessage } = axe._audit.data; + if (typeof incompleteFallbackMessage === 'function') { + incompleteFallbackMessage = incompleteFallbackMessage(); + } + if (typeof incompleteFallbackMessage !== 'string') { + return ''; + } + return incompleteFallbackMessage; } - -export default incompleteFallbackMessage; diff --git a/test/core/reporters/helpers/incomplete-fallback-msg.js b/test/core/reporters/helpers/incomplete-fallback-msg.js index 5558b0ef84..4f0d9bbd44 100644 --- a/test/core/reporters/helpers/incomplete-fallback-msg.js +++ b/test/core/reporters/helpers/incomplete-fallback-msg.js @@ -1,6 +1,13 @@ describe('helpers.incompleteFallbackMessage', function() { 'use strict'; - beforeEach(function() { + + it('returns a non-empty string by default', function () { + var summary = helpers.incompleteFallbackMessage(); + assert.typeOf(summary, 'string'); + assert.notEqual(summary, ''); + }); + + it('should return a string', function() { axe._load({ messages: {}, rules: [], @@ -8,9 +15,6 @@ describe('helpers.incompleteFallbackMessage', function() { incompleteFallbackMessage: 'Dogs are the best' } }); - }); - - it('should return a string', function() { var summary = helpers.incompleteFallbackMessage(); assert.equal(summary, 'Dogs are the best'); }); @@ -29,4 +33,39 @@ describe('helpers.incompleteFallbackMessage', function() { var summary = helpers.incompleteFallbackMessage(); assert.equal(summary, 'Dogs are the best'); }); + + describe('when passed an invalid value', function () { + it('returns `` when set to an object', function () { + axe._load({ + messages: {}, + rules: [], + data: { + incompleteFallbackMessage: {} + } + }); + assert.equal(helpers.incompleteFallbackMessage(), ''); + }); + + it('returns `` when set to null', function () { + axe._load({ + messages: {}, + rules: [], + data: { + incompleteFallbackMessage: null + } + }); + assert.equal(helpers.incompleteFallbackMessage(), ''); + }); + + it('returns `` when set to undefined', function () { + axe._load({ + messages: {}, + rules: [], + data: { + incompleteFallbackMessage: undefined + } + }); + assert.equal(helpers.incompleteFallbackMessage(), ''); + }); + }); });