From db3f324e5adbcf463ae787dcf592e7bba6c0212d Mon Sep 17 00:00:00 2001 From: Paul Irish Date: Wed, 2 Aug 2017 15:10:59 -0700 Subject: [PATCH] All audits must specify helpText and failureDescription (#2737) --- docs/recipes/custom-audit/searchable-audit.js | 1 + .../dobetterweb/password-inputs-can-be-pasted-into.js | 3 ++- lighthouse-core/config/config.js | 6 +++++- lighthouse-core/test/config/config-test.js | 4 +++- .../test/fixtures/invalid-audits/missing-audit.js | 2 +- .../test/fixtures/invalid-audits/missing-category.js | 2 +- .../test/fixtures/invalid-audits/missing-description.js | 2 +- .../invalid-audits/missing-generate-audit-result.js | 2 +- .../test/fixtures/invalid-audits/missing-help-text.js | 1 + .../test/fixtures/invalid-audits/missing-name.js | 2 +- .../fixtures/invalid-audits/missing-required-artifacts.js | 3 ++- .../test/fixtures/invalid-audits/require-error.js | 2 +- lighthouse-core/test/fixtures/valid-custom-audit.js | 1 + .../test/report/v2/renderer/category-renderer-test.js | 6 +++--- lighthouse-core/test/runner-test.js | 1 + 15 files changed, 25 insertions(+), 13 deletions(-) diff --git a/docs/recipes/custom-audit/searchable-audit.js b/docs/recipes/custom-audit/searchable-audit.js index e635c7fb0384..4e82134ea3b5 100644 --- a/docs/recipes/custom-audit/searchable-audit.js +++ b/docs/recipes/custom-audit/searchable-audit.js @@ -20,6 +20,7 @@ class LoadAudit extends Audit { category: 'MyCustomCategory', name: 'searchable-audit', description: 'Search box initialized and ready', + failureDescription: 'Search box slow to initialize', helpText: 'Used to measure time from navigationStart to when the search' + ' box is initialized and ready to search.', diff --git a/lighthouse-core/audits/dobetterweb/password-inputs-can-be-pasted-into.js b/lighthouse-core/audits/dobetterweb/password-inputs-can-be-pasted-into.js index 47c62f3286ca..9b9b0fc8e18f 100644 --- a/lighthouse-core/audits/dobetterweb/password-inputs-can-be-pasted-into.js +++ b/lighthouse-core/audits/dobetterweb/password-inputs-can-be-pasted-into.js @@ -17,7 +17,8 @@ class PasswordInputsCanBePastedIntoAudit extends Audit { name: 'password-inputs-can-be-pasted-into', description: 'Allows users to paste into password fields', failureDescription: 'Prevents users to paste into password fields', - helpText: '', + helpText: 'Preventing password pasting undermines good security policy. ' + + '[Learn more](https://www.ncsc.gov.uk/blog-post/let-them-paste-passwords)', requiredArtifacts: ['PasswordInputsWithPreventedPaste'] }; } diff --git a/lighthouse-core/config/config.js b/lighthouse-core/config/config.js index ba7d42b74e08..c7c3896b51af 100644 --- a/lighthouse-core/config/config.js +++ b/lighthouse-core/config/config.js @@ -193,13 +193,17 @@ function assertValidAudit(auditDefinition, auditPath) { if (typeof auditDefinition.meta.failureDescription !== 'string' && auditDefinition.meta.informative !== true && auditDefinition.meta.scoringMode !== Audit.SCORING_MODES.NUMERIC) { - log.warn('config', `${auditName} has no failureDescription and should.`); + throw new Error(`${auditName} has no failureDescription and should.`); } if (typeof auditDefinition.meta.helpText !== 'string') { throw new Error( `${auditName} has no meta.helpText property, or the property is not a string.` ); + } else if (auditDefinition.meta.helpText === '') { + throw new Error( + `${auditName} has an empty meta.helpText string. Please add a description for the UI.` + ); } if (!Array.isArray(auditDefinition.meta.requiredArtifacts)) { diff --git a/lighthouse-core/test/config/config-test.js b/lighthouse-core/test/config/config-test.js index 46453e9c5d17..c5efec818672 100644 --- a/lighthouse-core/test/config/config-test.js +++ b/lighthouse-core/test/config/config-test.js @@ -38,7 +38,8 @@ describe('Config', () => { name: 'MyAudit', category: 'mine', description: 'My audit', - helpText: '', + failureDescription: 'My failing audit', + helpText: '.', requiredArtifacts: [] }; } @@ -443,6 +444,7 @@ describe('Config', () => { name: 'custom-audit', category: 'none', description: 'none', + failureDescription: 'none', helpText: 'none', requiredArtifacts: [], }; diff --git a/lighthouse-core/test/fixtures/invalid-audits/missing-audit.js b/lighthouse-core/test/fixtures/invalid-audits/missing-audit.js index 3c3b82481e92..b91bedc71193 100644 --- a/lighthouse-core/test/fixtures/invalid-audits/missing-audit.js +++ b/lighthouse-core/test/fixtures/invalid-audits/missing-audit.js @@ -25,7 +25,7 @@ class MissingRequiredArtifacts extends LighthouseAudit { name: 'missing-category', category: 'Custom', description: 'Missing required artifacts', - helpText: '', + helpText: 'This is missing required artifacts', requiredArtifacts: ['HTML'] }; } diff --git a/lighthouse-core/test/fixtures/invalid-audits/missing-category.js b/lighthouse-core/test/fixtures/invalid-audits/missing-category.js index 3843f0e9e1d6..7564fb726a6d 100644 --- a/lighthouse-core/test/fixtures/invalid-audits/missing-category.js +++ b/lighthouse-core/test/fixtures/invalid-audits/missing-category.js @@ -24,7 +24,7 @@ class MissingRequiredArtifacts extends LighthouseAudit { return { name: 'missing-category', description: 'Missing required artifacts', - helpText: '', + helpText: 'This is missing a required category', requiredArtifacts: ['HTML'] }; } diff --git a/lighthouse-core/test/fixtures/invalid-audits/missing-description.js b/lighthouse-core/test/fixtures/invalid-audits/missing-description.js index 0a17474531c1..16c0fae4d617 100644 --- a/lighthouse-core/test/fixtures/invalid-audits/missing-description.js +++ b/lighthouse-core/test/fixtures/invalid-audits/missing-description.js @@ -24,7 +24,7 @@ class MissingRequiredArtifacts extends LighthouseAudit { return { name: 'missing-description', category: 'Custom', - helpText: '', + helpText: 'This is missing required description (and failure description)', requiredArtifacts: ['HTML'] }; } diff --git a/lighthouse-core/test/fixtures/invalid-audits/missing-generate-audit-result.js b/lighthouse-core/test/fixtures/invalid-audits/missing-generate-audit-result.js index 0e8d5cdd2af6..892d496909e8 100644 --- a/lighthouse-core/test/fixtures/invalid-audits/missing-generate-audit-result.js +++ b/lighthouse-core/test/fixtures/invalid-audits/missing-generate-audit-result.js @@ -23,7 +23,7 @@ class MissingRequiredArtifacts { category: 'Custom', name: 'missing-required-artifacts', description: 'Missing required artifacts', - helpText: '', + helpText: 'This is missing required artifacts', requiredArtifacts: ['HTML'] }; } diff --git a/lighthouse-core/test/fixtures/invalid-audits/missing-help-text.js b/lighthouse-core/test/fixtures/invalid-audits/missing-help-text.js index 57f468aa597e..d87cfe1ef178 100644 --- a/lighthouse-core/test/fixtures/invalid-audits/missing-help-text.js +++ b/lighthouse-core/test/fixtures/invalid-audits/missing-help-text.js @@ -25,6 +25,7 @@ class MissingRequiredArtifacts extends LighthouseAudit { name: 'missing-description', category: 'Custom', description: 'Missing required artifacts', + failureDescription: 'Missing required artifacts is failing', requiredArtifacts: ['HTML'] }; } diff --git a/lighthouse-core/test/fixtures/invalid-audits/missing-name.js b/lighthouse-core/test/fixtures/invalid-audits/missing-name.js index 2bbf96acf29e..92711c732f7c 100644 --- a/lighthouse-core/test/fixtures/invalid-audits/missing-name.js +++ b/lighthouse-core/test/fixtures/invalid-audits/missing-name.js @@ -24,7 +24,7 @@ class MissingRequiredArtifacts extends LighthouseAudit { return { category: 'Custom', description: 'Missing name', - helpText: '', + helpText: 'This is missing required name', requiredArtifacts: ['HTML'] }; } diff --git a/lighthouse-core/test/fixtures/invalid-audits/missing-required-artifacts.js b/lighthouse-core/test/fixtures/invalid-audits/missing-required-artifacts.js index 5f2ff71b8623..1bf64522a9ef 100644 --- a/lighthouse-core/test/fixtures/invalid-audits/missing-required-artifacts.js +++ b/lighthouse-core/test/fixtures/invalid-audits/missing-required-artifacts.js @@ -25,7 +25,8 @@ class MissingRequiredArtifacts extends LighthouseAudit { category: 'Custom', name: 'missing-required-artifacts', description: 'Missing required artifacts', - helpText: '', + failureDescription: 'Missing required artifacts is failing', + helpText: 'This is missing required artifacts', }; } diff --git a/lighthouse-core/test/fixtures/invalid-audits/require-error.js b/lighthouse-core/test/fixtures/invalid-audits/require-error.js index 2021dc297a4c..54902894d472 100644 --- a/lighthouse-core/test/fixtures/invalid-audits/require-error.js +++ b/lighthouse-core/test/fixtures/invalid-audits/require-error.js @@ -25,7 +25,7 @@ class RequireErrorAudit extends LighthouseAudit { name: 'require-error', category: 'Custom', description: 'Require Error', - helpText: '', + helpText: 'This one has a bad require()', requiredArtifacts: ['HTML'] }; } diff --git a/lighthouse-core/test/fixtures/valid-custom-audit.js b/lighthouse-core/test/fixtures/valid-custom-audit.js index 40532000582c..a3e17104bd3a 100644 --- a/lighthouse-core/test/fixtures/valid-custom-audit.js +++ b/lighthouse-core/test/fixtures/valid-custom-audit.js @@ -25,6 +25,7 @@ class ValidCustomAudit extends LighthouseAudit { name: 'valid-audit', category: 'Custom', description: 'Valid Audit', + failureDescription: 'Valid failing Audit', helpText: 'Valid-sounding helpText', requiredArtifacts: ['HTML'] }; diff --git a/lighthouse-core/test/report/v2/renderer/category-renderer-test.js b/lighthouse-core/test/report/v2/renderer/category-renderer-test.js index d99a71f7bfd6..336f2e0af454 100644 --- a/lighthouse-core/test/report/v2/renderer/category-renderer-test.js +++ b/lighthouse-core/test/report/v2/renderer/category-renderer-test.js @@ -59,12 +59,12 @@ describe('CategoryRenderer', () => { it('renders an audit debug str when appropriate', () => { const audit1 = renderer._renderAudit({ scoringMode: 'binary', score: 0, - result: {helpText: '', debugString: 'Debug string', description: 'Audit title'}, + result: {helpText: 'help text', debugString: 'Debug string', description: 'Audit title'}, }); assert.ok(audit1.querySelector('.lh-debug')); const audit2 = renderer._renderAudit({ - scoringMode: 'binary', score: 0, result: {helpText: '', description: 'Audit title'}, + scoringMode: 'binary', score: 0, result: {helpText: 'help text', description: 'Audit title'}, }); assert.ok(!audit2.querySelector('.lh-debug')); }); @@ -72,7 +72,7 @@ describe('CategoryRenderer', () => { it('renders an informative audit', () => { const auditDOM = renderer._renderAudit({ id: 'informative', score: 0, - result: {description: 'It informs', helpText: '', informative: true}, + result: {description: 'It informs', helpText: 'help text', informative: true}, }); assert.ok(auditDOM.querySelector('.lh-score--informative')); diff --git a/lighthouse-core/test/runner-test.js b/lighthouse-core/test/runner-test.js index fa7688e04c3c..3d0768dc3415 100644 --- a/lighthouse-core/test/runner-test.js +++ b/lighthouse-core/test/runner-test.js @@ -187,6 +187,7 @@ describe('Runner', () => { category: 'ThrowThrow', name: 'throwy-audit', description: 'Always throws', + failureDescription: 'Always throws is failing, natch', helpText: 'Test for always throwing', requiredArtifacts: [] };