diff --git a/lib/utils/index.js b/lib/utils/index.js index b6dcdb8ce..9671c00d4 100644 --- a/lib/utils/index.js +++ b/lib/utils/index.js @@ -3133,7 +3133,7 @@ function getWithDefaultsProps(node) { for (const prop of param.properties) { if (prop.type !== 'Property') { - return {} + continue } const name = getStaticPropertyName(prop) if (name != null) { diff --git a/tests/lib/rules/require-default-prop.js b/tests/lib/rules/require-default-prop.js index 97aea4919..834f319aa 100644 --- a/tests/lib/rules/require-default-prop.js +++ b/tests/lib/rules/require-default-prop.js @@ -329,6 +329,28 @@ ruleTester.run('require-default-prop', rule, { ...languageOptions, parserOptions: { parser: require.resolve('@typescript-eslint/parser') } } + }, + { + filename: 'test.vue', + code: ` + + `, + languageOptions: { + parser: require('vue-eslint-parser'), + ...languageOptions, + parserOptions: { parser: require.resolve('@typescript-eslint/parser') } + } } ], @@ -544,6 +566,33 @@ ruleTester.run('require-default-prop', rule, { ...languageOptions } }, + { + filename: 'test.vue', + code: ` + + `, + errors: [ + { + message: "Prop 'bar' requires default value to be set.", + line: 8 + } + ], + languageOptions: { + parser: require('vue-eslint-parser'), + ...languageOptions, + parserOptions: { parser: require.resolve('@typescript-eslint/parser') } + } + }, ...(semver.lt( require('@typescript-eslint/parser/package.json').version, '4.0.0'