From 6440590d38c08b34f78cfca1f36d801249828cf5 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Mat=C4=9Bj=20Chalk?= Date: Mon, 9 Oct 2023 14:15:07 +0200 Subject: [PATCH] test(plugin-eslint): add test case and improve test docs --- packages/plugin-eslint/src/lib/eslint-plugin.spec.ts | 8 ++++++++ packages/plugin-eslint/src/lib/meta/rules.spec.ts | 11 ++++++++--- 2 files changed, 16 insertions(+), 3 deletions(-) diff --git a/packages/plugin-eslint/src/lib/eslint-plugin.spec.ts b/packages/plugin-eslint/src/lib/eslint-plugin.spec.ts index 365f68638..66a9ba989 100644 --- a/packages/plugin-eslint/src/lib/eslint-plugin.spec.ts +++ b/packages/plugin-eslint/src/lib/eslint-plugin.spec.ts @@ -48,4 +48,12 @@ describe('eslintPlugin', () => { eslintPlugin({ eslintrc: '.eslintrc.json' }), ).rejects.toThrowError('patterns'); }); + + it("should throw if eslintrc file doesn't exist", async () => { + await expect( + eslintPlugin({ eslintrc: '.eslintrc.yml', patterns: '**/*.js' }), + ).rejects.toThrowError( + 'Failed to load config ".eslintrc.yml" to extend from', + ); + }); }); diff --git a/packages/plugin-eslint/src/lib/meta/rules.spec.ts b/packages/plugin-eslint/src/lib/meta/rules.spec.ts index 54c3e002e..e783e264c 100644 --- a/packages/plugin-eslint/src/lib/meta/rules.spec.ts +++ b/packages/plugin-eslint/src/lib/meta/rules.spec.ts @@ -90,7 +90,7 @@ describe('listRules', () => { }); }); - describe('Nx monorepo', () => { + describe('Nx monorepo project', () => { const nxRootDir = join(fixturesDir, 'nx-monorepo'); const eslintrc = join(nxRootDir, 'packages/utils/.eslintrc.json'); @@ -109,6 +109,7 @@ describe('listRules', () => { }); it('should include explicitly set plugin rule with custom options', async () => { + // set in root .eslintrc.json await expect(listRules(eslint, patterns)).resolves.toContainEqual({ ruleId: '@nx/enforce-module-boundaries', meta: { @@ -146,6 +147,7 @@ describe('listRules', () => { }); it('should include built-in rule set implicitly by extending recommended config', async () => { + // extended via @nx/typescript -> @typescript-eslint/eslint-recommended await expect(listRules(eslint, patterns)).resolves.toContainEqual({ ruleId: 'no-var', meta: { @@ -166,6 +168,7 @@ describe('listRules', () => { }); it('should include plugin rule set implicitly by extending recommended config', async () => { + // extended via @nx/typescript -> @typescript-eslint/recommended await expect(listRules(eslint, patterns)).resolves.toContainEqual({ ruleId: '@typescript-eslint/no-extra-semi', meta: { @@ -188,7 +191,8 @@ describe('listRules', () => { } satisfies RuleData); }); - it('should not include rule which was turned off', async () => { + it('should not include rule which was turned off in extended config', async () => { + // extended TypeScript config sets "no-extra-semi": "off" await expect(listRules(eslint, patterns)).resolves.not.toContainEqual( expect.objectContaining({ ruleId: 'no-extra-semi', @@ -196,7 +200,8 @@ describe('listRules', () => { ); }); - it('should include rule added by to root config by project config', async () => { + it('should include rule added to root config by project config', async () => { + // set only in packages/utils/.eslintrc.json await expect(listRules(eslint, patterns)).resolves.toContainEqual({ ruleId: '@nx/dependency-checks', meta: {