Skip to content

Commit

Permalink
Expand renamed-package-scope rule
Browse files Browse the repository at this point in the history
  • Loading branch information
connor-baer committed Oct 23, 2024
1 parent 25a475c commit 46c6fd7
Show file tree
Hide file tree
Showing 3 changed files with 122 additions and 11 deletions.
5 changes: 5 additions & 0 deletions .changeset/metal-games-knock.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
---
'@sumup-oss/eslint-plugin-circuit-ui': minor
---

Expanded the `renamed-package-scope` ESLint rule to cover additional occurrences of package names, for example in Jest module mocks.
Original file line number Diff line number Diff line change
Expand Up @@ -78,5 +78,63 @@ ruleTester.run('renamed-package-scope', renamedPackageScope, {
`,
errors: [{ messageId: 'refactor' }],
},
{
name: 'dynamic import from the old package scope',
code: `
const components = await import('@sumup/circuit-ui');
`,
output: `
const components = await import('@sumup-oss/circuit-ui');
`,
errors: [{ messageId: 'refactor' }],
},
{
name: 'module mock of the old package scope',
code: `
jest.mock('@sumup/circuit-ui');
jest.mock('@sumup/intl', () => ({
...jest.requireActual('@sumup/intl'),
formatNumber: jest.fn(),
}));
`,
output: `
jest.mock('@sumup-oss/circuit-ui');
jest.mock('@sumup-oss/intl', () => ({
...jest.requireActual('@sumup-oss/intl'),
formatNumber: jest.fn(),
}));
`,
errors: [
{ messageId: 'refactor' },
{ messageId: 'refactor' },
{ messageId: 'refactor' },
],
},
{
name: 'module mock of the old package scope with type annotations',
code: `
vi.mock('@sumup/circuit-ui', () => ({
...vi.importActual<typeof import('@sumup/circuit-ui')>(
'@sumup/circuit-ui',
),
useCollapsible: vi.fn(),
}));
`,
output: `
vi.mock('@sumup-oss/circuit-ui', () => ({
...vi.importActual<typeof import('@sumup-oss/circuit-ui')>(
'@sumup-oss/circuit-ui',
),
useCollapsible: vi.fn(),
}));
`,
errors: [
{ messageId: 'refactor' },
{ messageId: 'refactor' },
{ messageId: 'refactor' },
],
},
],
});
70 changes: 59 additions & 11 deletions packages/eslint-plugin-circuit-ui/renamed-package-scope/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -66,21 +66,69 @@ export const renamedPackageScope = createRule({
// See https://eslint.org/docs/latest/extend/selectors#known-issues
const escapedFrom = from.replace('/', '\\u002F');

function fixPackageName(node: TSESTree.Node | TSESTree.Token) {
context.report({
node,
messageId: 'refactor',
data: { from, to },
fix(fixer) {
return fixer.replaceText(
node,
context.sourceCode.getText(node).replace(from, to),
);
},
});
}

return Object.assign(visitors, {
[`ImportDeclaration:has(Literal[value=/${escapedFrom}(?!-).*/])`]: (
node: TSESTree.ImportDeclaration,
) => {
context.report({
node,
messageId: 'refactor',
data: { from, to },
fix(fixer) {
return fixer.replaceText(
node,
context.sourceCode.getText(node).replace(from, to),
);
},
});
const { source } = node;

if (source.type !== 'Literal') {
return;
}

fixPackageName(source);
},
[`ImportExpression:has(Literal[value=/${escapedFrom}(?!-).*/])`]: (
node: TSESTree.ImportExpression,
) => {
const { source } = node;

if (source.type !== 'Literal') {
return;
}

fixPackageName(source);
},
[`CallExpression:has(Identifier[name=/(mock|requireActual|importActual)/]):has(Literal[value=/${escapedFrom}(?!-).*/])`]:
(node: TSESTree.CallExpression) => {
const firstArg = node.arguments[0];

if (firstArg.type !== 'Literal') {
return;
}

fixPackageName(firstArg);
},
[`TSImportType:has(Literal[value=/${escapedFrom}(?!-).*/])`]: (
node: TSESTree.TSImportType,
) => {
const { argument } = node;

if (argument.type !== 'TSLiteralType') {
return;
}

const { literal } = argument;

if (literal.type !== 'Literal') {
return;
}

fixPackageName(literal);
},
});
}, {});
Expand Down

0 comments on commit 46c6fd7

Please sign in to comment.