pumuki 6.3.138 → 6.3.139
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 +7 -0
- package/docs/operations/RELEASE_NOTES.md +6 -0
- package/integrations/evidence/writeEvidence.test.ts +1 -0
- package/integrations/evidence/writeEvidence.ts +6 -0
- package/integrations/tdd/contract.ts +1 -0
- package/integrations/tdd/enforcement.ts +40 -0
- package/integrations/tdd/types.ts +6 -0
- package/package.json +1 -1
package/CHANGELOG.md
CHANGED
|
@@ -6,6 +6,13 @@ This project follows [Semantic Versioning](https://semver.org/spec/v2.0.0.html).
|
|
|
6
6
|
|
|
7
7
|
## [Unreleased]
|
|
8
8
|
|
|
9
|
+
## [6.3.139] - 2026-05-05
|
|
10
|
+
|
|
11
|
+
### Fixed
|
|
12
|
+
|
|
13
|
+
- **PUMUKI-INC-060 baseline test gate:** la evidencia TDD/BDD exige ahora un baseline test `passed` por slice antes del evento `red`; si falta o falla, el gate bloquea con `TDD_BASELINE_TEST_REQUIRED` o `TDD_BASELINE_TEST_MUST_PASS`.
|
|
14
|
+
- **Alineación all-severities en evidencia:** los tests de evidencia quedan sincronizados con el contrato publicado de bloqueo por cualquier severidad (`BLOCK` / `BLOCKED`), incluyendo findings `WARN`.
|
|
15
|
+
|
|
9
16
|
## [6.3.138] - 2026-05-05
|
|
10
17
|
|
|
11
18
|
### Fixed
|
|
@@ -4,6 +4,12 @@ This file tracks the active deterministic framework line used in this repository
|
|
|
4
4
|
Canonical release chronology lives in `CHANGELOG.md`.
|
|
5
5
|
This file keeps only the operational highlights and rollout notes that matter while running the framework.
|
|
6
6
|
|
|
7
|
+
### 2026-05-05 (v6.3.139)
|
|
8
|
+
|
|
9
|
+
- **Baseline tests antes de editar:** Pumuki bloquea cambios TDD/BDD in-scope si cada slice no registra un baseline test pasado antes de RED.
|
|
10
|
+
- **RuralGo INC060:** cierra el gap por el que una regresión de test preexistente en un componente relacionado podía pasar desapercibida antes de iterar.
|
|
11
|
+
- **Rollout:** publicar `pumuki@6.3.139`, repinear RuralGo primero y revalidar `PRE_WRITE`, `PRE_COMMIT`, `PRE_PUSH` y `CI`.
|
|
12
|
+
|
|
7
13
|
### 2026-05-05 (v6.3.138)
|
|
8
14
|
|
|
9
15
|
- **Doc-only sin worktree sucio:** cuando el índice solo contiene `*.md` / `*.mdx`, Pumuki restaura `.ai_evidence.json` trackeado a `HEAD` tras refrescar el gate, evitando el fallo del framework `pre-commit` por “files were modified by this hook”.
|
|
@@ -272,6 +272,12 @@ const normalizeTddBddSnapshot = (snapshot: TddBddSnapshot | undefined): TddBddSn
|
|
|
272
272
|
slices_invalid: snapshot.evidence.slices_invalid,
|
|
273
273
|
integrity_ok: snapshot.evidence.integrity_ok,
|
|
274
274
|
errors: [...snapshot.evidence.errors],
|
|
275
|
+
baseline: {
|
|
276
|
+
required: snapshot.evidence.baseline.required,
|
|
277
|
+
passed: snapshot.evidence.baseline.passed,
|
|
278
|
+
missing: snapshot.evidence.baseline.missing,
|
|
279
|
+
failed: snapshot.evidence.baseline.failed,
|
|
280
|
+
},
|
|
275
281
|
},
|
|
276
282
|
waiver: {
|
|
277
283
|
applied: snapshot.waiver.applied,
|
|
@@ -104,6 +104,12 @@ export const enforceTddBddPolicy = (params: {
|
|
|
104
104
|
slices_invalid: 0,
|
|
105
105
|
integrity_ok: true,
|
|
106
106
|
errors: [],
|
|
107
|
+
baseline: {
|
|
108
|
+
required: scope.inScope,
|
|
109
|
+
passed: 0,
|
|
110
|
+
missing: 0,
|
|
111
|
+
failed: 0,
|
|
112
|
+
},
|
|
107
113
|
},
|
|
108
114
|
waiver: {
|
|
109
115
|
applied: false,
|
|
@@ -207,6 +213,9 @@ export const enforceTddBddPolicy = (params: {
|
|
|
207
213
|
const sliceFindings: Finding[] = [];
|
|
208
214
|
const seenSliceIds = new Set<string>();
|
|
209
215
|
let validSlices = 0;
|
|
216
|
+
let baselinePassed = 0;
|
|
217
|
+
let baselineMissing = 0;
|
|
218
|
+
let baselineFailed = 0;
|
|
210
219
|
|
|
211
220
|
if (evidenceRead.evidence.slices.length === 0) {
|
|
212
221
|
sliceFindings.push(
|
|
@@ -257,6 +266,30 @@ export const enforceTddBddPolicy = (params: {
|
|
|
257
266
|
);
|
|
258
267
|
}
|
|
259
268
|
|
|
269
|
+
if (!slice.baseline) {
|
|
270
|
+
baselineMissing += 1;
|
|
271
|
+
sliceFindings.push(
|
|
272
|
+
buildFinding({
|
|
273
|
+
ruleId: 'generic_tdd_baseline_required',
|
|
274
|
+
code: 'TDD_BASELINE_TEST_REQUIRED',
|
|
275
|
+
message: `Slice ${slice.id} must include passing baseline test evidence before RED.`,
|
|
276
|
+
filePath: evidenceRead.path,
|
|
277
|
+
})
|
|
278
|
+
);
|
|
279
|
+
} else if (slice.baseline.status !== 'passed') {
|
|
280
|
+
baselineFailed += 1;
|
|
281
|
+
sliceFindings.push(
|
|
282
|
+
buildFinding({
|
|
283
|
+
ruleId: 'generic_tdd_baseline_required',
|
|
284
|
+
code: 'TDD_BASELINE_TEST_MUST_PASS',
|
|
285
|
+
message: `Slice ${slice.id} baseline test evidence must pass before editing related code.`,
|
|
286
|
+
filePath: evidenceRead.path,
|
|
287
|
+
})
|
|
288
|
+
);
|
|
289
|
+
} else {
|
|
290
|
+
baselinePassed += 1;
|
|
291
|
+
}
|
|
292
|
+
|
|
260
293
|
if (slice.red.status !== 'failed') {
|
|
261
294
|
sliceFindings.push(
|
|
262
295
|
buildFinding({
|
|
@@ -281,6 +314,7 @@ export const enforceTddBddPolicy = (params: {
|
|
|
281
314
|
|
|
282
315
|
if (
|
|
283
316
|
!isTimelineOrdered([
|
|
317
|
+
slice.baseline?.timestamp,
|
|
284
318
|
slice.red.timestamp,
|
|
285
319
|
slice.green.timestamp,
|
|
286
320
|
slice.refactor.timestamp,
|
|
@@ -320,6 +354,12 @@ export const enforceTddBddPolicy = (params: {
|
|
|
320
354
|
slices_invalid: invalidSlices,
|
|
321
355
|
integrity_ok: evidenceRead.integrity.valid,
|
|
322
356
|
errors: sliceFindings.map((finding) => finding.code),
|
|
357
|
+
baseline: {
|
|
358
|
+
required: true,
|
|
359
|
+
passed: baselinePassed,
|
|
360
|
+
missing: baselineMissing,
|
|
361
|
+
failed: baselineFailed,
|
|
362
|
+
},
|
|
323
363
|
},
|
|
324
364
|
waiver: {
|
|
325
365
|
applied: false,
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "pumuki",
|
|
3
|
-
"version": "6.3.
|
|
3
|
+
"version": "6.3.139",
|
|
4
4
|
"description": "Enterprise-grade AST Intelligence System with multi-platform support (iOS, Android, Backend, Frontend) and Feature-First + DDD + Clean Architecture enforcement. Includes dynamic violations API for intelligent querying.",
|
|
5
5
|
"main": "index.js",
|
|
6
6
|
"bin": {
|