From 5300577c533d65ea68309f2547225ef31bbb22a8 Mon Sep 17 00:00:00 2001 From: Wilco Fiers Date: Mon, 25 Sep 2017 20:19:21 +0200 Subject: [PATCH] fix: Match prerelease versions for helpUrl (#546) --- lib/core/base/audit.js | 2 +- test/core/base/audit.js | 32 ++++++++++++++++++++++++++++++++ 2 files changed, 33 insertions(+), 1 deletion(-) diff --git a/lib/core/base/audit.js b/lib/core/base/audit.js index c07b66818f..2e59072cd6 100644 --- a/lib/core/base/audit.js +++ b/lib/core/base/audit.js @@ -299,7 +299,7 @@ function getHelpUrl ({brand, application}, ruleId, version) { } Audit.prototype._constructHelpUrls = function (previous = null) { - var version = axe.version.substring(0, axe.version.lastIndexOf('.')); + var version = (axe.version.match(/^[1-9][0-9]*\.[1-9][0-9]*/) || ['x.y'])[0]; this.rules.forEach(rule => { if (!this.data.rules[rule.id]) { this.data.rules[rule.id] = {}; diff --git a/test/core/base/audit.js b/test/core/base/audit.js index 556c6434b6..8103ff7306 100644 --- a/test/core/base/audit.js +++ b/test/core/base/audit.js @@ -152,6 +152,38 @@ describe('Audit', function () { 'https://dequeuniversity.com/rules/thing/x.y/target2?application=axeAPI' ); }); + it('understands prerelease type version numbers', function () { + var tempVersion = axe.version; + var audit = new Audit(); + audit.addRule({ + id: 'target', + matches: 'function () {return "hello";}', + selector: 'bob' + }); + + axe.version = '3.2.1-alpha.0'; + audit._constructHelpUrls(); + + axe.version = tempVersion; + assert.equal(audit.data.rules.target.helpUrl, + 'https://dequeuniversity.com/rules/axe/3.2/target?application=axeAPI'); + }); + it('sets x.y as version for invalid versions', function () { + var tempVersion = axe.version; + var audit = new Audit(); + audit.addRule({ + id: 'target', + matches: 'function () {return "hello";}', + selector: 'bob' + }); + + axe.version = 'in-3.0-valid'; + audit._constructHelpUrls(); + + axe.version = tempVersion; + assert.equal(audit.data.rules.target.helpUrl, + 'https://dequeuniversity.com/rules/axe/x.y/target?application=axeAPI'); + }); }); describe('Audit#setBranding', function () {