pumuki 6.3.31 → 6.3.32

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.
@@ -7,7 +7,7 @@
7
7
  ## Estado actual
8
8
  - Plan activo: `docs/seguimiento-completo-validacion-ruralgo-03-03-2026.md`
9
9
  - Estado del plan: EN CURSO
10
- - Task activa (`🚧`): `P12.F2.T51` (publicar release con el hardening `#551` y cerrar trazabilidad final en canónico + master).
10
+ - Task activa (`🚧`): `P12.F2.T53` (publicar patch release con la ampliación de suite contractual `#557` y dejar disponibilidad inmediata para consumers).
11
11
 
12
12
  ## Historial resumido
13
13
  - No se mantienen MDs históricos de seguimiento en este repositorio.
@@ -1736,11 +1736,32 @@ Criterio de salida F5:
1736
1736
  - `npm run -s validation:contract-suite:enterprise -- --json`
1737
1737
  - `npm run -s validation:package-manifest`
1738
1738
 
1739
- - 🚧 `P12.F2.T51` Publicar release que incluya el hardening `#551` (suite contractual) y dejar trazabilidad final en canónico + master.
1739
+ - `P12.F2.T51` Publicar release que incluya el hardening `#551` (suite contractual) y dejar trazabilidad final en canónico + master.
1740
+ - cierre ejecutado:
1741
+ - rama release creada y mergeada: `release/6.3.31` -> `#555` (`https://github.com/SwiftEnProfundidad/ast-intelligence-hooks/pull/555`).
1742
+ - publicación npm completada: `pumuki@6.3.31`.
1743
+ - issue `#551` cerrada tras merge de `#553` y release publicada.
1744
+ - evidencia:
1745
+ - `npm publish --access public`
1746
+ - `npm view pumuki version` => `6.3.31`
1747
+ - `gh pr view 555 --json state,mergeCommit,url`
1748
+
1749
+ - ✅ `P12.F2.T52` Ejecutar siguiente iteración técnica post-release `6.3.31`: ampliar la suite contractual multi-repo con fixture adicional y cobertura de regresión.
1750
+ - cierre ejecutado:
1751
+ - issue creada y cerrada: `#557`.
1752
+ - rama técnica creada y mergeada: `feature/557-contract-suite-repeat-profile` -> `#558` (`https://github.com/SwiftEnProfundidad/ast-intelligence-hooks/pull/558`).
1753
+ - commit de merge en `develop`: `5f0302c`.
1754
+ - evidencia:
1755
+ - `npx --yes tsx@4.21.0 --test scripts/__tests__/enterprise-contract-suite-contract.test.ts scripts/__tests__/enterprise-contract-suite-args-lib.test.ts scripts/__tests__/enterprise-contract-suite-report-lib.test.ts`
1756
+ - `npm run -s typecheck`
1757
+ - `npm run -s validation:contract-suite:enterprise -- --json`
1758
+ - `npm run -s validation:tracking-single-active`
1759
+
1760
+ - 🚧 `P12.F2.T53` Publicar patch release con la ampliación de suite contractual (`#557`) y dejar disponibilidad inmediata para consumidores.
1740
1761
  - salida esperada:
1741
- - versión npm publicada con el MVP de suite contractual multi-repo.
1742
- - canónico RuralGO y master plan alineados con refs de release.
1743
- - estado operativo preparado para siguiente bloque de mejoras.
1762
+ - versión npm publicada con el perfil adicional `minimal-repeat`.
1763
+ - PR de release mergeada en `develop` con evidencias de validación.
1764
+ - seguimiento maestro apuntando a esta task como única activa.
1744
1765
 
1745
1766
  Criterio de salida F6:
1746
1767
  - veredicto final trazable y cierre administrativo completo.
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "pumuki",
3
- "version": "6.3.31",
3
+ "version": "6.3.32",
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": {
@@ -1,4 +1,4 @@
1
- export type EnterpriseContractProfileId = 'minimal' | 'block';
1
+ export type EnterpriseContractProfileId = 'minimal' | 'block' | 'minimal-repeat';
2
2
 
3
3
  export type EnterpriseContractProfileSpec = {
4
4
  id: EnterpriseContractProfileId;
@@ -29,3 +29,21 @@ export type EnterpriseContractSuiteOptions = {
29
29
  summaryPath: string;
30
30
  printJson: boolean;
31
31
  };
32
+
33
+ export const resolveEnterpriseContractProfiles = (): ReadonlyArray<EnterpriseContractProfileSpec> => [
34
+ {
35
+ id: 'minimal',
36
+ mode: 'minimal',
37
+ expectedExitCode: 1,
38
+ },
39
+ {
40
+ id: 'block',
41
+ mode: 'block',
42
+ expectedExitCode: 0,
43
+ },
44
+ {
45
+ id: 'minimal-repeat',
46
+ mode: 'minimal',
47
+ expectedExitCode: 1,
48
+ },
49
+ ];
@@ -8,27 +8,13 @@ import {
8
8
  renderEnterpriseContractSummary,
9
9
  } from './enterprise-contract-suite-report-lib';
10
10
  import type {
11
- EnterpriseContractProfileResult,
12
11
  EnterpriseContractProfileSpec,
12
+ EnterpriseContractProfileResult,
13
13
  } from './enterprise-contract-suite-contract';
14
+ import { resolveEnterpriseContractProfiles } from './enterprise-contract-suite-contract';
14
15
  import { ensureDirectory } from './package-install-smoke-file-lib';
15
16
  import { runCommand } from './package-install-smoke-command-lib';
16
17
 
17
- const PROFILE_SPECS: ReadonlyArray<EnterpriseContractProfileSpec> = [
18
- {
19
- id: 'minimal',
20
- mode: 'minimal',
21
- // The minimal fixture intentionally omits platform skill contracts to assert strict governance blocking.
22
- expectedExitCode: 1,
23
- },
24
- {
25
- id: 'block',
26
- mode: 'block',
27
- // The block fixture is expected to complete successfully as a deterministic BLOCK smoke scenario.
28
- expectedExitCode: 0,
29
- },
30
- ];
31
-
32
18
  const runProfile = (
33
19
  repoRoot: string,
34
20
  profile: EnterpriseContractProfileSpec
@@ -58,7 +44,9 @@ const writeTextFile = (repoRoot: string, relativePath: string, content: string):
58
44
 
59
45
  const main = (): number => {
60
46
  const options = parseEnterpriseContractSuiteArgs(process.argv.slice(2));
61
- const results = PROFILE_SPECS.map((profile) => runProfile(options.repoRoot, profile));
47
+ const results = resolveEnterpriseContractProfiles().map((profile) =>
48
+ runProfile(options.repoRoot, profile)
49
+ );
62
50
 
63
51
  const report = buildEnterpriseContractReport({
64
52
  repoRoot: options.repoRoot,