From deb40506e733134c596d2d93bec3077389184352 Mon Sep 17 00:00:00 2001 From: Simen Bekkhus Date: Sat, 13 Jan 2018 16:27:41 +0100 Subject: [PATCH 1/2] fix(valid-expect): error on missing async matchers --- docs/rules/valid-expect.md | 2 ++ rules/__tests__/valid_expect.test.js | 30 ++++++++++++++++++++++++++++ rules/valid_expect.js | 9 ++++++++- 3 files changed, 40 insertions(+), 1 deletion(-) diff --git a/docs/rules/valid-expect.md b/docs/rules/valid-expect.md index 83249b63d..b01785ddc 100644 --- a/docs/rules/valid-expect.md +++ b/docs/rules/valid-expect.md @@ -32,6 +32,7 @@ expect().toEqual('something'); expect('something', 'else'); expect('something'); expect(true).toBeDefined; +expect(Promise.resolve('hello')).resolves; ``` The following patterns are not warnings: @@ -40,4 +41,5 @@ The following patterns are not warnings: expect('something').toEqual('something'); expect([1, 2, 3]).toEqual([1, 2, 3]); expect(true).toBeDefined(); +expect(Promise.resolve('hello')).resolves.toEqual('hello'); ``` diff --git a/rules/__tests__/valid_expect.test.js b/rules/__tests__/valid_expect.test.js index 1c6be5e95..8b1f17673 100644 --- a/rules/__tests__/valid_expect.test.js +++ b/rules/__tests__/valid_expect.test.js @@ -101,5 +101,35 @@ ruleTester.run('valid-expect', rules['valid-expect'], { }, ], }, + { + code: 'expect(true).resolves;', + errors: [ + { + endColumn: 22, + column: 14, + message: '"resolves" needs a matcher.', + }, + ], + }, + { + code: 'expect(true).rejects;', + errors: [ + { + endColumn: 21, + column: 14, + message: '"rejects" needs a matcher.', + }, + ], + }, + { + code: 'expect(true).not;', + errors: [ + { + endColumn: 17, + column: 14, + message: '"not" needs a matcher.', + }, + ], + }, ], }); diff --git a/rules/valid_expect.js b/rules/valid_expect.js index 1b37e3ed4..674d20b0e 100644 --- a/rules/valid_expect.js +++ b/rules/valid_expect.js @@ -83,11 +83,18 @@ module.exports = context => { // matcher was not called if (grandParent.type === 'ExpressionStatement') { + let message; + if (expectProperties.indexOf(propertyName) > -1) { + message = `"${propertyName}" needs a matcher.`; + } else { + message = `"${propertyName}" was not called.`; + } + context.report({ // For some reason `endColumn` isn't set in tests if `loc` is not // added loc: parentProperty.loc, - message: `"${propertyName}" was not called.`, + message, node: parentProperty, }); } From 146dcb72b140eeb030890575b57c00d6073e44a1 Mon Sep 17 00:00:00 2001 From: Simen Bekkhus Date: Sat, 13 Jan 2018 17:47:10 +0100 Subject: [PATCH 2/2] refactor: change message --- rules/__tests__/valid_expect.test.js | 6 +++--- rules/valid_expect.js | 2 +- 2 files changed, 4 insertions(+), 4 deletions(-) diff --git a/rules/__tests__/valid_expect.test.js b/rules/__tests__/valid_expect.test.js index 8b1f17673..ed74b6463 100644 --- a/rules/__tests__/valid_expect.test.js +++ b/rules/__tests__/valid_expect.test.js @@ -107,7 +107,7 @@ ruleTester.run('valid-expect', rules['valid-expect'], { { endColumn: 22, column: 14, - message: '"resolves" needs a matcher.', + message: '"resolves" needs to call a matcher.', }, ], }, @@ -117,7 +117,7 @@ ruleTester.run('valid-expect', rules['valid-expect'], { { endColumn: 21, column: 14, - message: '"rejects" needs a matcher.', + message: '"rejects" needs to call a matcher.', }, ], }, @@ -127,7 +127,7 @@ ruleTester.run('valid-expect', rules['valid-expect'], { { endColumn: 17, column: 14, - message: '"not" needs a matcher.', + message: '"not" needs to call a matcher.', }, ], }, diff --git a/rules/valid_expect.js b/rules/valid_expect.js index 674d20b0e..401c013b3 100644 --- a/rules/valid_expect.js +++ b/rules/valid_expect.js @@ -85,7 +85,7 @@ module.exports = context => { if (grandParent.type === 'ExpressionStatement') { let message; if (expectProperties.indexOf(propertyName) > -1) { - message = `"${propertyName}" needs a matcher.`; + message = `"${propertyName}" needs to call a matcher.`; } else { message = `"${propertyName}" was not called.`; }