@prairielearn/eslint-plugin 2.1.3 → 2.1.5
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +12 -0
- package/dist/tests/aws-client-mandatory-config.test.js +4 -1
- package/dist/tests/aws-client-mandatory-config.test.js.map +1 -1
- package/dist/tests/aws-client-shared-config.test.js +4 -1
- package/dist/tests/aws-client-shared-config.test.js.map +1 -1
- package/dist/tests/jsx-no-dollar-interpolation.test.js +4 -1
- package/dist/tests/jsx-no-dollar-interpolation.test.js.map +1 -1
- package/package.json +9 -23
- package/src/tests/aws-client-mandatory-config.test.ts +4 -1
- package/src/tests/aws-client-shared-config.test.ts +4 -1
- package/src/tests/jsx-no-dollar-interpolation.test.ts +4 -1
- package/tsconfig.json +1 -1
- package/vitest.config.ts +11 -0
package/CHANGELOG.md
CHANGED
|
@@ -1,8 +1,11 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
const rule_tester_1 = require("@typescript-eslint/rule-tester");
|
|
4
|
+
const vitest_1 = require("vitest");
|
|
4
5
|
const aws_client_mandatory_config_1 = require("../rules/aws-client-mandatory-config");
|
|
5
|
-
rule_tester_1.RuleTester.afterAll =
|
|
6
|
+
rule_tester_1.RuleTester.afterAll = vitest_1.afterAll;
|
|
7
|
+
rule_tester_1.RuleTester.describe = vitest_1.describe;
|
|
8
|
+
rule_tester_1.RuleTester.it = vitest_1.it;
|
|
6
9
|
const ruleTester = new rule_tester_1.RuleTester();
|
|
7
10
|
ruleTester.run('aws-client-mandatory-config', aws_client_mandatory_config_1.default, {
|
|
8
11
|
valid: [
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"aws-client-mandatory-config.test.js","sourceRoot":"","sources":["../../src/tests/aws-client-mandatory-config.test.ts"],"names":[],"mappings":";;AAAA,gEAA4D;
|
|
1
|
+
{"version":3,"file":"aws-client-mandatory-config.test.js","sourceRoot":"","sources":["../../src/tests/aws-client-mandatory-config.test.ts"],"names":[],"mappings":";;AAAA,gEAA4D;AAC5D,mCAAgD;AAEhD,sFAAwD;AAExD,wBAAU,CAAC,QAAQ,GAAG,iBAAQ,CAAC;AAC/B,wBAAU,CAAC,QAAQ,GAAG,iBAAQ,CAAC;AAC/B,wBAAU,CAAC,EAAE,GAAG,WAAE,CAAC;AAEnB,MAAM,UAAU,GAAG,IAAI,wBAAU,EAAE,CAAC;AAEpC,UAAU,CAAC,GAAG,CAAC,6BAA6B,EAAE,qCAAI,EAAE;IAClD,KAAK,EAAE;QACL;YACE,IAAI,EAAE,0EAA0E;SACjF;QACD;YACE,IAAI,EAAE,sFAAsF;SAC7F;QACD;YACE,IAAI,EAAE,6EAA6E;SACpF;QACD;YACE,IAAI,EAAE,yFAAyF;SAChG;KACF;IACD,OAAO,EAAE;QACP;YACE,IAAI,EAAE,mDAAmD;YACzD,MAAM,EAAE,CAAC,EAAE,SAAS,EAAE,eAAe,EAAE,CAAC;SACzC;KACF;CACF,CAAC,CAAC","sourcesContent":["import { RuleTester } from '@typescript-eslint/rule-tester';\nimport { afterAll, describe, it } from 'vitest';\n\nimport rule from '../rules/aws-client-mandatory-config';\n\nRuleTester.afterAll = afterAll;\nRuleTester.describe = describe;\nRuleTester.it = it;\n\nconst ruleTester = new RuleTester();\n\nruleTester.run('aws-client-mandatory-config', rule, {\n valid: [\n {\n code: \"import { S3 } from '@aws-sdk/client-s3'; new S3({ region: 'us-east-2' })\",\n },\n {\n code: \"import { S3Client } from '@aws-sdk/client-s3'; new S3Client({ region: 'us-east-2' })\",\n },\n {\n code: \"import { EC2 } from '@aws-sdk/client-ec2'; new EC2({ region: 'us-east-2' })\",\n },\n {\n code: \"import { EC2Client } from '@aws-sdk/client-ec2'; new EC2Client({ region: 'us-east-2' })\",\n },\n ],\n invalid: [\n {\n code: \"import { S3 } from '@aws-sdk/client-s3'; new S3()\",\n errors: [{ messageId: 'missingConfig' }],\n },\n ],\n});\n"]}
|
|
@@ -1,8 +1,11 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
const rule_tester_1 = require("@typescript-eslint/rule-tester");
|
|
4
|
+
const vitest_1 = require("vitest");
|
|
4
5
|
const aws_client_shared_config_1 = require("../rules/aws-client-shared-config");
|
|
5
|
-
rule_tester_1.RuleTester.afterAll =
|
|
6
|
+
rule_tester_1.RuleTester.afterAll = vitest_1.afterAll;
|
|
7
|
+
rule_tester_1.RuleTester.describe = vitest_1.describe;
|
|
8
|
+
rule_tester_1.RuleTester.it = vitest_1.it;
|
|
6
9
|
const ruleTester = new rule_tester_1.RuleTester();
|
|
7
10
|
ruleTester.run('aws-client-shared-config', aws_client_shared_config_1.default, {
|
|
8
11
|
valid: [
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"aws-client-shared-config.test.js","sourceRoot":"","sources":["../../src/tests/aws-client-shared-config.test.ts"],"names":[],"mappings":";;AAAA,gEAA4D;
|
|
1
|
+
{"version":3,"file":"aws-client-shared-config.test.js","sourceRoot":"","sources":["../../src/tests/aws-client-shared-config.test.ts"],"names":[],"mappings":";;AAAA,gEAA4D;AAC5D,mCAAgD;AAEhD,gFAAqD;AAErD,wBAAU,CAAC,QAAQ,GAAG,iBAAQ,CAAC;AAC/B,wBAAU,CAAC,QAAQ,GAAG,iBAAQ,CAAC;AAC/B,wBAAU,CAAC,EAAE,GAAG,WAAE,CAAC;AAEnB,MAAM,UAAU,GAAG,IAAI,wBAAU,EAAE,CAAC;AAEpC,UAAU,CAAC,GAAG,CAAC,0BAA0B,EAAE,kCAAI,EAAE;IAC/C,KAAK,EAAE;QACL;YACE,IAAI,EAAE,wEAAwE;SAC/E;QACD;YACE,IAAI,EAAE,oFAAoF;SAC3F;QACD;YACE,IAAI,EAAE,4EAA4E;SACnF;QACD;YACE,IAAI,EAAE,wFAAwF;SAC/F;QACD;YACE,IAAI,EAAE,gFAAgF;SACvF;KACF;IACD,OAAO,EAAE;QACP;YACE,IAAI,EAAE,2EAA2E;YACjF,MAAM,EAAE,CAAC,EAAE,SAAS,EAAE,gBAAgB,EAAE,CAAC;SAC1C;QACD;YACE,IAAI,EAAE,8EAA8E;YACpF,MAAM,EAAE,CAAC,EAAE,SAAS,EAAE,gBAAgB,EAAE,CAAC;SAC1C;QACD;YACE,IAAI,EAAE,mEAAmE;YACzE,MAAM,EAAE,CAAC,EAAE,SAAS,EAAE,gBAAgB,EAAE,CAAC;SAC1C;KACF;CACF,CAAC,CAAC","sourcesContent":["import { RuleTester } from '@typescript-eslint/rule-tester';\nimport { afterAll, describe, it } from 'vitest';\n\nimport rule from '../rules/aws-client-shared-config';\n\nRuleTester.afterAll = afterAll;\nRuleTester.describe = describe;\nRuleTester.it = it;\n\nconst ruleTester = new RuleTester();\n\nruleTester.run('aws-client-shared-config', rule, {\n valid: [\n {\n code: \"import { S3 } from '@aws-sdk/client-s3'; new S3(makeS3ClientConfig());\",\n },\n {\n code: \"import { S3Client } from '@aws-sdk/client-s3'; new S3Client(makeS3ClientConfig());\",\n },\n {\n code: \"import { EC2 } from '@aws-sdk/client-ec2'; new EC2(makeAwsClientConfig());\",\n },\n {\n code: \"import { EC2Client } from '@aws-sdk/client-ec2'; new EC2Client(makeAwsClientConfig());\",\n },\n {\n code: \"import { EC2 } from '@aws-sdk/client-ec2'; new EC2(aws.makeAwsClientConfig());\",\n },\n ],\n invalid: [\n {\n code: \"import { S3 } from '@aws-sdk/client-s3'; new S3({ region: 'us-east-2' });\",\n errors: [{ messageId: 'improperConfig' }],\n },\n {\n code: \"import { EC2 } from '@aws-sdk/client-ec2'; new EC2({ region: 'us-east-2' });\",\n errors: [{ messageId: 'improperConfig' }],\n },\n {\n code: \"import { S3 } from '@aws-sdk/client-s3'; new S3(wrongFunction());\",\n errors: [{ messageId: 'improperConfig' }],\n },\n ],\n});\n"]}
|
|
@@ -1,8 +1,11 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
const rule_tester_1 = require("@typescript-eslint/rule-tester");
|
|
4
|
+
const vitest_1 = require("vitest");
|
|
4
5
|
const jsx_no_dollar_interpolation_1 = require("../rules/jsx-no-dollar-interpolation");
|
|
5
|
-
rule_tester_1.RuleTester.afterAll =
|
|
6
|
+
rule_tester_1.RuleTester.afterAll = vitest_1.afterAll;
|
|
7
|
+
rule_tester_1.RuleTester.describe = vitest_1.describe;
|
|
8
|
+
rule_tester_1.RuleTester.it = vitest_1.it;
|
|
6
9
|
const ruleTester = new rule_tester_1.RuleTester({
|
|
7
10
|
languageOptions: {
|
|
8
11
|
parserOptions: {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"jsx-no-dollar-interpolation.test.js","sourceRoot":"","sources":["../../src/tests/jsx-no-dollar-interpolation.test.ts"],"names":[],"mappings":";;AAAA,gEAA4D;
|
|
1
|
+
{"version":3,"file":"jsx-no-dollar-interpolation.test.js","sourceRoot":"","sources":["../../src/tests/jsx-no-dollar-interpolation.test.ts"],"names":[],"mappings":";;AAAA,gEAA4D;AAC5D,mCAAgD;AAEhD,sFAAwD;AAExD,wBAAU,CAAC,QAAQ,GAAG,iBAAQ,CAAC;AAC/B,wBAAU,CAAC,QAAQ,GAAG,iBAAQ,CAAC;AAC/B,wBAAU,CAAC,EAAE,GAAG,WAAE,CAAC;AAEnB,MAAM,UAAU,GAAG,IAAI,wBAAU,CAAC;IAChC,eAAe,EAAE;QACf,aAAa,EAAE;YACb,YAAY,EAAE;gBACZ,GAAG,EAAE,IAAI;aACV;SACF;KACF;CACF,CAAC,CAAC;AAEH,UAAU,CAAC,GAAG,CAAC,6BAA6B,EAAE,qCAAI,EAAE;IAClD,KAAK,EAAE;QACL;YACE,IAAI,EAAE,kBAAkB;SACzB;QACD;YACE,IAAI,EAAE,iBAAiB;SACxB;QACD;YACE,IAAI,EAAE,iBAAiB;SACxB;QACD;YACE,IAAI,EAAE,cAAc;SACrB;KACF;IACD,OAAO,EAAE;QACP;YACE,uDAAuD;YACvD,IAAI,EAAE,uBAAuB;YAC7B,MAAM,EAAE;gBACN;oBACE,SAAS,EAAE,+BAA+B;oBAC1C,IAAI,EAAE,CAAC;oBACP,MAAM,EAAE,CAAC;oBACT,OAAO,EAAE,CAAC;oBACV,SAAS,EAAE,EAAE;iBACd;aACF;SACF;QACD;YACE,IAAI,EAAE,wBAAwB;YAC9B,MAAM,EAAE;gBACN;oBACE,SAAS,EAAE,+BAA+B;oBAC1C,IAAI,EAAE,CAAC;oBACP,MAAM,EAAE,CAAC;oBACT,OAAO,EAAE,CAAC;oBACV,SAAS,EAAE,EAAE;iBACd;aACF;SACF;KACF;CACF,CAAC,CAAC","sourcesContent":["import { RuleTester } from '@typescript-eslint/rule-tester';\nimport { afterAll, describe, it } from 'vitest';\n\nimport rule from '../rules/jsx-no-dollar-interpolation';\n\nRuleTester.afterAll = afterAll;\nRuleTester.describe = describe;\nRuleTester.it = it;\n\nconst ruleTester = new RuleTester({\n languageOptions: {\n parserOptions: {\n ecmaFeatures: {\n jsx: true,\n },\n },\n },\n});\n\nruleTester.run('jsx-no-dollar-interpolation', rule, {\n valid: [\n {\n code: '<div>hello</div>',\n },\n {\n code: '<div>100$</div>',\n },\n {\n code: '<div>$100</div>',\n },\n {\n code: '<div>$</div>',\n },\n ],\n invalid: [\n {\n // eslint-disable-next-line no-template-curly-in-string\n code: '<div>${message}</div>',\n errors: [\n {\n messageId: 'dollarInterpolationNotAllowed',\n line: 1,\n column: 6,\n endLine: 1,\n endColumn: 16,\n },\n ],\n },\n {\n code: '<div>$ {message}</div>',\n errors: [\n {\n messageId: 'dollarInterpolationNotAllowed',\n line: 1,\n column: 6,\n endLine: 1,\n endColumn: 17,\n },\n ],\n },\n ],\n});\n"]}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@prairielearn/eslint-plugin",
|
|
3
|
-
"version": "2.1.
|
|
3
|
+
"version": "2.1.5",
|
|
4
4
|
"repository": {
|
|
5
5
|
"type": "git",
|
|
6
6
|
"url": "https://github.com/PrairieLearn/PrairieLearn.git",
|
|
@@ -10,32 +10,18 @@
|
|
|
10
10
|
"scripts": {
|
|
11
11
|
"build": "tsc",
|
|
12
12
|
"dev": "tsc --watch --preserveWatchOutput",
|
|
13
|
-
"test": "
|
|
13
|
+
"test": "vitest run --coverage"
|
|
14
14
|
},
|
|
15
15
|
"dependencies": {
|
|
16
|
-
"@typescript-eslint/utils": "^8.
|
|
16
|
+
"@typescript-eslint/utils": "^8.33.0"
|
|
17
17
|
},
|
|
18
18
|
"devDependencies": {
|
|
19
19
|
"@prairielearn/tsconfig": "^0.0.0",
|
|
20
|
-
"@types/
|
|
21
|
-
"@
|
|
22
|
-
"@
|
|
23
|
-
"
|
|
24
|
-
"
|
|
25
|
-
"
|
|
26
|
-
"mocha": "^11.1.0",
|
|
27
|
-
"tsx": "^4.19.3",
|
|
28
|
-
"typescript": "^5.8.3"
|
|
29
|
-
},
|
|
30
|
-
"c8": {
|
|
31
|
-
"reporter": [
|
|
32
|
-
"html",
|
|
33
|
-
"text-summary",
|
|
34
|
-
"cobertura"
|
|
35
|
-
],
|
|
36
|
-
"all": true,
|
|
37
|
-
"include": [
|
|
38
|
-
"src/**"
|
|
39
|
-
]
|
|
20
|
+
"@types/node": "^20.17.57",
|
|
21
|
+
"@typescript-eslint/rule-tester": "^8.33.0",
|
|
22
|
+
"@vitest/coverage-v8": "^3.1.4",
|
|
23
|
+
"tsx": "^4.19.4",
|
|
24
|
+
"typescript": "^5.8.3",
|
|
25
|
+
"vitest": "^3.1.4"
|
|
40
26
|
}
|
|
41
27
|
}
|
|
@@ -1,8 +1,11 @@
|
|
|
1
1
|
import { RuleTester } from '@typescript-eslint/rule-tester';
|
|
2
|
+
import { afterAll, describe, it } from 'vitest';
|
|
2
3
|
|
|
3
4
|
import rule from '../rules/aws-client-mandatory-config';
|
|
4
5
|
|
|
5
|
-
RuleTester.afterAll =
|
|
6
|
+
RuleTester.afterAll = afterAll;
|
|
7
|
+
RuleTester.describe = describe;
|
|
8
|
+
RuleTester.it = it;
|
|
6
9
|
|
|
7
10
|
const ruleTester = new RuleTester();
|
|
8
11
|
|
|
@@ -1,8 +1,11 @@
|
|
|
1
1
|
import { RuleTester } from '@typescript-eslint/rule-tester';
|
|
2
|
+
import { afterAll, describe, it } from 'vitest';
|
|
2
3
|
|
|
3
4
|
import rule from '../rules/aws-client-shared-config';
|
|
4
5
|
|
|
5
|
-
RuleTester.afterAll =
|
|
6
|
+
RuleTester.afterAll = afterAll;
|
|
7
|
+
RuleTester.describe = describe;
|
|
8
|
+
RuleTester.it = it;
|
|
6
9
|
|
|
7
10
|
const ruleTester = new RuleTester();
|
|
8
11
|
|
|
@@ -1,8 +1,11 @@
|
|
|
1
1
|
import { RuleTester } from '@typescript-eslint/rule-tester';
|
|
2
|
+
import { afterAll, describe, it } from 'vitest';
|
|
2
3
|
|
|
3
4
|
import rule from '../rules/jsx-no-dollar-interpolation';
|
|
4
5
|
|
|
5
|
-
RuleTester.afterAll =
|
|
6
|
+
RuleTester.afterAll = afterAll;
|
|
7
|
+
RuleTester.describe = describe;
|
|
8
|
+
RuleTester.it = it;
|
|
6
9
|
|
|
7
10
|
const ruleTester = new RuleTester({
|
|
8
11
|
languageOptions: {
|
package/tsconfig.json
CHANGED