@checkdigit/eslint-plugin 7.6.0-PR.75-7ee9 → 7.6.0-PR.97-b19c

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.
Files changed (77) hide show
  1. package/dist-mjs/index.mjs +8 -156
  2. package/dist-mjs/no-status-code-assert.mjs +63 -0
  3. package/dist-mjs/require-resolve-full-response.mjs +5 -5
  4. package/dist-types/no-status-code-assert.d.ts +5 -0
  5. package/package.json +1 -1
  6. package/src/index.ts +4 -152
  7. package/src/no-status-code-assert.ts +85 -0
  8. package/src/require-resolve-full-response.ts +4 -4
  9. package/dist-mjs/agent/add-assert-import.mjs +0 -58
  10. package/dist-mjs/agent/add-base-path-const.mjs +0 -65
  11. package/dist-mjs/agent/add-base-path-import.mjs +0 -60
  12. package/dist-mjs/agent/add-url-domain.mjs +0 -61
  13. package/dist-mjs/agent/agent-test-wiring.mjs +0 -221
  14. package/dist-mjs/agent/fetch-response-body-json.mjs +0 -146
  15. package/dist-mjs/agent/fetch-response-header-getter.mjs +0 -117
  16. package/dist-mjs/agent/fetch-response-status.mjs +0 -76
  17. package/dist-mjs/agent/fetch-then.mjs +0 -273
  18. package/dist-mjs/agent/fetch.mjs +0 -48
  19. package/dist-mjs/agent/file.mjs +0 -43
  20. package/dist-mjs/agent/fix-function-call-arguments.mjs +0 -153
  21. package/dist-mjs/agent/no-fixture.mjs +0 -397
  22. package/dist-mjs/agent/no-mapped-response.mjs +0 -75
  23. package/dist-mjs/agent/no-service-wrapper.mjs +0 -185
  24. package/dist-mjs/agent/no-status-code.mjs +0 -59
  25. package/dist-mjs/agent/no-supertest.mjs +0 -346
  26. package/dist-mjs/agent/no-unused-function-argument.mjs +0 -79
  27. package/dist-mjs/agent/no-unused-imports.mjs +0 -81
  28. package/dist-mjs/agent/no-unused-service-variable.mjs +0 -74
  29. package/dist-mjs/agent/response-reference.mjs +0 -78
  30. package/dist-mjs/agent/supertest-then.mjs +0 -170
  31. package/dist-mjs/agent/url.mjs +0 -32
  32. package/dist-types/agent/add-assert-import.d.ts +0 -4
  33. package/dist-types/agent/add-base-path-const.d.ts +0 -4
  34. package/dist-types/agent/add-base-path-import.d.ts +0 -4
  35. package/dist-types/agent/add-url-domain.d.ts +0 -4
  36. package/dist-types/agent/agent-test-wiring.d.ts +0 -4
  37. package/dist-types/agent/fetch-response-body-json.d.ts +0 -4
  38. package/dist-types/agent/fetch-response-header-getter.d.ts +0 -4
  39. package/dist-types/agent/fetch-response-status.d.ts +0 -4
  40. package/dist-types/agent/fetch-then.d.ts +0 -4
  41. package/dist-types/agent/fetch.d.ts +0 -8
  42. package/dist-types/agent/file.d.ts +0 -7
  43. package/dist-types/agent/fix-function-call-arguments.d.ts +0 -9
  44. package/dist-types/agent/no-fixture.d.ts +0 -4
  45. package/dist-types/agent/no-mapped-response.d.ts +0 -4
  46. package/dist-types/agent/no-service-wrapper.d.ts +0 -4
  47. package/dist-types/agent/no-status-code.d.ts +0 -4
  48. package/dist-types/agent/no-supertest.d.ts +0 -4
  49. package/dist-types/agent/no-unused-function-argument.d.ts +0 -4
  50. package/dist-types/agent/no-unused-imports.d.ts +0 -4
  51. package/dist-types/agent/no-unused-service-variable.d.ts +0 -4
  52. package/dist-types/agent/response-reference.d.ts +0 -17
  53. package/dist-types/agent/supertest-then.d.ts +0 -4
  54. package/dist-types/agent/url.d.ts +0 -4
  55. package/src/agent/add-assert-import.ts +0 -74
  56. package/src/agent/add-base-path-const.ts +0 -81
  57. package/src/agent/add-base-path-import.ts +0 -69
  58. package/src/agent/add-url-domain.ts +0 -76
  59. package/src/agent/agent-test-wiring.ts +0 -273
  60. package/src/agent/fetch-response-body-json.ts +0 -194
  61. package/src/agent/fetch-response-header-getter.ts +0 -148
  62. package/src/agent/fetch-response-status.ts +0 -100
  63. package/src/agent/fetch-then.ts +0 -359
  64. package/src/agent/fetch.ts +0 -69
  65. package/src/agent/file.ts +0 -42
  66. package/src/agent/fix-function-call-arguments.ts +0 -200
  67. package/src/agent/no-fixture.ts +0 -581
  68. package/src/agent/no-mapped-response.ts +0 -84
  69. package/src/agent/no-service-wrapper.ts +0 -241
  70. package/src/agent/no-status-code.ts +0 -69
  71. package/src/agent/no-supertest.ts +0 -517
  72. package/src/agent/no-unused-function-argument.ts +0 -98
  73. package/src/agent/no-unused-imports.ts +0 -103
  74. package/src/agent/no-unused-service-variable.ts +0 -93
  75. package/src/agent/response-reference.ts +0 -153
  76. package/src/agent/supertest-then.ts +0 -230
  77. package/src/agent/url.ts +0 -32
@@ -1,79 +0,0 @@
1
- // src/agent/no-unused-function-argument.ts
2
- import { strict as assert } from "node:assert";
3
- import { ESLintUtils, TSESTree } from "@typescript-eslint/utils";
4
- import getDocumentationUrl from "../get-documentation-url.mjs";
5
- var ruleId = "no-unused-function-argument";
6
- var createRule = ESLintUtils.RuleCreator((name) => getDocumentationUrl(name));
7
- var rule = createRule({
8
- name: ruleId,
9
- meta: {
10
- type: "suggestion",
11
- docs: {
12
- description: "Remove unused function arguments."
13
- },
14
- messages: {
15
- removeUnusedFunctionArguments: "Removing unused function arguments.",
16
- unknownError: 'Unknown error occurred in file "{{fileName}}": {{ error }}.'
17
- },
18
- fixable: "code",
19
- schema: []
20
- },
21
- defaultOptions: [],
22
- create(context) {
23
- const sourceCode = context.sourceCode;
24
- function isParameterUsed(parameter, scope) {
25
- return scope.references.some((ref) => ref.identifier.name === parameter.name) || scope.childScopes.some((childScope) => isParameterUsed(parameter, childScope));
26
- }
27
- return {
28
- FunctionDeclaration(functionDeclaration) {
29
- try {
30
- const parameters = functionDeclaration.params;
31
- if (parameters.length === 0) {
32
- return;
33
- }
34
- const functionScope = sourceCode.getScope(functionDeclaration);
35
- const parametersToKeep = parameters.filter(
36
- (parameter) => parameter.type !== TSESTree.AST_NODE_TYPES.Identifier || isParameterUsed(parameter, functionScope)
37
- );
38
- if (parametersToKeep.length === parameters.length) {
39
- return;
40
- }
41
- const updatedParameters = parametersToKeep.map((parameter) => sourceCode.getText(parameter)).join(", ");
42
- context.report({
43
- node: functionDeclaration,
44
- messageId: "removeUnusedFunctionArguments",
45
- fix(fixer) {
46
- const firstParameter = parameters[0];
47
- const lastParameter = parameters.at(-1);
48
- assert.ok(firstParameter !== void 0 && lastParameter !== void 0);
49
- const tokenAfterParameters = sourceCode.getTokenAfter(lastParameter);
50
- return fixer.replaceTextRange(
51
- [
52
- firstParameter.range[0],
53
- tokenAfterParameters?.value === "," ? tokenAfterParameters.range[1] : lastParameter.range[1]
54
- ],
55
- updatedParameters
56
- );
57
- }
58
- });
59
- } catch (error) {
60
- console.error(`Failed to apply ${ruleId} rule for file "${context.filename}":`, error);
61
- context.report({
62
- node: functionDeclaration,
63
- messageId: "unknownError",
64
- data: {
65
- fileName: context.filename,
66
- error: error instanceof Error ? error.toString() : JSON.stringify(error)
67
- }
68
- });
69
- }
70
- }
71
- };
72
- }
73
- });
74
- var no_unused_function_argument_default = rule;
75
- export {
76
- no_unused_function_argument_default as default,
77
- ruleId
78
- };
79
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL2FnZW50L25vLXVudXNlZC1mdW5jdGlvbi1hcmd1bWVudC50cyJdLAogICJtYXBwaW5ncyI6ICI7QUFRQSxTQUFTLFVBQVUsY0FBYztBQUVqQyxTQUFTLGFBQWEsZ0JBQWdCO0FBR3RDLE9BQU8seUJBQXlCO0FBRXpCLElBQU0sU0FBUztBQUV0QixJQUFNLGFBQWEsWUFBWSxZQUFZLENBQUMsU0FBUyxvQkFBb0IsSUFBSSxDQUFDO0FBRTlFLElBQU0sT0FBaUYsV0FBVztBQUFBLEVBQ2hHLE1BQU07QUFBQSxFQUNOLE1BQU07QUFBQSxJQUNKLE1BQU07QUFBQSxJQUNOLE1BQU07QUFBQSxNQUNKLGFBQWE7QUFBQSxJQUNmO0FBQUEsSUFDQSxVQUFVO0FBQUEsTUFDUiwrQkFBK0I7QUFBQSxNQUMvQixjQUFjO0FBQUEsSUFDaEI7QUFBQSxJQUNBLFNBQVM7QUFBQSxJQUNULFFBQVEsQ0FBQztBQUFBLEVBQ1g7QUFBQSxFQUNBLGdCQUFnQixDQUFDO0FBQUEsRUFDakIsT0FBTyxTQUFTO0FBQ2QsVUFBTSxhQUFhLFFBQVE7QUFFM0IsYUFBUyxnQkFBZ0IsV0FBZ0MsT0FBNkI7QUFDcEYsYUFDRSxNQUFNLFdBQVcsS0FBSyxDQUFDLFFBQVEsSUFBSSxXQUFXLFNBQVMsVUFBVSxJQUFJLEtBQ3JFLE1BQU0sWUFBWSxLQUFLLENBQUMsZUFBZSxnQkFBZ0IsV0FBVyxVQUFVLENBQUM7QUFBQSxJQUVqRjtBQUVBLFdBQU87QUFBQSxNQUNMLG9CQUFvQixxQkFBbUQ7QUFDckUsWUFBSTtBQUNGLGdCQUFNLGFBQWEsb0JBQW9CO0FBQ3ZDLGNBQUksV0FBVyxXQUFXLEdBQUc7QUFDM0I7QUFBQSxVQUNGO0FBRUEsZ0JBQU0sZ0JBQWdCLFdBQVcsU0FBUyxtQkFBbUI7QUFDN0QsZ0JBQU0sbUJBQW1CLFdBQVc7QUFBQSxZQUNsQyxDQUFDLGNBQ0MsVUFBVSxTQUFTLFNBQVMsZUFBZSxjQUFjLGdCQUFnQixXQUFXLGFBQWE7QUFBQSxVQUNyRztBQUNBLGNBQUksaUJBQWlCLFdBQVcsV0FBVyxRQUFRO0FBQ2pEO0FBQUEsVUFDRjtBQUVBLGdCQUFNLG9CQUFvQixpQkFBaUIsSUFBSSxDQUFDLGNBQWMsV0FBVyxRQUFRLFNBQVMsQ0FBQyxFQUFFLEtBQUssSUFBSTtBQUN0RyxrQkFBUSxPQUFPO0FBQUEsWUFDYixNQUFNO0FBQUEsWUFDTixXQUFXO0FBQUEsWUFDWCxJQUFJLE9BQU87QUFDVCxvQkFBTSxpQkFBaUIsV0FBVyxDQUFDO0FBQ25DLG9CQUFNLGdCQUFnQixXQUFXLEdBQUcsRUFBRTtBQUN0QyxxQkFBTyxHQUFHLG1CQUFtQixVQUFhLGtCQUFrQixNQUFTO0FBQ3JFLG9CQUFNLHVCQUF1QixXQUFXLGNBQWMsYUFBYTtBQUVuRSxxQkFBTyxNQUFNO0FBQUEsZ0JBQ1g7QUFBQSxrQkFDRSxlQUFlLE1BQU0sQ0FBQztBQUFBLGtCQUN0QixzQkFBc0IsVUFBVSxNQUFNLHFCQUFxQixNQUFNLENBQUMsSUFBSSxjQUFjLE1BQU0sQ0FBQztBQUFBLGdCQUM3RjtBQUFBLGdCQUNBO0FBQUEsY0FDRjtBQUFBLFlBQ0Y7QUFBQSxVQUNGLENBQUM7QUFBQSxRQUNILFNBQVMsT0FBTztBQUVkLGtCQUFRLE1BQU0sbUJBQW1CLE1BQU0sbUJBQW1CLFFBQVEsUUFBUSxNQUFNLEtBQUs7QUFDckYsa0JBQVEsT0FBTztBQUFBLFlBQ2IsTUFBTTtBQUFBLFlBQ04sV0FBVztBQUFBLFlBQ1gsTUFBTTtBQUFBLGNBQ0osVUFBVSxRQUFRO0FBQUEsY0FDbEIsT0FBTyxpQkFBaUIsUUFBUSxNQUFNLFNBQVMsSUFBSSxLQUFLLFVBQVUsS0FBSztBQUFBLFlBQ3pFO0FBQUEsVUFDRixDQUFDO0FBQUEsUUFDSDtBQUFBLE1BQ0Y7QUFBQSxJQUNGO0FBQUEsRUFDRjtBQUNGLENBQUM7QUFFRCxJQUFPLHNDQUFROyIsCiAgIm5hbWVzIjogW10KfQo=
@@ -1,81 +0,0 @@
1
- // src/agent/no-unused-imports.ts
2
- import { ESLintUtils, TSESTree } from "@typescript-eslint/utils";
3
- import getDocumentationUrl from "../get-documentation-url.mjs";
4
- var ruleId = "no-unused-imports";
5
- var createRule = ESLintUtils.RuleCreator((name) => getDocumentationUrl(name));
6
- var rule = createRule({
7
- name: ruleId,
8
- meta: {
9
- type: "suggestion",
10
- docs: {
11
- description: "Remove unused imports."
12
- },
13
- messages: {
14
- removeUnusedImports: "Removing unused imports.",
15
- unknownError: 'Unknown error occurred in file "{{fileName}}": {{ error }}.'
16
- },
17
- fixable: "code",
18
- schema: []
19
- },
20
- defaultOptions: [],
21
- create(context) {
22
- const sourceCode = context.sourceCode;
23
- function isImportUsed(specifier, scope) {
24
- return specifier.type !== TSESTree.AST_NODE_TYPES.ImportSpecifier || scope.references.some((ref) => ref.identifier.name === specifier.local.name) || scope.childScopes.some((childScope) => isImportUsed(specifier, childScope));
25
- }
26
- return {
27
- ImportDeclaration(importDeclaration) {
28
- try {
29
- const moduleName = importDeclaration.source.value;
30
- if (!importDeclaration.specifiers.every(
31
- (specifier) => specifier.type === TSESTree.AST_NODE_TYPES.ImportSpecifier
32
- ) || // [TODO:] move to meta schema
33
- !["@checkdigit/serve-runtime", "@checkdigit/fixture"].includes(moduleName)) {
34
- return;
35
- }
36
- const originalSpecifiers = importDeclaration.specifiers;
37
- const scope = sourceCode.getScope(importDeclaration);
38
- const usedSpecifiers = originalSpecifiers.filter((specifier) => isImportUsed(specifier, scope));
39
- if (usedSpecifiers.length === originalSpecifiers.length) {
40
- return;
41
- }
42
- if (usedSpecifiers.length === 0) {
43
- context.report({
44
- messageId: "removeUnusedImports",
45
- node: importDeclaration,
46
- *fix(fixer) {
47
- yield fixer.remove(importDeclaration);
48
- }
49
- });
50
- return;
51
- }
52
- const usedSpecifierTexts = usedSpecifiers.map((specifier) => sourceCode.getText(specifier));
53
- const updatedImportDeclaration = `import ${importDeclaration.importKind === "type" ? "type " : ""}{ ${usedSpecifierTexts.join(", ")} } from '${moduleName}';`;
54
- context.report({
55
- messageId: "removeUnusedImports",
56
- node: importDeclaration,
57
- *fix(fixer) {
58
- yield fixer.replaceText(importDeclaration, updatedImportDeclaration);
59
- }
60
- });
61
- } catch (error) {
62
- console.error(`Failed to apply ${ruleId} rule for file "${context.filename}":`, error);
63
- context.report({
64
- node: importDeclaration,
65
- messageId: "unknownError",
66
- data: {
67
- fileName: context.filename,
68
- error: error instanceof Error ? error.toString() : JSON.stringify(error)
69
- }
70
- });
71
- }
72
- }
73
- };
74
- }
75
- });
76
- var no_unused_imports_default = rule;
77
- export {
78
- no_unused_imports_default as default,
79
- ruleId
80
- };
81
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL2FnZW50L25vLXVudXNlZC1pbXBvcnRzLnRzIl0sCiAgIm1hcHBpbmdzIjogIjtBQVFBLFNBQVMsYUFBYSxnQkFBZ0I7QUFHdEMsT0FBTyx5QkFBeUI7QUFFekIsSUFBTSxTQUFTO0FBRXRCLElBQU0sYUFBYSxZQUFZLFlBQVksQ0FBQyxTQUFTLG9CQUFvQixJQUFJLENBQUM7QUFFOUUsSUFBTSxPQUF1RSxXQUFXO0FBQUEsRUFDdEYsTUFBTTtBQUFBLEVBQ04sTUFBTTtBQUFBLElBQ0osTUFBTTtBQUFBLElBQ04sTUFBTTtBQUFBLE1BQ0osYUFBYTtBQUFBLElBQ2Y7QUFBQSxJQUNBLFVBQVU7QUFBQSxNQUNSLHFCQUFxQjtBQUFBLE1BQ3JCLGNBQWM7QUFBQSxJQUNoQjtBQUFBLElBQ0EsU0FBUztBQUFBLElBQ1QsUUFBUSxDQUFDO0FBQUEsRUFDWDtBQUFBLEVBQ0EsZ0JBQWdCLENBQUM7QUFBQSxFQUNqQixPQUFPLFNBQVM7QUFDZCxVQUFNLGFBQWEsUUFBUTtBQUUzQixhQUFTLGFBQWEsV0FBa0MsT0FBNkI7QUFDbkYsYUFDRSxVQUFVLFNBQVMsU0FBUyxlQUFlLG1CQUMzQyxNQUFNLFdBQVcsS0FBSyxDQUFDLFFBQVEsSUFBSSxXQUFXLFNBQVMsVUFBVSxNQUFNLElBQUksS0FDM0UsTUFBTSxZQUFZLEtBQUssQ0FBQyxlQUFlLGFBQWEsV0FBVyxVQUFVLENBQUM7QUFBQSxJQUU5RTtBQUVBLFdBQU87QUFBQSxNQUNMLGtCQUFrQixtQkFBbUI7QUFDbkMsWUFBSTtBQUNGLGdCQUFNLGFBQWEsa0JBQWtCLE9BQU87QUFDNUMsY0FDRSxDQUFDLGtCQUFrQixXQUFXO0FBQUEsWUFDNUIsQ0FBQyxjQUFjLFVBQVUsU0FBUyxTQUFTLGVBQWU7QUFBQSxVQUM1RDtBQUFBLFVBRUEsQ0FBQyxDQUFDLDZCQUE2QixxQkFBcUIsRUFBRSxTQUFTLFVBQVUsR0FDekU7QUFDQTtBQUFBLFVBQ0Y7QUFFQSxnQkFBTSxxQkFBcUIsa0JBQWtCO0FBQzdDLGdCQUFNLFFBQVEsV0FBVyxTQUFTLGlCQUFpQjtBQUNuRCxnQkFBTSxpQkFBaUIsbUJBQW1CLE9BQU8sQ0FBQyxjQUFjLGFBQWEsV0FBVyxLQUFLLENBQUM7QUFDOUYsY0FBSSxlQUFlLFdBQVcsbUJBQW1CLFFBQVE7QUFDdkQ7QUFBQSxVQUNGO0FBRUEsY0FBSSxlQUFlLFdBQVcsR0FBRztBQUMvQixvQkFBUSxPQUFPO0FBQUEsY0FDYixXQUFXO0FBQUEsY0FDWCxNQUFNO0FBQUEsY0FDTixDQUFDLElBQUksT0FBTztBQUNWLHNCQUFNLE1BQU0sT0FBTyxpQkFBaUI7QUFBQSxjQUN0QztBQUFBLFlBQ0YsQ0FBQztBQUNEO0FBQUEsVUFDRjtBQUVBLGdCQUFNLHFCQUFxQixlQUFlLElBQUksQ0FBQyxjQUFjLFdBQVcsUUFBUSxTQUFTLENBQUM7QUFDMUYsZ0JBQU0sMkJBQTJCLFVBQVUsa0JBQWtCLGVBQWUsU0FBUyxVQUFVLEVBQUUsS0FBSyxtQkFBbUIsS0FBSyxJQUFJLENBQUMsWUFBWSxVQUFVO0FBRXpKLGtCQUFRLE9BQU87QUFBQSxZQUNiLFdBQVc7QUFBQSxZQUNYLE1BQU07QUFBQSxZQUNOLENBQUMsSUFBSSxPQUFPO0FBQ1Ysb0JBQU0sTUFBTSxZQUFZLG1CQUFtQix3QkFBd0I7QUFBQSxZQUNyRTtBQUFBLFVBQ0YsQ0FBQztBQUFBLFFBQ0gsU0FBUyxPQUFPO0FBRWQsa0JBQVEsTUFBTSxtQkFBbUIsTUFBTSxtQkFBbUIsUUFBUSxRQUFRLE1BQU0sS0FBSztBQUNyRixrQkFBUSxPQUFPO0FBQUEsWUFDYixNQUFNO0FBQUEsWUFDTixXQUFXO0FBQUEsWUFDWCxNQUFNO0FBQUEsY0FDSixVQUFVLFFBQVE7QUFBQSxjQUNsQixPQUFPLGlCQUFpQixRQUFRLE1BQU0sU0FBUyxJQUFJLEtBQUssVUFBVSxLQUFLO0FBQUEsWUFDekU7QUFBQSxVQUNGLENBQUM7QUFBQSxRQUNIO0FBQUEsTUFDRjtBQUFBLElBQ0Y7QUFBQSxFQUNGO0FBQ0YsQ0FBQztBQUVELElBQU8sNEJBQVE7IiwKICAibmFtZXMiOiBbXQp9Cg==
@@ -1,74 +0,0 @@
1
- // src/agent/no-unused-service-variable.ts
2
- import { strict as assert } from "node:assert";
3
- import { ESLintUtils, TSESTree } from "@typescript-eslint/utils";
4
- import getDocumentationUrl from "../get-documentation-url.mjs";
5
- import { getEnclosingScopeNode } from "../library/ts-tree.mjs";
6
- var ruleId = "no-unused-service-variable";
7
- var createRule = ESLintUtils.RuleCreator((name) => getDocumentationUrl(name));
8
- var rule = createRule({
9
- name: ruleId,
10
- meta: {
11
- type: "suggestion",
12
- docs: {
13
- description: "Remove unused service variables."
14
- },
15
- messages: {
16
- removeUnusedServiceVariables: "Removing unused service variables.",
17
- unknownError: 'Unknown error occurred in file "{{fileName}}": {{ error }}.'
18
- },
19
- fixable: "code",
20
- schema: []
21
- },
22
- defaultOptions: [],
23
- create(context) {
24
- const sourceCode = context.sourceCode;
25
- const scopeManager = sourceCode.scopeManager;
26
- function isVariableUsed(variableIdentifier, scope) {
27
- const variable = scope.variables.find((variableToCheck) => variableToCheck.name === variableIdentifier.name);
28
- return variable !== void 0 && variable.references.length > 1;
29
- }
30
- return {
31
- VariableDeclaration(variableDeclaration) {
32
- try {
33
- if (variableDeclaration.declarations.length !== 1 || !sourceCode.getText(variableDeclaration).includes(".service.")) {
34
- return;
35
- }
36
- const enclosingScopeNode = getEnclosingScopeNode(variableDeclaration);
37
- assert.ok(enclosingScopeNode, "enclosingScopeNode is undefined");
38
- const declarator = variableDeclaration.declarations[0];
39
- if (declarator.id.type !== TSESTree.AST_NODE_TYPES.Identifier) {
40
- return;
41
- }
42
- const scope = scopeManager?.acquire(enclosingScopeNode);
43
- assert.ok(scope, "variable declaration is undefined");
44
- if (isVariableUsed(declarator.id, scope)) {
45
- return;
46
- }
47
- context.report({
48
- node: variableDeclaration,
49
- messageId: "removeUnusedServiceVariables",
50
- fix(fixer) {
51
- return fixer.remove(variableDeclaration);
52
- }
53
- });
54
- } catch (error) {
55
- console.error(`Failed to apply ${ruleId} rule for file "${context.filename}":`, error);
56
- context.report({
57
- node: variableDeclaration,
58
- messageId: "unknownError",
59
- data: {
60
- fileName: context.filename,
61
- error: error instanceof Error ? error.toString() : JSON.stringify(error)
62
- }
63
- });
64
- }
65
- }
66
- };
67
- }
68
- });
69
- var no_unused_service_variable_default = rule;
70
- export {
71
- no_unused_service_variable_default as default,
72
- ruleId
73
- };
74
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL2FnZW50L25vLXVudXNlZC1zZXJ2aWNlLXZhcmlhYmxlLnRzIl0sCiAgIm1hcHBpbmdzIjogIjtBQVFBLFNBQVMsVUFBVSxjQUFjO0FBRWpDLFNBQVMsYUFBYSxnQkFBZ0I7QUFHdEMsT0FBTyx5QkFBeUI7QUFDaEMsU0FBUyw2QkFBNkI7QUFFL0IsSUFBTSxTQUFTO0FBRXRCLElBQU0sYUFBYSxZQUFZLFlBQVksQ0FBQyxTQUFTLG9CQUFvQixJQUFJLENBQUM7QUFFOUUsSUFBTSxPQUFnRixXQUFXO0FBQUEsRUFDL0YsTUFBTTtBQUFBLEVBQ04sTUFBTTtBQUFBLElBQ0osTUFBTTtBQUFBLElBQ04sTUFBTTtBQUFBLE1BQ0osYUFBYTtBQUFBLElBQ2Y7QUFBQSxJQUNBLFVBQVU7QUFBQSxNQUNSLDhCQUE4QjtBQUFBLE1BQzlCLGNBQWM7QUFBQSxJQUNoQjtBQUFBLElBQ0EsU0FBUztBQUFBLElBQ1QsUUFBUSxDQUFDO0FBQUEsRUFDWDtBQUFBLEVBQ0EsZ0JBQWdCLENBQUM7QUFBQSxFQUNqQixPQUFPLFNBQVM7QUFDZCxVQUFNLGFBQWEsUUFBUTtBQUMzQixVQUFNLGVBQWUsV0FBVztBQUVoQyxhQUFTLGVBQWUsb0JBQXlDLE9BQTZCO0FBQzVGLFlBQU0sV0FBVyxNQUFNLFVBQVUsS0FBSyxDQUFDLG9CQUFvQixnQkFBZ0IsU0FBUyxtQkFBbUIsSUFBSTtBQUMzRyxhQUFPLGFBQWEsVUFBYSxTQUFTLFdBQVcsU0FBUztBQUFBLElBQ2hFO0FBRUEsV0FBTztBQUFBLE1BQ0wsb0JBQW9CLHFCQUFtRDtBQUNyRSxZQUFJO0FBQ0YsY0FDRSxvQkFBb0IsYUFBYSxXQUFXLEtBQzVDLENBQUMsV0FBVyxRQUFRLG1CQUFtQixFQUFFLFNBQVMsV0FBVyxHQUM3RDtBQUNBO0FBQUEsVUFDRjtBQUVBLGdCQUFNLHFCQUFxQixzQkFBc0IsbUJBQW1CO0FBQ3BFLGlCQUFPLEdBQUcsb0JBQW9CLGlDQUFpQztBQUUvRCxnQkFBTSxhQUFhLG9CQUFvQixhQUFhLENBQUM7QUFDckQsY0FBSSxXQUFXLEdBQUcsU0FBUyxTQUFTLGVBQWUsWUFBWTtBQUM3RDtBQUFBLFVBQ0Y7QUFFQSxnQkFBTSxRQUFRLGNBQWMsUUFBUSxrQkFBa0I7QUFDdEQsaUJBQU8sR0FBRyxPQUFPLG1DQUFtQztBQUNwRCxjQUFJLGVBQWUsV0FBVyxJQUFJLEtBQUssR0FBRztBQUN4QztBQUFBLFVBQ0Y7QUFFQSxrQkFBUSxPQUFPO0FBQUEsWUFDYixNQUFNO0FBQUEsWUFDTixXQUFXO0FBQUEsWUFDWCxJQUFJLE9BQU87QUFDVCxxQkFBTyxNQUFNLE9BQU8sbUJBQW1CO0FBQUEsWUFDekM7QUFBQSxVQUNGLENBQUM7QUFBQSxRQUNILFNBQVMsT0FBTztBQUVkLGtCQUFRLE1BQU0sbUJBQW1CLE1BQU0sbUJBQW1CLFFBQVEsUUFBUSxNQUFNLEtBQUs7QUFDckYsa0JBQVEsT0FBTztBQUFBLFlBQ2IsTUFBTTtBQUFBLFlBQ04sV0FBVztBQUFBLFlBQ1gsTUFBTTtBQUFBLGNBQ0osVUFBVSxRQUFRO0FBQUEsY0FDbEIsT0FBTyxpQkFBaUIsUUFBUSxNQUFNLFNBQVMsSUFBSSxLQUFLLFVBQVUsS0FBSztBQUFBLFlBQ3pFO0FBQUEsVUFDRixDQUFDO0FBQUEsUUFDSDtBQUFBLE1BQ0Y7QUFBQSxJQUNGO0FBQUEsRUFDRjtBQUNGLENBQUM7QUFFRCxJQUFPLHFDQUFROyIsCiAgIm5hbWVzIjogW10KfQo=
@@ -1,78 +0,0 @@
1
- // src/agent/response-reference.ts
2
- import { strict as assert } from "node:assert";
3
- import debug from "debug";
4
- import { AST_NODE_TYPES } from "@typescript-eslint/utils";
5
- import { getParent } from "../library/ts-tree.mjs";
6
- var log = debug("eslint-plugin:response-reference");
7
- function analyzeResponseReferences(variableDeclaration, scopeManager) {
8
- const results = {
9
- bodyReferences: [],
10
- headersReferences: [],
11
- statusReferences: []
12
- };
13
- if (!variableDeclaration) {
14
- return results;
15
- }
16
- const responseVariables = scopeManager.getDeclaredVariables(variableDeclaration);
17
- for (const responseVariable of responseVariables) {
18
- const identifier = responseVariable.identifiers[0];
19
- assert.ok(identifier);
20
- const identifierParent = getParent(identifier);
21
- assert.ok(identifierParent);
22
- if (identifierParent.type === AST_NODE_TYPES.VariableDeclarator) {
23
- results.variable = responseVariable;
24
- const responseReferences = responseVariable.references.map(
25
- (responseReference) => getParent(responseReference.identifier)
26
- );
27
- results.bodyReferences = responseReferences.filter(
28
- (node) => node?.type === AST_NODE_TYPES.MemberExpression && node.property.type === AST_NODE_TYPES.Identifier && node.property.name === "body"
29
- );
30
- results.headersReferences = responseReferences.filter(
31
- (node) => node?.type === AST_NODE_TYPES.MemberExpression && node.property.type === AST_NODE_TYPES.Identifier && (node.property.name === "header" || node.property.name === "headers" || node.property.name === "get")
32
- );
33
- results.statusReferences = responseReferences.filter(
34
- (node) => node?.type === AST_NODE_TYPES.MemberExpression && node.property.type === AST_NODE_TYPES.Identifier && (node.property.name === "status" || node.property.name === "statusCode")
35
- );
36
- } else if (
37
- // body reference through destruction/renaming, e.g. "const { body } = ..."
38
- identifierParent.type === AST_NODE_TYPES.Property && identifierParent.key.type === AST_NODE_TYPES.Identifier && identifierParent.key.name === "body"
39
- ) {
40
- results.destructuringBodyVariable = responseVariable;
41
- } else if (
42
- // body reference through destruction/renaming, e.g. "const { body } = ..."
43
- identifierParent.type === AST_NODE_TYPES.Property && identifierParent.key.type === AST_NODE_TYPES.Identifier && (identifierParent.key.name === "status" || identifierParent.key.name === "statusCode")
44
- ) {
45
- results.destructuringStatusVariable = responseVariable;
46
- } else if (
47
- // header reference through destruction/renaming, e.g. "const { headers } = ..."
48
- identifierParent.type === AST_NODE_TYPES.Property && identifierParent.key.type === AST_NODE_TYPES.Identifier && identifierParent.key.name === "headers"
49
- ) {
50
- results.destructuringHeadersVariable = responseVariable;
51
- results.destructuringHeadersReferences = responseVariable.references.map((reference) => reference.identifier).map(getParent).filter(
52
- (parent) => parent?.type === AST_NODE_TYPES.MemberExpression && parent.property.type === AST_NODE_TYPES.Identifier && parent.property.name !== "get" && getParent(parent)?.type !== AST_NODE_TYPES.CallExpression
53
- );
54
- } else if (identifierParent.type === AST_NODE_TYPES.Property) {
55
- const parent = getParent(identifierParent);
56
- if (parent?.type === AST_NODE_TYPES.ObjectPattern) {
57
- const parent2 = getParent(parent);
58
- if (parent2?.type === AST_NODE_TYPES.Property && parent2.key.type === AST_NODE_TYPES.Identifier && parent2.key.name === "body") {
59
- results.destructuringBodyVariable = parent;
60
- }
61
- if (parent2?.type === AST_NODE_TYPES.Property && parent2.key.type === AST_NODE_TYPES.Identifier && (parent2.key.name === "status" || parent2.key.name === "statusCode")) {
62
- results.destructuringStatusVariable = parent;
63
- }
64
- if (parent2?.type === AST_NODE_TYPES.Property && parent2.key.type === AST_NODE_TYPES.Identifier && (parent2.key.name === "header" || parent2.key.name === "headers")) {
65
- results.destructuringHeadersVariable = parent;
66
- }
67
- }
68
- } else {
69
- log("+++++++ can not handle identifierParent", identifierParent);
70
- throw new Error(`Unknown response variable reference: ${responseVariable.name}`);
71
- }
72
- }
73
- return results;
74
- }
75
- export {
76
- analyzeResponseReferences
77
- };
78
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL2FnZW50L3Jlc3BvbnNlLXJlZmVyZW5jZS50cyJdLAogICJtYXBwaW5ncyI6ICI7QUFRQSxTQUFTLFVBQVUsY0FBYztBQUVqQyxPQUFPLFdBQVc7QUFFbEIsU0FBUyxzQkFBZ0M7QUFFekMsU0FBUyxpQkFBaUI7QUFFMUIsSUFBTSxNQUFNLE1BQU0sa0NBQWtDO0FBUTdDLFNBQVMsMEJBQ2QscUJBQ0EsY0FVQTtBQUNBLFFBQU0sVUFTRjtBQUFBLElBQ0YsZ0JBQWdCLENBQUM7QUFBQSxJQUNqQixtQkFBbUIsQ0FBQztBQUFBLElBQ3BCLGtCQUFrQixDQUFDO0FBQUEsRUFDckI7QUFDQSxNQUFJLENBQUMscUJBQXFCO0FBQ3hCLFdBQU87QUFBQSxFQUNUO0FBRUEsUUFBTSxvQkFBb0IsYUFBYSxxQkFBcUIsbUJBQW1CO0FBQy9FLGFBQVcsb0JBQW9CLG1CQUFtQjtBQUNoRCxVQUFNLGFBQWEsaUJBQWlCLFlBQVksQ0FBQztBQUNqRCxXQUFPLEdBQUcsVUFBVTtBQUNwQixVQUFNLG1CQUFtQixVQUFVLFVBQVU7QUFDN0MsV0FBTyxHQUFHLGdCQUFnQjtBQUMxQixRQUFJLGlCQUFpQixTQUFTLGVBQWUsb0JBQW9CO0FBRS9ELGNBQVEsV0FBVztBQUNuQixZQUFNLHFCQUFxQixpQkFBaUIsV0FBVztBQUFBLFFBQUksQ0FBQyxzQkFDMUQsVUFBVSxrQkFBa0IsVUFBVTtBQUFBLE1BQ3hDO0FBRUEsY0FBUSxpQkFBaUIsbUJBQW1CO0FBQUEsUUFDMUMsQ0FBQyxTQUNDLE1BQU0sU0FBUyxlQUFlLG9CQUM5QixLQUFLLFNBQVMsU0FBUyxlQUFlLGNBQ3RDLEtBQUssU0FBUyxTQUFTO0FBQUEsTUFDM0I7QUFFQSxjQUFRLG9CQUFvQixtQkFBbUI7QUFBQSxRQUM3QyxDQUFDLFNBQ0MsTUFBTSxTQUFTLGVBQWUsb0JBQzlCLEtBQUssU0FBUyxTQUFTLGVBQWUsZUFDckMsS0FBSyxTQUFTLFNBQVMsWUFBWSxLQUFLLFNBQVMsU0FBUyxhQUFhLEtBQUssU0FBUyxTQUFTO0FBQUEsTUFDbkc7QUFFQSxjQUFRLG1CQUFtQixtQkFBbUI7QUFBQSxRQUM1QyxDQUFDLFNBQ0MsTUFBTSxTQUFTLGVBQWUsb0JBQzlCLEtBQUssU0FBUyxTQUFTLGVBQWUsZUFDckMsS0FBSyxTQUFTLFNBQVMsWUFBWSxLQUFLLFNBQVMsU0FBUztBQUFBLE1BQy9EO0FBQUEsSUFDRjtBQUFBO0FBQUEsTUFFRSxpQkFBaUIsU0FBUyxlQUFlLFlBQ3pDLGlCQUFpQixJQUFJLFNBQVMsZUFBZSxjQUM3QyxpQkFBaUIsSUFBSSxTQUFTO0FBQUEsTUFDOUI7QUFDQSxjQUFRLDRCQUE0QjtBQUFBLElBQ3RDO0FBQUE7QUFBQSxNQUVFLGlCQUFpQixTQUFTLGVBQWUsWUFDekMsaUJBQWlCLElBQUksU0FBUyxlQUFlLGVBQzVDLGlCQUFpQixJQUFJLFNBQVMsWUFBWSxpQkFBaUIsSUFBSSxTQUFTO0FBQUEsTUFDekU7QUFDQSxjQUFRLDhCQUE4QjtBQUFBLElBQ3hDO0FBQUE7QUFBQSxNQUVFLGlCQUFpQixTQUFTLGVBQWUsWUFDekMsaUJBQWlCLElBQUksU0FBUyxlQUFlLGNBQzdDLGlCQUFpQixJQUFJLFNBQVM7QUFBQSxNQUM5QjtBQUNBLGNBQVEsK0JBQStCO0FBQ3ZDLGNBQVEsaUNBQWlDLGlCQUFpQixXQUN2RCxJQUFJLENBQUMsY0FBYyxVQUFVLFVBQVUsRUFDdkMsSUFBSSxTQUFTLEVBQ2I7QUFBQSxRQUNDLENBQUMsV0FDQyxRQUFRLFNBQVMsZUFBZSxvQkFDaEMsT0FBTyxTQUFTLFNBQVMsZUFBZSxjQUN4QyxPQUFPLFNBQVMsU0FBUyxTQUN6QixVQUFVLE1BQU0sR0FBRyxTQUFTLGVBQWU7QUFBQSxNQUMvQztBQUFBLElBQ0osV0FBVyxpQkFBaUIsU0FBUyxlQUFlLFVBQVU7QUFDNUQsWUFBTSxTQUFTLFVBQVUsZ0JBQWdCO0FBQ3pDLFVBQUksUUFBUSxTQUFTLGVBQWUsZUFBZTtBQUVqRCxjQUFNLFVBQVUsVUFBVSxNQUFNO0FBQ2hDLFlBQ0UsU0FBUyxTQUFTLGVBQWUsWUFDakMsUUFBUSxJQUFJLFNBQVMsZUFBZSxjQUNwQyxRQUFRLElBQUksU0FBUyxRQUNyQjtBQUNBLGtCQUFRLDRCQUE0QjtBQUFBLFFBQ3RDO0FBQ0EsWUFDRSxTQUFTLFNBQVMsZUFBZSxZQUNqQyxRQUFRLElBQUksU0FBUyxlQUFlLGVBQ25DLFFBQVEsSUFBSSxTQUFTLFlBQVksUUFBUSxJQUFJLFNBQVMsZUFDdkQ7QUFDQSxrQkFBUSw4QkFBOEI7QUFBQSxRQUN4QztBQUNBLFlBQ0UsU0FBUyxTQUFTLGVBQWUsWUFDakMsUUFBUSxJQUFJLFNBQVMsZUFBZSxlQUNuQyxRQUFRLElBQUksU0FBUyxZQUFZLFFBQVEsSUFBSSxTQUFTLFlBQ3ZEO0FBQ0Esa0JBQVEsK0JBQStCO0FBQUEsUUFDekM7QUFBQSxNQUNGO0FBQUEsSUFDRixPQUFPO0FBQ0wsVUFBSSwyQ0FBMkMsZ0JBQWdCO0FBQy9ELFlBQU0sSUFBSSxNQUFNLHdDQUF3QyxpQkFBaUIsSUFBSSxFQUFFO0FBQUEsSUFDakY7QUFBQSxFQUNGO0FBQ0EsU0FBTztBQUNUOyIsCiAgIm5hbWVzIjogW10KfQo=
@@ -1,170 +0,0 @@
1
- // src/agent/supertest-then.ts
2
- import { strict as assert } from "node:assert";
3
- import { AST_NODE_TYPES, ESLintUtils } from "@typescript-eslint/utils";
4
- import { getEnclosingFunction, getParent, isUsedInArrayOrAsArgument } from "../library/ts-tree.mjs";
5
- import getDocumentationUrl from "../get-documentation-url.mjs";
6
- import { getIndentation } from "../library/format.mjs";
7
- var ruleId = "supertest-then";
8
- function analyzeFixtureCall(call, results, sourceCode) {
9
- const parent = getParent(call);
10
- if (!parent) {
11
- return;
12
- }
13
- let nextCall;
14
- if (parent.type !== AST_NODE_TYPES.MemberExpression) {
15
- results.fixtureNode = call;
16
- return;
17
- }
18
- if (parent.property.type === AST_NODE_TYPES.Identifier) {
19
- if (parent.property.name === "expect") {
20
- const assertionCall = getParent(parent);
21
- assert.ok(assertionCall && assertionCall.type === AST_NODE_TYPES.CallExpression);
22
- results.assertions = [...results.assertions ?? [], assertionCall.arguments];
23
- nextCall = assertionCall;
24
- }
25
- } else {
26
- throw new Error(`Unexpected TSESTree.Expression in fixture/supertest call ${sourceCode.getText(parent)}.`);
27
- }
28
- if (nextCall) {
29
- analyzeFixtureCall(nextCall, results, sourceCode);
30
- }
31
- }
32
- function createResponseAssertions(fixtureCallInformation, sourceCode, responseVariableName) {
33
- let statusAssertion;
34
- const nonStatusAssertions = [];
35
- for (const expectArguments of fixtureCallInformation.assertions ?? []) {
36
- if (expectArguments.length === 1) {
37
- const [assertionArgument] = expectArguments;
38
- assert.ok(assertionArgument);
39
- if (assertionArgument.type === AST_NODE_TYPES.MemberExpression && assertionArgument.object.type === AST_NODE_TYPES.Identifier && assertionArgument.object.name === "StatusCodes" || assertionArgument.type === AST_NODE_TYPES.Literal || sourceCode.getText(assertionArgument).includes("StatusCodes.")) {
40
- statusAssertion = `assert.equal(${responseVariableName}.status, ${sourceCode.getText(assertionArgument)})`;
41
- } else if (assertionArgument.type === AST_NODE_TYPES.ArrowFunctionExpression) {
42
- let functionBody = sourceCode.getText(assertionArgument.body);
43
- const [originalResponseArgument] = assertionArgument.params;
44
- assert.ok(originalResponseArgument?.type === AST_NODE_TYPES.Identifier);
45
- const originalResponseArgumentName = originalResponseArgument.name;
46
- if (originalResponseArgumentName !== responseVariableName) {
47
- functionBody = functionBody.replace(
48
- new RegExp(`\\b${originalResponseArgumentName}\\b`, "ug"),
49
- responseVariableName
50
- );
51
- }
52
- nonStatusAssertions.push(`assert.doesNotThrow(()=>${functionBody})`);
53
- } else if (assertionArgument.type === AST_NODE_TYPES.Identifier) {
54
- nonStatusAssertions.push(
55
- `assert.doesNotThrow(()=>${sourceCode.getText(assertionArgument)}(${responseVariableName}))`
56
- );
57
- } else if (assertionArgument.type === AST_NODE_TYPES.ObjectExpression || assertionArgument.type === AST_NODE_TYPES.CallExpression) {
58
- nonStatusAssertions.push(
59
- `assert.deepEqual(await ${responseVariableName}.json(), ${sourceCode.getText(assertionArgument)})`
60
- );
61
- } else {
62
- throw new Error(`Unexpected Supertest assertion argument: ".expect(${sourceCode.getText(assertionArgument)})`);
63
- }
64
- } else if (expectArguments.length === 2) {
65
- const [headerName, headerValue] = expectArguments;
66
- assert.ok(headerName && headerValue);
67
- const headersReference = `${responseVariableName}.headers`;
68
- if (headerValue.type === AST_NODE_TYPES.Literal && headerValue.value instanceof RegExp) {
69
- nonStatusAssertions.push(
70
- `assert.ok(${headersReference}.get(${sourceCode.getText(headerName)}).match(${sourceCode.getText(headerValue)}))`
71
- );
72
- } else {
73
- nonStatusAssertions.push(
74
- `assert.equal(${headersReference}.get(${sourceCode.getText(headerName)}), ${sourceCode.getText(headerValue)})`
75
- );
76
- }
77
- }
78
- }
79
- return {
80
- statusAssertion,
81
- nonStatusAssertions
82
- };
83
- }
84
- var createRule = ESLintUtils.RuleCreator((name) => getDocumentationUrl(name));
85
- var rule = createRule({
86
- name: ruleId,
87
- meta: {
88
- type: "suggestion",
89
- docs: {
90
- description: "Prefer native fetch API over customized fixture API.",
91
- url: getDocumentationUrl(ruleId)
92
- },
93
- messages: {
94
- preferNativeFetch: "Prefer native fetch API over customized fixture API.",
95
- // shouldUseHeaderGetter: 'Getter should be used to access response headers.',
96
- unknownError: 'Unknown error occurred in file "{{fileName}}": {{ error }}.'
97
- },
98
- fixable: "code",
99
- schema: []
100
- },
101
- defaultOptions: [],
102
- create(context) {
103
- const sourceCode = context.sourceCode;
104
- const scopeManager = sourceCode.scopeManager;
105
- assert.ok(scopeManager);
106
- return {
107
- 'CallExpression[callee.property.name="expect"]': (supertestCall) => {
108
- try {
109
- assert.ok(supertestCall.callee.type === AST_NODE_TYPES.MemberExpression);
110
- if (supertestCall.callee.object.type !== AST_NODE_TYPES.CallExpression || supertestCall.callee.object.callee.type === AST_NODE_TYPES.MemberExpression && supertestCall.callee.object.callee.property.type === AST_NODE_TYPES.Identifier && supertestCall.callee.object.callee.property.name === "expect") {
111
- return;
112
- }
113
- if (!(isUsedInArrayOrAsArgument(supertestCall) || getEnclosingFunction(supertestCall)?.async === false)) {
114
- return;
115
- }
116
- const fixtureFunction = supertestCall.callee.object;
117
- const indentation = getIndentation(supertestCall, sourceCode);
118
- const [urlArgumentNode] = supertestCall.arguments;
119
- assert.ok(urlArgumentNode !== void 0);
120
- const fixtureCallInformation = {};
121
- analyzeFixtureCall(fixtureFunction, fixtureCallInformation, sourceCode);
122
- const responseVariableNameToUse = "res";
123
- const { statusAssertion, nonStatusAssertions } = createResponseAssertions(
124
- fixtureCallInformation,
125
- sourceCode,
126
- responseVariableNameToUse
127
- );
128
- const disableLintComment = "// eslint-disable-next-line @checkdigit/no-promise-instance-method";
129
- const fetchCallText = sourceCode.getText(fixtureFunction);
130
- const appendingAssignmentAndAssertionText = [
131
- ...statusAssertion !== void 0 ? [statusAssertion] : [],
132
- ...nonStatusAssertions
133
- ].join(`;
134
- ${indentation}`);
135
- const replacementText = fixtureCallInformation.assertions ? [
136
- disableLintComment,
137
- `${fetchCallText}.then((${responseVariableNameToUse}) => {`,
138
- appendingAssignmentAndAssertionText === "" ? "" : ` ${appendingAssignmentAndAssertionText};`,
139
- ` return ${responseVariableNameToUse};`,
140
- `})`
141
- ].join(`
142
- ${indentation}`) : fetchCallText;
143
- context.report({
144
- node: supertestCall,
145
- messageId: "preferNativeFetch",
146
- fix(fixer) {
147
- return fixer.replaceText(fixtureCallInformation.fixtureNode, replacementText);
148
- }
149
- });
150
- } catch (error) {
151
- console.error(`Failed to apply ${ruleId} rule for file "${context.filename}":`, error);
152
- context.report({
153
- node: supertestCall,
154
- messageId: "unknownError",
155
- data: {
156
- fileName: context.filename,
157
- error: error instanceof Error ? error.toString() : JSON.stringify(error)
158
- }
159
- });
160
- }
161
- }
162
- };
163
- }
164
- });
165
- var supertest_then_default = rule;
166
- export {
167
- supertest_then_default as default,
168
- ruleId
169
- };
170
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL2FnZW50L3N1cGVydGVzdC10aGVuLnRzIl0sCiAgIm1hcHBpbmdzIjogIjtBQVFBLFNBQVMsVUFBVSxjQUFjO0FBRWpDLFNBQVMsZ0JBQWdCLG1CQUE2QjtBQUd0RCxTQUFTLHNCQUFzQixXQUFXLGlDQUFpQztBQUMzRSxPQUFPLHlCQUF5QjtBQUNoQyxTQUFTLHNCQUFzQjtBQUV4QixJQUFNLFNBQVM7QUFVdEIsU0FBUyxtQkFBbUIsTUFBK0IsU0FBaUMsWUFBd0I7QUFDbEgsUUFBTSxTQUFTLFVBQVUsSUFBSTtBQUM3QixNQUFJLENBQUMsUUFBUTtBQUNYO0FBQUEsRUFDRjtBQUVBLE1BQUk7QUFDSixNQUFJLE9BQU8sU0FBUyxlQUFlLGtCQUFrQjtBQUNuRCxZQUFRLGNBQWM7QUFDdEI7QUFBQSxFQUNGO0FBRUEsTUFBSSxPQUFPLFNBQVMsU0FBUyxlQUFlLFlBQVk7QUFDdEQsUUFBSSxPQUFPLFNBQVMsU0FBUyxVQUFVO0FBRXJDLFlBQU0sZ0JBQWdCLFVBQVUsTUFBTTtBQUN0QyxhQUFPLEdBQUcsaUJBQWlCLGNBQWMsU0FBUyxlQUFlLGNBQWM7QUFDL0UsY0FBUSxhQUFhLENBQUMsR0FBSSxRQUFRLGNBQWMsQ0FBQyxHQUFJLGNBQWMsU0FBa0M7QUFDckcsaUJBQVc7QUFBQSxJQUNiO0FBQUEsRUFDRixPQUFPO0FBQ0wsVUFBTSxJQUFJLE1BQU0sNERBQTRELFdBQVcsUUFBUSxNQUFNLENBQUMsR0FBRztBQUFBLEVBQzNHO0FBQ0EsTUFBSSxVQUFVO0FBQ1osdUJBQW1CLFVBQVUsU0FBUyxVQUFVO0FBQUEsRUFDbEQ7QUFDRjtBQUdBLFNBQVMseUJBQ1Asd0JBQ0EsWUFDQSxzQkFDQTtBQUNBLE1BQUk7QUFDSixRQUFNLHNCQUFnQyxDQUFDO0FBQ3ZDLGFBQVcsbUJBQW1CLHVCQUF1QixjQUFjLENBQUMsR0FBRztBQUNyRSxRQUFJLGdCQUFnQixXQUFXLEdBQUc7QUFDaEMsWUFBTSxDQUFDLGlCQUFpQixJQUFJO0FB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
@@ -1,32 +0,0 @@
1
- // src/agent/url.ts
2
- var PLAIN_URL_REGEXP = /^[`']\/\w+(?<serviceNamePart>-\w+)*\/v\d+\/(?<any>.|\r|\n)+[`']$/u;
3
- var TOKENIZED_URL_REGEXP = /^`\$\{(?<serviceNamePart>[A-Z]+_)*BASE_PATH\}\/(?<any>.|\r|\n)+`$/u;
4
- function isServiceApiCallUrl(url) {
5
- return PLAIN_URL_REGEXP.test(url) || TOKENIZED_URL_REGEXP.test(url);
6
- }
7
- function replaceEndpointUrlPrefixWithBasePath(url) {
8
- return url.replace(
9
- /^(?<quotStart>[`'])\/(?<servicename>\w+(?<parts>-\w+)*)(?<path>\/v\d+\/)(?<endpoint>(?<any>.|\r|\n)+)(?<quotEnd>[`'])$/u,
10
- // eslint-disable-next-line no-template-curly-in-string
11
- "`${BASE_PATH}/$5`"
12
- );
13
- }
14
- function replaceEndpointUrlPrefixWithDomain(url) {
15
- return url.replace(
16
- /^(?<quotStart>[`'])\/(?<servicename>\w+(?<parts>-\w+)*)(?<path>\/v\d+\/(?<any>.|\r|\n)+(?<quotEnd>[`'])$)/u,
17
- "$1https://$2.checkdigit/$2$4"
18
- );
19
- }
20
- function addBasePathUrlDomain(url) {
21
- return url.replace(
22
- /^(?<quotStart>[`'])\/(?<servicename>\w+(?<parts>-\w+)*)(?<path>\/v\d+(?<quotEnd>[`'])$)/u,
23
- "$1https://$2.checkdigit/$2$4"
24
- );
25
- }
26
- export {
27
- addBasePathUrlDomain,
28
- isServiceApiCallUrl,
29
- replaceEndpointUrlPrefixWithBasePath,
30
- replaceEndpointUrlPrefixWithDomain
31
- };
32
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL2FnZW50L3VybC50cyJdLAogICJtYXBwaW5ncyI6ICI7QUFHQSxJQUFNLG1CQUEyQjtBQUVqQyxJQUFNLHVCQUErQjtBQUU5QixTQUFTLG9CQUFvQixLQUFzQjtBQUN4RCxTQUFPLGlCQUFpQixLQUFLLEdBQUcsS0FBSyxxQkFBcUIsS0FBSyxHQUFHO0FBQ3BFO0FBRU8sU0FBUyxxQ0FBcUMsS0FBcUI7QUFDeEUsU0FBTyxJQUFJO0FBQUEsSUFDVDtBQUFBO0FBQUEsSUFFQTtBQUFBLEVBQ0Y7QUFDRjtBQUVPLFNBQVMsbUNBQW1DLEtBQXFCO0FBQ3RFLFNBQU8sSUFBSTtBQUFBLElBQ1Q7QUFBQSxJQUNBO0FBQUEsRUFDRjtBQUNGO0FBRU8sU0FBUyxxQkFBcUIsS0FBcUI7QUFDeEQsU0FBTyxJQUFJO0FBQUEsSUFDVDtBQUFBLElBQ0E7QUFBQSxFQUNGO0FBQ0Y7IiwKICAibmFtZXMiOiBbXQp9Cg==
@@ -1,4 +0,0 @@
1
- import { ESLintUtils } from '@typescript-eslint/utils';
2
- export declare const ruleId = "add-assert-import";
3
- declare const rule: ESLintUtils.RuleModule<'addAssertImport'>;
4
- export default rule;
@@ -1,4 +0,0 @@
1
- import { ESLintUtils } from '@typescript-eslint/utils';
2
- export declare const ruleId = "add-base-path-const";
3
- declare const rule: ESLintUtils.RuleModule<'addBasePathConst'>;
4
- export default rule;
@@ -1,4 +0,0 @@
1
- import { ESLintUtils } from '@typescript-eslint/utils';
2
- export declare const ruleId = "add-base-path-import";
3
- declare const rule: ESLintUtils.RuleModule<'addBasePathImport'>;
4
- export default rule;
@@ -1,4 +0,0 @@
1
- import { ESLintUtils } from '@typescript-eslint/utils';
2
- export declare const ruleId = "add-url-domain";
3
- declare const rule: ESLintUtils.RuleModule<'addDomain' | 'unknownError'>;
4
- export default rule;
@@ -1,4 +0,0 @@
1
- import { ESLintUtils } from '@typescript-eslint/utils';
2
- export declare const ruleId = "agent-test-wiring";
3
- declare const rule: ESLintUtils.RuleModule<'updateTestWiring' | 'unknownError'>;
4
- export default rule;
@@ -1,4 +0,0 @@
1
- import { ESLintUtils } from '@typescript-eslint/utils';
2
- export declare const ruleId = "fetch-response-body-json";
3
- declare const rule: ESLintUtils.RuleModule<'unknownError' | 'replaceBodyWithJson' | 'refactorNeeded'>;
4
- export default rule;
@@ -1,4 +0,0 @@
1
- import { ESLintUtils } from '@typescript-eslint/utils';
2
- export declare const ruleId = "fetch-response-header-getter-ts";
3
- declare const rule: ESLintUtils.RuleModule<'unknownError' | 'useGetter'>;
4
- export default rule;
@@ -1,4 +0,0 @@
1
- import { ESLintUtils } from '@typescript-eslint/utils';
2
- export declare const ruleId = "fetch-response-status";
3
- declare const rule: ESLintUtils.RuleModule<'unknownError' | 'renameStatusCodeProperty'>;
4
- export default rule;
@@ -1,4 +0,0 @@
1
- import { ESLintUtils } from '@typescript-eslint/utils';
2
- export declare const ruleId = "fetch-then";
3
- declare const rule: ESLintUtils.RuleModule<'unknownError' | 'preferNativeFetch' | 'shouldUseHeaderGetter'>;
4
- export default rule;
@@ -1,8 +0,0 @@
1
- import { TSESTree } from '@typescript-eslint/utils';
2
- import ts from 'typescript';
3
- export declare function getResponseBodyRetrievalText(responseVariableName: string): string;
4
- export declare function getResponseStatusRetrievalText(responseVariableName: string): string;
5
- export declare function getResponseHeadersRetrievalText(responseVariableName: string): string;
6
- export declare function isInvalidResponseHeadersAccess(responseHeadersAccess: TSESTree.Node): boolean;
7
- export declare function hasAssertions(fixtureCall: TSESTree.Node): boolean;
8
- export declare function isFetchResponse(type: ts.Type): boolean;
@@ -1,7 +0,0 @@
1
- export declare function isApiIndexFile(filename: string): boolean;
2
- export declare function getProjectRootFolder(indexFilename: string): string;
3
- export declare function getSwaggerPathByIndexFile(indexFilename: string): string;
4
- export declare function loadSwagger(filename: string): string;
5
- export declare function loadPackageJson(projectRoot: string): string;
6
- export declare function getApiFolder(folder: string): string | undefined;
7
- export declare function getApiIndexPathByFilename(filename: string): string | undefined;
@@ -1,9 +0,0 @@
1
- import { ESLintUtils } from '@typescript-eslint/utils';
2
- export declare const ruleId = "fix-function-call-arguments";
3
- export interface FixFunctionCallArgumentsRuleOptions {
4
- typesToCheck: string[];
5
- }
6
- declare const rule: ESLintUtils.RuleModule<'removeIncompatibleFunctionArguments' | 'unknownError', [
7
- FixFunctionCallArgumentsRuleOptions
8
- ]>;
9
- export default rule;
@@ -1,4 +0,0 @@
1
- import { ESLintUtils } from '@typescript-eslint/utils';
2
- export declare const ruleId = "no-fixture";
3
- declare const rule: ESLintUtils.RuleModule<'unknownError' | 'preferNativeFetch'>;
4
- export default rule;
@@ -1,4 +0,0 @@
1
- import { ESLintUtils } from '@typescript-eslint/utils';
2
- export declare const ruleId = "no-mapped-response";
3
- declare const rule: ESLintUtils.RuleModule<'unknownError' | 'replaceFullResponseWithFetchResponse'>;
4
- export default rule;
@@ -1,4 +0,0 @@
1
- import { ESLintUtils } from '@typescript-eslint/utils';
2
- export declare const ruleId = "no-service-wrapper";
3
- declare const rule: ESLintUtils.RuleModule<'unknownError' | 'preferNativeFetch' | 'invalidOptions'>;
4
- export default rule;