qfai 0.3.8 → 0.4.2

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 (158) hide show
  1. package/README.md +12 -0
  2. package/assets/init/.qfai/README.md +5 -0
  3. package/assets/init/.qfai/prompts/README.md +1 -0
  4. package/assets/init/.qfai/prompts/qfai-generate-test-globs.md +29 -0
  5. package/assets/init/.qfai/specs/README.md +1 -1
  6. package/assets/init/root/qfai.config.yaml +8 -0
  7. package/assets/init/root/tests/qfai-traceability.sample.test.ts +2 -0
  8. package/dist/cli/index.cjs +717 -364
  9. package/dist/cli/index.cjs.map +1 -1
  10. package/dist/cli/index.d.ts +0 -2
  11. package/dist/cli/index.mjs +719 -366
  12. package/dist/cli/index.mjs.map +1 -1
  13. package/dist/index.cjs +710 -351
  14. package/dist/index.cjs.map +1 -1
  15. package/dist/index.d.cts +26 -3
  16. package/dist/index.d.ts +156 -2
  17. package/dist/index.mjs +714 -354
  18. package/dist/index.mjs.map +1 -1
  19. package/package.json +2 -1
  20. package/dist/cli/commands/init.d.ts +0 -8
  21. package/dist/cli/commands/init.d.ts.map +0 -1
  22. package/dist/cli/commands/init.js +0 -30
  23. package/dist/cli/commands/init.js.map +0 -1
  24. package/dist/cli/commands/report.d.ts +0 -7
  25. package/dist/cli/commands/report.d.ts.map +0 -1
  26. package/dist/cli/commands/report.js +0 -80
  27. package/dist/cli/commands/report.js.map +0 -1
  28. package/dist/cli/commands/validate.d.ts +0 -9
  29. package/dist/cli/commands/validate.d.ts.map +0 -1
  30. package/dist/cli/commands/validate.js +0 -57
  31. package/dist/cli/commands/validate.js.map +0 -1
  32. package/dist/cli/index.d.ts.map +0 -1
  33. package/dist/cli/index.js +0 -7
  34. package/dist/cli/index.js.map +0 -1
  35. package/dist/cli/lib/args.d.ts +0 -18
  36. package/dist/cli/lib/args.d.ts.map +0 -1
  37. package/dist/cli/lib/args.js +0 -98
  38. package/dist/cli/lib/args.js.map +0 -1
  39. package/dist/cli/lib/assets.d.ts +0 -2
  40. package/dist/cli/lib/assets.d.ts.map +0 -1
  41. package/dist/cli/lib/assets.js +0 -24
  42. package/dist/cli/lib/assets.js.map +0 -1
  43. package/dist/cli/lib/failOn.d.ts +0 -5
  44. package/dist/cli/lib/failOn.d.ts.map +0 -1
  45. package/dist/cli/lib/failOn.js +0 -10
  46. package/dist/cli/lib/failOn.js.map +0 -1
  47. package/dist/cli/lib/fs.d.ts +0 -11
  48. package/dist/cli/lib/fs.d.ts.map +0 -1
  49. package/dist/cli/lib/fs.js +0 -91
  50. package/dist/cli/lib/fs.js.map +0 -1
  51. package/dist/cli/lib/logger.d.ts +0 -4
  52. package/dist/cli/lib/logger.d.ts.map +0 -1
  53. package/dist/cli/lib/logger.js +0 -10
  54. package/dist/cli/lib/logger.js.map +0 -1
  55. package/dist/cli/main.d.ts +0 -2
  56. package/dist/cli/main.d.ts.map +0 -1
  57. package/dist/cli/main.js +0 -66
  58. package/dist/cli/main.js.map +0 -1
  59. package/dist/core/config.d.ts +0 -44
  60. package/dist/core/config.d.ts.map +0 -1
  61. package/dist/core/config.js +0 -218
  62. package/dist/core/config.js.map +0 -1
  63. package/dist/core/contractIndex.d.ts +0 -13
  64. package/dist/core/contractIndex.d.ts.map +0 -1
  65. package/dist/core/contractIndex.js +0 -66
  66. package/dist/core/contractIndex.js.map +0 -1
  67. package/dist/core/contracts.d.ts +0 -5
  68. package/dist/core/contracts.d.ts.map +0 -1
  69. package/dist/core/contracts.js +0 -42
  70. package/dist/core/contracts.js.map +0 -1
  71. package/dist/core/discovery.d.ts +0 -14
  72. package/dist/core/discovery.d.ts.map +0 -1
  73. package/dist/core/discovery.js +0 -55
  74. package/dist/core/discovery.js.map +0 -1
  75. package/dist/core/fs.d.ts +0 -6
  76. package/dist/core/fs.d.ts.map +0 -1
  77. package/dist/core/fs.js +0 -55
  78. package/dist/core/fs.js.map +0 -1
  79. package/dist/core/gherkin/parse.d.ts +0 -7
  80. package/dist/core/gherkin/parse.d.ts.map +0 -1
  81. package/dist/core/gherkin/parse.js +0 -25
  82. package/dist/core/gherkin/parse.js.map +0 -1
  83. package/dist/core/ids.d.ts +0 -6
  84. package/dist/core/ids.d.ts.map +0 -1
  85. package/dist/core/ids.js +0 -52
  86. package/dist/core/ids.js.map +0 -1
  87. package/dist/core/index.d.ts +0 -13
  88. package/dist/core/index.d.ts.map +0 -1
  89. package/dist/core/index.js +0 -13
  90. package/dist/core/index.js.map +0 -1
  91. package/dist/core/parse/adr.d.ts +0 -13
  92. package/dist/core/parse/adr.d.ts.map +0 -1
  93. package/dist/core/parse/adr.js +0 -33
  94. package/dist/core/parse/adr.js.map +0 -1
  95. package/dist/core/parse/gherkin.d.ts +0 -12
  96. package/dist/core/parse/gherkin.d.ts.map +0 -1
  97. package/dist/core/parse/gherkin.js +0 -22
  98. package/dist/core/parse/gherkin.js.map +0 -1
  99. package/dist/core/parse/markdown.d.ts +0 -14
  100. package/dist/core/parse/markdown.d.ts.map +0 -1
  101. package/dist/core/parse/markdown.js +0 -45
  102. package/dist/core/parse/markdown.js.map +0 -1
  103. package/dist/core/parse/spec.d.ts +0 -28
  104. package/dist/core/parse/spec.d.ts.map +0 -1
  105. package/dist/core/parse/spec.js +0 -80
  106. package/dist/core/parse/spec.js.map +0 -1
  107. package/dist/core/report.d.ts +0 -39
  108. package/dist/core/report.d.ts.map +0 -1
  109. package/dist/core/report.js +0 -226
  110. package/dist/core/report.js.map +0 -1
  111. package/dist/core/scenarioModel.d.ts +0 -33
  112. package/dist/core/scenarioModel.d.ts.map +0 -1
  113. package/dist/core/scenarioModel.js +0 -130
  114. package/dist/core/scenarioModel.js.map +0 -1
  115. package/dist/core/specLayout.d.ts +0 -8
  116. package/dist/core/specLayout.d.ts.map +0 -1
  117. package/dist/core/specLayout.js +0 -36
  118. package/dist/core/specLayout.js.map +0 -1
  119. package/dist/core/types.d.ts +0 -25
  120. package/dist/core/types.d.ts.map +0 -1
  121. package/dist/core/types.js +0 -2
  122. package/dist/core/types.js.map +0 -1
  123. package/dist/core/validate.d.ts +0 -4
  124. package/dist/core/validate.d.ts.map +0 -1
  125. package/dist/core/validate.js +0 -34
  126. package/dist/core/validate.js.map +0 -1
  127. package/dist/core/validators/contracts.d.ts +0 -5
  128. package/dist/core/validators/contracts.d.ts.map +0 -1
  129. package/dist/core/validators/contracts.js +0 -162
  130. package/dist/core/validators/contracts.js.map +0 -1
  131. package/dist/core/validators/delta.d.ts +0 -4
  132. package/dist/core/validators/delta.d.ts.map +0 -1
  133. package/dist/core/validators/delta.js +0 -68
  134. package/dist/core/validators/delta.js.map +0 -1
  135. package/dist/core/validators/ids.d.ts +0 -4
  136. package/dist/core/validators/ids.d.ts.map +0 -1
  137. package/dist/core/validators/ids.js +0 -88
  138. package/dist/core/validators/ids.js.map +0 -1
  139. package/dist/core/validators/scenario.d.ts +0 -5
  140. package/dist/core/validators/scenario.d.ts.map +0 -1
  141. package/dist/core/validators/scenario.js +0 -140
  142. package/dist/core/validators/scenario.js.map +0 -1
  143. package/dist/core/validators/spec.d.ts +0 -5
  144. package/dist/core/validators/spec.d.ts.map +0 -1
  145. package/dist/core/validators/spec.js +0 -94
  146. package/dist/core/validators/spec.js.map +0 -1
  147. package/dist/core/validators/traceability.d.ts +0 -4
  148. package/dist/core/validators/traceability.d.ts.map +0 -1
  149. package/dist/core/validators/traceability.js +0 -180
  150. package/dist/core/validators/traceability.js.map +0 -1
  151. package/dist/core/version.d.ts +0 -2
  152. package/dist/core/version.d.ts.map +0 -1
  153. package/dist/core/version.js +0 -25
  154. package/dist/core/version.js.map +0 -1
  155. package/dist/index.d.ts.map +0 -1
  156. package/dist/index.js +0 -2
  157. package/dist/index.js.map +0 -1
  158. package/dist/tsconfig.tsbuildinfo +0 -1
package/dist/index.d.cts CHANGED
@@ -1,5 +1,17 @@
1
+ type ScCoverage = {
2
+ total: number;
3
+ covered: number;
4
+ missing: number;
5
+ missingIds: string[];
6
+ refs: Record<string, string[]>;
7
+ };
8
+ type TestFileScan = {
9
+ globs: string[];
10
+ excludeGlobs: string[];
11
+ matchedFileCount: number;
12
+ };
13
+
1
14
  type IssueSeverity = "info" | "warning" | "error";
2
- declare const VALIDATION_SCHEMA_VERSION: "0.2";
3
15
  type IssueLocation = {
4
16
  line: number;
5
17
  column?: number;
@@ -18,11 +30,15 @@ type ValidationCounts = {
18
30
  warning: number;
19
31
  error: number;
20
32
  };
33
+ type ValidationTraceability = {
34
+ sc: ScCoverage;
35
+ testFiles: TestFileScan;
36
+ };
21
37
  type ValidationResult = {
22
- schemaVersion: typeof VALIDATION_SCHEMA_VERSION;
23
38
  toolVersion: string;
24
39
  issues: Issue[];
25
40
  counts: ValidationCounts;
41
+ traceability?: ValidationTraceability;
26
42
  };
27
43
 
28
44
  type FailOn = "never" | "warning" | "error";
@@ -45,6 +61,10 @@ type QfaiValidationConfig = {
45
61
  traceability: {
46
62
  brMustHaveSc: boolean;
47
63
  scMustTouchContracts: boolean;
64
+ scMustHaveTest: boolean;
65
+ testFileGlobs: string[];
66
+ testFileExcludeGlobs: string[];
67
+ scNoTestSeverity: TraceabilitySeverity;
48
68
  allowOrphanContracts: boolean;
49
69
  unknownContractIdSeverity: TraceabilitySeverity;
50
70
  };
@@ -95,6 +115,9 @@ type ReportIds = {
95
115
  type ReportTraceability = {
96
116
  upstreamIdsFound: number;
97
117
  referencedInCodeOrTests: boolean;
118
+ sc: ScCoverage;
119
+ scSources: Record<string, string[]>;
120
+ testFiles: TestFileScan;
98
121
  };
99
122
  type ReportData = {
100
123
  tool: "qfai";
@@ -130,4 +153,4 @@ declare function validateSpecContent(text: string, file: string, requiredSection
130
153
 
131
154
  declare function validateTraceability(root: string, config: QfaiConfig): Promise<Issue[]>;
132
155
 
133
- export { type ConfigLoadResult, type ConfigPathKey, type FailOn, type IdFormatPrefix, type IdPrefix, type Issue, type IssueLocation, type IssueSeverity, type OutputFormat, type QfaiConfig, type QfaiOutputConfig, type QfaiPaths, type QfaiValidationConfig, type ReportData, type ReportIds, type ReportSummary, type ReportTraceability, type TraceabilitySeverity, VALIDATION_SCHEMA_VERSION, type ValidationCounts, type ValidationResult, createReportData, defaultConfig, extractAllIds, extractIds, extractInvalidIds, formatReportJson, formatReportMarkdown, getConfigPath, lintSql, loadConfig, resolvePath, resolveToolVersion, validateContracts, validateDefinedIds, validateDeltas, validateProject, validateScenarioContent, validateScenarios, validateSpecContent, validateSpecs, validateTraceability };
156
+ export { type ConfigLoadResult, type ConfigPathKey, type FailOn, type IdFormatPrefix, type IdPrefix, type Issue, type IssueLocation, type IssueSeverity, type OutputFormat, type QfaiConfig, type QfaiOutputConfig, type QfaiPaths, type QfaiValidationConfig, type ReportData, type ReportIds, type ReportSummary, type ReportTraceability, type TraceabilitySeverity, type ValidationCounts, type ValidationResult, type ValidationTraceability, createReportData, defaultConfig, extractAllIds, extractIds, extractInvalidIds, formatReportJson, formatReportMarkdown, getConfigPath, lintSql, loadConfig, resolvePath, resolveToolVersion, validateContracts, validateDefinedIds, validateDeltas, validateProject, validateScenarioContent, validateScenarios, validateSpecContent, validateSpecs, validateTraceability };
package/dist/index.d.ts CHANGED
@@ -1,2 +1,156 @@
1
- export * from "./core/index.js";
2
- //# sourceMappingURL=index.d.ts.map
1
+ type ScCoverage = {
2
+ total: number;
3
+ covered: number;
4
+ missing: number;
5
+ missingIds: string[];
6
+ refs: Record<string, string[]>;
7
+ };
8
+ type TestFileScan = {
9
+ globs: string[];
10
+ excludeGlobs: string[];
11
+ matchedFileCount: number;
12
+ };
13
+
14
+ type IssueSeverity = "info" | "warning" | "error";
15
+ type IssueLocation = {
16
+ line: number;
17
+ column?: number;
18
+ };
19
+ type Issue = {
20
+ code: string;
21
+ severity: IssueSeverity;
22
+ message: string;
23
+ file?: string;
24
+ refs?: string[];
25
+ rule?: string;
26
+ loc?: IssueLocation;
27
+ };
28
+ type ValidationCounts = {
29
+ info: number;
30
+ warning: number;
31
+ error: number;
32
+ };
33
+ type ValidationTraceability = {
34
+ sc: ScCoverage;
35
+ testFiles: TestFileScan;
36
+ };
37
+ type ValidationResult = {
38
+ toolVersion: string;
39
+ issues: Issue[];
40
+ counts: ValidationCounts;
41
+ traceability?: ValidationTraceability;
42
+ };
43
+
44
+ type FailOn = "never" | "warning" | "error";
45
+ type OutputFormat = "text" | "github";
46
+ type TraceabilitySeverity = "warning" | "error";
47
+ type QfaiPaths = {
48
+ contractsDir: string;
49
+ specsDir: string;
50
+ rulesDir: string;
51
+ outDir: string;
52
+ promptsDir: string;
53
+ srcDir: string;
54
+ testsDir: string;
55
+ };
56
+ type QfaiValidationConfig = {
57
+ failOn: FailOn;
58
+ require: {
59
+ specSections: string[];
60
+ };
61
+ traceability: {
62
+ brMustHaveSc: boolean;
63
+ scMustTouchContracts: boolean;
64
+ scMustHaveTest: boolean;
65
+ testFileGlobs: string[];
66
+ testFileExcludeGlobs: string[];
67
+ scNoTestSeverity: TraceabilitySeverity;
68
+ allowOrphanContracts: boolean;
69
+ unknownContractIdSeverity: TraceabilitySeverity;
70
+ };
71
+ };
72
+ type QfaiOutputConfig = {
73
+ validateJsonPath: string;
74
+ };
75
+ type QfaiConfig = {
76
+ paths: QfaiPaths;
77
+ validation: QfaiValidationConfig;
78
+ output: QfaiOutputConfig;
79
+ };
80
+ type ConfigPathKey = keyof QfaiPaths;
81
+ type ConfigLoadResult = {
82
+ config: QfaiConfig;
83
+ issues: Issue[];
84
+ configPath: string;
85
+ };
86
+ declare const defaultConfig: QfaiConfig;
87
+ declare function getConfigPath(root: string): string;
88
+ declare function loadConfig(root: string): Promise<ConfigLoadResult>;
89
+ declare function resolvePath(root: string, config: QfaiConfig, key: ConfigPathKey): string;
90
+
91
+ type IdPrefix = "SPEC" | "BR" | "SC" | "UI" | "API" | "DATA";
92
+ type IdFormatPrefix = IdPrefix | "ADR";
93
+ declare function extractIds(text: string, prefix: IdPrefix): string[];
94
+ declare function extractAllIds(text: string): string[];
95
+ declare function extractInvalidIds(text: string, prefixes: IdFormatPrefix[]): string[];
96
+
97
+ type ReportSummary = {
98
+ specs: number;
99
+ scenarios: number;
100
+ contracts: {
101
+ api: number;
102
+ ui: number;
103
+ db: number;
104
+ };
105
+ counts: ValidationCounts;
106
+ };
107
+ type ReportIds = {
108
+ spec: string[];
109
+ br: string[];
110
+ sc: string[];
111
+ ui: string[];
112
+ api: string[];
113
+ data: string[];
114
+ };
115
+ type ReportTraceability = {
116
+ upstreamIdsFound: number;
117
+ referencedInCodeOrTests: boolean;
118
+ sc: ScCoverage;
119
+ scSources: Record<string, string[]>;
120
+ testFiles: TestFileScan;
121
+ };
122
+ type ReportData = {
123
+ tool: "qfai";
124
+ version: string;
125
+ generatedAt: string;
126
+ root: string;
127
+ configPath: string;
128
+ summary: ReportSummary;
129
+ ids: ReportIds;
130
+ traceability: ReportTraceability;
131
+ issues: Issue[];
132
+ };
133
+ declare function createReportData(root: string, validation?: ValidationResult, configResult?: ConfigLoadResult): Promise<ReportData>;
134
+ declare function formatReportMarkdown(data: ReportData): string;
135
+ declare function formatReportJson(data: ReportData): string;
136
+
137
+ declare function validateProject(root: string, configResult?: ConfigLoadResult): Promise<ValidationResult>;
138
+
139
+ declare function resolveToolVersion(): Promise<string>;
140
+
141
+ declare function validateContracts(root: string, config: QfaiConfig): Promise<Issue[]>;
142
+ declare function lintSql(text: string, file: string): Issue[];
143
+
144
+ declare function validateDeltas(root: string, config: QfaiConfig): Promise<Issue[]>;
145
+
146
+ declare function validateDefinedIds(root: string, config: QfaiConfig): Promise<Issue[]>;
147
+
148
+ declare function validateScenarios(root: string, config: QfaiConfig): Promise<Issue[]>;
149
+ declare function validateScenarioContent(text: string, file: string): Issue[];
150
+
151
+ declare function validateSpecs(root: string, config: QfaiConfig): Promise<Issue[]>;
152
+ declare function validateSpecContent(text: string, file: string, requiredSections: string[]): Issue[];
153
+
154
+ declare function validateTraceability(root: string, config: QfaiConfig): Promise<Issue[]>;
155
+
156
+ export { type ConfigLoadResult, type ConfigPathKey, type FailOn, type IdFormatPrefix, type IdPrefix, type Issue, type IssueLocation, type IssueSeverity, type OutputFormat, type QfaiConfig, type QfaiOutputConfig, type QfaiPaths, type QfaiValidationConfig, type ReportData, type ReportIds, type ReportSummary, type ReportTraceability, type TraceabilitySeverity, type ValidationCounts, type ValidationResult, type ValidationTraceability, createReportData, defaultConfig, extractAllIds, extractIds, extractInvalidIds, formatReportJson, formatReportMarkdown, getConfigPath, lintSql, loadConfig, resolvePath, resolveToolVersion, validateContracts, validateDefinedIds, validateDeltas, validateProject, validateScenarioContent, validateScenarios, validateSpecContent, validateSpecs, validateTraceability };