Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat(eslint-plugin): support Eslint 9 and 8 simultaneously #7072

Open
wants to merge 49 commits into
base: main
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
49 commits
Select commit Hold shift + click to select a range
33904d7
feat: let eslint-plugin-qwink support Eslint 9 and 8 simultaneously
Nov 19, 2024
93f850e
feat: let eslint-plugin-qwink support Eslint 9 and 8 simultaneously
Nov 19, 2024
83909c4
Merge branch 'main' into 6048_eslint-flag
JerryWu1234 Nov 19, 2024
6953229
Merge branch 'main' into 6048_eslint-flag
JerryWu1234 Nov 22, 2024
efb017d
support 8 and 9
Nov 22, 2024
f2bdd0d
Merge branch '6048_eslint-flag' of https://github.com/JerryWu1234/qwi…
Nov 22, 2024
5c0723e
upgrade
Nov 22, 2024
0738804
upgrade
Nov 22, 2024
5ed62c5
upgrade
Nov 22, 2024
35ccf83
upgrade
Nov 22, 2024
df6f8f9
Merge branch '6048_eslint-flag' of https://github.com/JerryWu1234/qwi…
Nov 22, 2024
fc3aa53
Update qwik-binding-map.ts
JerryWu1234 Nov 22, 2024
f6d7862
upgrade
Nov 22, 2024
af55f94
upgrade
Nov 22, 2024
64b5c11
upgrade
Nov 22, 2024
cce51f0
upgrade
Nov 22, 2024
20a6fd4
upgrade
Nov 22, 2024
0bda546
upgrade
Nov 22, 2024
02cba46
fix
Nov 22, 2024
5701e52
Merge branch 'main' into 6048_eslint-flag
JerryWu1234 Nov 27, 2024
0f75492
Merge branch 'main' into 6048_eslint-flag
JerryWu1234 Nov 28, 2024
2458862
fix
Nov 28, 2024
b82a195
Merge branch '6048_eslint-flag' of https://github.com/JerryWu1234/qwi…
Nov 28, 2024
278a5df
Merge branch 'main' into 6048_eslint-flag
JerryWu1234 Nov 29, 2024
d378168
Merge branch 'main' into 6048_eslint-flag
JerryWu1234 Dec 6, 2024
0dab706
Merge branch 'main' into 6048_eslint-flag
JerryWu1234 Dec 10, 2024
fc93083
fix
JerryWu1234 Dec 11, 2024
07427ad
Merge branch 'main' into 6048_eslint-flag
JerryWu1234 Dec 11, 2024
13efa82
fix
JerryWu1234 Dec 11, 2024
939f856
Merge branch '6048_eslint-flag' of https://github.com/JerryWu1234/qwi…
JerryWu1234 Dec 11, 2024
13421f3
fix
JerryWu1234 Dec 12, 2024
88efe1b
Merge branch 'main' into 6048_eslint-flag
JerryWu1234 Dec 13, 2024
3a5aae2
Merge branch 'main' into 6048_eslint-flag
JerryWu1234 Dec 27, 2024
1276d1e
Merge branch 'main' into 6048_eslint-flag
JerryWu1234 Dec 31, 2024
aa1d5fb
fix
Dec 31, 2024
5f4e62e
Merge branch 'main' into 6048_eslint-flag
JerryWu1234 Jan 12, 2025
142761d
Update breezy-toes-help.md
JerryWu1234 Jan 18, 2025
c16404b
fix error ts
JerryWu1234 Jan 25, 2025
692b768
fix error when using in eslint 9
JerryWu1234 Jan 25, 2025
43cff26
fix get an error when getscope no param
JerryWu1234 Jan 25, 2025
b34da96
test
JerryWu1234 Jan 25, 2025
8f1fa6c
test
JerryWu1234 Jan 25, 2025
6ab2780
fix console
JerryWu1234 Jan 25, 2025
7ea5e59
fix ts an error
JerryWu1234 Jan 25, 2025
f348826
fix ts an error
JerryWu1234 Jan 25, 2025
a4946d3
fix dependency error
JerryWu1234 Jan 25, 2025
e1993a5
fix
JerryWu1234 Jan 25, 2025
b0b17aa
fix: appear an error when @types/eslint is 9 version
JerryWu1234 Jan 26, 2025
f2aca1c
Merge branch 'main' into 6048_eslint-flag
JerryWu1234 Jan 26, 2025
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
5 changes: 5 additions & 0 deletions .changeset/breezy-toes-help.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
---
'eslint-plugin-qwik': minor
---

let eslint-plugin-qwik support Eslint 9 and 8 simultaneously
2 changes: 1 addition & 1 deletion e2e/qwik-cli-e2e/utils/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -67,7 +67,7 @@ function replacePackagesWithLocalOnes(tmpDir: string) {
for (const { name, absolutePath } of tarballConfig) {
patchPackageJsonForPlugin(tmpDir, name, absolutePath);
}
execSync('npm i', {
execSync('pnpm i', {
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Why is this change needed?

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

did you guys discuss it? what was the answer?

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@JerryWu1234 what happens if you leave this as npm?

cwd: tmpDir,
// only output errors
stdio: ['ignore', 'ignore', 'inherit'],
Expand Down
10 changes: 10 additions & 0 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,16 @@
"config": {
"syncpack": {
"versionGroups": [
{
"label": "Allow ESLint 9 types in eslint-plugin-qwik",
"dependencies": [
"@types/eslint"
],
"packages": [
"eslint-plugin-qwik"
],
"policy": "matches@9.6.1"
},
{
"label": "Be lenient in vite versions for prod. v4 is broken, v5 is good",
"dependencyTypes": [
Expand Down
88 changes: 60 additions & 28 deletions packages/eslint-plugin-qwik/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -9,8 +9,9 @@ import { preferClasslist } from './src/preferClasslist';
import { unusedServer } from './src/unusedServer';
import { useMethodUsage } from './src/useMethodUsage';
import { validLexicalScope } from './src/validLexicalScope';
import pkg from './package.json';

export const rules = {
const rules = {
'use-method-usage': useMethodUsage,
'valid-lexical-scope': validLexicalScope,
'loader-location': loaderLocation,
Expand All @@ -24,37 +25,68 @@ export const rules = {
'no-use-visible-task': noUseVisibleTask,
};

export const configs = {
const recommendedRules = {
'qwik/use-method-usage': 'error',
'qwik/valid-lexical-scope': 'error',
'qwik/no-react-props': 'error',
'qwik/prefer-classlist': 'warn',
'qwik/jsx-no-script-url': 'warn',
'qwik/loader-location': 'warn',
'qwik/jsx-key': 'warn',
'qwik/unused-server': 'error',
'qwik/jsx-img': 'warn',
'qwik/jsx-a': 'warn',
'qwik/no-use-visible-task': 'warn',
};
const strictRules = {
'qwik/valid-lexical-scope': 'error',
'qwik/use-method-usage': 'error',
'qwik/loader-location': 'error',
'qwik/no-react-props': 'error',
'qwik/prefer-classlist': 'error',
'qwik/jsx-no-script-url': 'error',
'qwik/jsx-key': 'error',
'qwik/unused-server': 'error',
'qwik/jsx-img': 'error',
'qwik/jsx-a': 'error',
'qwik/no-use-visible-task': 'warn',
};

const configs = {
recommended: {
plugins: ['qwik'],
rules: {
'qwik/use-method-usage': 'error',
'qwik/valid-lexical-scope': 'error',
'qwik/no-react-props': 'error',
'qwik/prefer-classlist': 'warn',
'qwik/jsx-no-script-url': 'warn',
'qwik/loader-location': 'warn',
'qwik/jsx-key': 'warn',
'qwik/unused-server': 'error',
'qwik/jsx-img': 'warn',
'qwik/jsx-a': 'warn',
'qwik/no-use-visible-task': 'warn',
},
rules: recommendedRules,
},
strict: {
plugins: ['qwik'],
rules: {
'qwik/valid-lexical-scope': 'error',
'qwik/use-method-usage': 'error',
'qwik/loader-location': 'error',
'qwik/no-react-props': 'error',
'qwik/prefer-classlist': 'error',
'qwik/jsx-no-script-url': 'error',
'qwik/jsx-key': 'error',
'qwik/unused-server': 'error',
'qwik/jsx-img': 'error',
'qwik/jsx-a': 'error',
'qwik/no-use-visible-task': 'warn',
},
rules: strictRules,
},
};

const qwikEslint9Plugin = {
configs: {
recommended: [
{
plugins: {
qwik: this,
},
rules: recommendedRules,
},
],
strict: [
{
plugins: {
qwik: this,
},
rules: strictRules,
},
],
},
meta: {
name: pkg.name,
version: pkg.version,
},
rules,
};

export { configs, qwikEslint9Plugin, rules };
9 changes: 3 additions & 6 deletions packages/eslint-plugin-qwik/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -11,10 +11,10 @@
"devDependencies": {
"@builder.io/qwik": "workspace:^",
"@builder.io/qwik-city": "workspace:^",
"@types/eslint": "8.56.10",
"@types/estree": "1.0.5",
"@typescript-eslint/rule-tester": "7.8.0",
"redent": "4.0.0"
"@typescript-eslint/rule-tester": "8.14.0",
"redent": "4.0.0",
"@types/eslint": "9.6.1"
},
"engines": {
"node": ">=16.8.0 <18.0.0 || >=18.11"
Expand All @@ -31,9 +31,6 @@
],
"license": "MIT",
"main": "dist/index.js",
"peerDependencies": {
"eslint": "^8.57.0"
},
"repository": {
"type": "git",
"url": "https://github.com/QwikDev/qwik.git",
Expand Down
32 changes: 17 additions & 15 deletions packages/eslint-plugin-qwik/qwik.unit.ts
Original file line number Diff line number Diff line change
@@ -1,7 +1,5 @@
import * as vitest from 'vitest';
// @ts-ignore
import { RuleTester } from '@typescript-eslint/rule-tester';

import { RuleTester, type RuleTesterConfig } from '@typescript-eslint/rule-tester';
import { fileURLToPath } from 'node:url';
import { rules } from './index';
import { readdir, readFile, stat } from 'node:fs/promises';
Expand All @@ -14,22 +12,26 @@ RuleTester.itOnly = vitest.it.only;
RuleTester.describe = vitest.describe;

const testConfig = {
parser: '@typescript-eslint/parser',
env: {
es6: true,
rules: {
'no-console': 'error',
},
parserOptions: {
tsconfigRootDir: fileURLToPath(new URL('.', import.meta.url)),
project: ['./tests/tsconfig.json'],
ecmaFeatures: {
jsx: true,
languageOptions: {
parserOptions: {
projectService: {
allowDefaultProject: ['*.ts*'],
},
sourceType: 'module',
ecmaFeatures: {
jsx: true,
},
ecmaVersion: 2024,
project: ['./tests/tsconfig.json'],
tsconfigRootDir: fileURLToPath(new URL('.', import.meta.url)),
},
ecmaVersion: 2020,
sourceType: 'module',
},
};
} as RuleTesterConfig;

const ruleTester = new RuleTester(testConfig as any);
const ruleTester = new RuleTester(testConfig);
interface TestCase {
name: string;
filename: string;
Expand Down
3 changes: 2 additions & 1 deletion packages/eslint-plugin-qwik/src/jsxKey.ts
Original file line number Diff line number Diff line change
Expand Up @@ -60,7 +60,8 @@ export const jsxKey = {
},

create(context) {
const modifyJsxSource = context.sourceCode
const sourceCode = context.sourceCode ?? context.getSourceCode();
const modifyJsxSource = sourceCode
.getAllComments()
.some((c) => c.value.includes('@jsxImportSource'));
if (modifyJsxSource) {
Expand Down
3 changes: 2 additions & 1 deletion packages/eslint-plugin-qwik/src/jsxNoScriptUrl.ts
Original file line number Diff line number Diff line change
Expand Up @@ -31,12 +31,13 @@ export const jsxNoScriptUrl = {
},
},
create(context) {
const sourceCode = context.sourceCode ?? context.getSourceCode();
return {
JSXAttribute(node) {
if (node.name.type === 'JSXIdentifier' && node.value) {
const link = getStaticValue(
node.value.type === 'JSXExpressionContainer' ? node.value.expression : node.value,
context.getScope()
sourceCode.getScope ? sourceCode.getScope(node) : context.getScope()
);
if (link && typeof link.value === 'string' && isJavaScriptProtocol.test(link.value)) {
context.report({
Expand Down
2 changes: 1 addition & 1 deletion packages/eslint-plugin-qwik/src/loaderLocation.ts
Original file line number Diff line number Diff line change
Expand Up @@ -55,7 +55,7 @@ If you understand this, you can disable this warning with:
},
create(context) {
const routesDir = context.options?.[0]?.routesDir ?? 'src/routes';
const path = normalizePath(context.getFilename());
const path = normalizePath(context.filename ?? context.getFilename());
const isLayout = /\/layout(|!|-.+)\.(j|t)sx?$/.test(path);
const isIndex = /\/index(|!|@.+)\.(j|t)sx?$/.test(path);
const isPlugin = /\/plugin(|@.+)\.(j|t)sx?$/.test(path);
Expand Down
3 changes: 2 additions & 1 deletion packages/eslint-plugin-qwik/src/useMethodUsage.ts
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,8 @@ export const useMethodUsage: Rule.RuleModule = {
},
},
create(context) {
const modifyJsxSource = context.sourceCode
const sourceCode = context.sourceCode ?? context.getSourceCode();
const modifyJsxSource = sourceCode
.getAllComments()
.some((c) => c.value.includes('@jsxImportSource'));
if (modifyJsxSource) {
Expand Down
Loading
Loading