diff --git a/docs/rules/no-unlocalized-strings.md b/docs/rules/no-unlocalized-strings.md index 836fcd0..402e0ae 100644 --- a/docs/rules/no-unlocalized-strings.md +++ b/docs/rules/no-unlocalized-strings.md @@ -16,9 +16,9 @@ The rule doesn’t come with built-in ignore settings because each project is un "error", { "ignore": [ - // Ignore strings that don’t start with an uppercase letter - // or don't contain two words separated by whitespace - "^(?![A-Z].*|\\w+\\s\\w+).+$", + // Ignore strings which are a single "word" (no spaces) + // and doesn't start with an uppercase letter + "^(?![A-Z])\\S+$", // Ignore UPPERCASE literals // Example: const test = "FOO" "^[A-Z0-9_-]+$" @@ -60,7 +60,7 @@ The rule doesn’t come with built-in ignore settings because each project is un ], // Following settings require typed linting https://typescript-eslint.io/getting-started/typed-linting/ "useTsTypes": true, - "ignoreMethodsOnType": [ + "ignoreMethodsOnTypes": [ // Ignore specified methods on Map and Set types "Map.get", "Map.has", diff --git a/src/rules/no-unlocalized-strings.ts b/src/rules/no-unlocalized-strings.ts index 24d244c..490015d 100644 --- a/src/rules/no-unlocalized-strings.ts +++ b/src/rules/no-unlocalized-strings.ts @@ -243,7 +243,7 @@ export const rule = createRule({ visited.add(node) const text = getText(node) - if (!text || isIgnoredSymbol(text)) { + if (!text || isIgnoredSymbol(text) || isTextWhiteListed(text)) { return } @@ -481,9 +481,9 @@ export const rule = createRule({ }, 'TemplateLiteral:exit'(node: TSESTree.TemplateLiteral) { if (visited.has(node)) return - const quasisValue = getText(node) + const text = getText(node) - if (isTextWhiteListed(quasisValue)) return + if (!text || isTextWhiteListed(text)) return context.report({ node, messageId: 'default' }) }, diff --git a/tests/src/rules/no-unlocalized-strings.test.ts b/tests/src/rules/no-unlocalized-strings.test.ts index bdaa34f..9d302dd 100644 --- a/tests/src/rules/no-unlocalized-strings.test.ts +++ b/tests/src/rules/no-unlocalized-strings.test.ts @@ -35,6 +35,18 @@ ruleTester.run(name, rule, { name: 'should ignore non word strings 2', code: 'const a = `0123456789!@#$%^&*()_+|~-=\\`[]{};\':",./<>?`;', }, + { + name: 'should ignore strings containing only variables', + code: 'const t = `${BRAND_NAME}`', + }, + { + name: 'should ignore strings containing few variables', + code: 'const t = `${BRAND_NAME}${BRAND_NAME}`', + }, + { + name: 'should ignore strings containing few variables with spaces', + code: 'const t = ` ${BRAND_NAME} ${BRAND_NAME} `', + }, { code: 'hello("Hello")', options: [{ ignoreFunctions: ['hello'] }], @@ -92,6 +104,15 @@ ruleTester.run(name, rule, { // // JSX { code: '
' }, { code: '
' }, + { + name: 'Should ignore non-word strings in the JSX Text', + code: `+`, + }, + { + name: 'Should JSX Text if it matches the ignore option', + code: `foo`, + options: [{ ignore: ['^foo'] }], + }, { code: '
' }, { code: '
' }, { code: '
{i18n._("foo")}
' }, @@ -125,6 +146,10 @@ ruleTester.run(name, rule, { { code: '' }, { code: '`, + }, { code: '
', options: [{ ignoreNames: ['foo'] }] }, { code: '
', options: [{ ignoreNames: ['foo'] }] }, { @@ -362,6 +387,12 @@ jsxTester.run('no-unlocalized-strings', rule, { valid: [ { code: '{ i18n._("abc") }' }, { code: '{ i18n._(`abc`) }' }, + { + name: 'Should not flag the JSX text with only spaces and interpolations', + code: ` + {variable} + `, + }, { code: 'Hello' }, { code: 'Hello' }, { @@ -415,3 +446,27 @@ jsxTester.run('no-unlocalized-strings', rule, { }, ], }) + +/** + * This test is covering the ignore regex proposed in the documentation + * This regex doesn't used directly in the code. + */ +describe('Default ignore regex', () => { + const regex = '^(?![A-Z])\\S+$' + + test.each([ + ['hello', true], + ['helloMyVar', true], + ['package.json', true], + ['./src/**/*.test*', true], + ['camel_case', true], + + // Start from capital letter + ['Hello', false], + // Multiword string (has space) + ['hello world', false], + ['Hello World', false], + ])('validate %s', (str, pass) => { + expect(new RegExp(regex).test(str)).toBe(pass) + }) +})