qa360 2.0.7 → 2.0.8

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.
@@ -51,8 +51,12 @@ export class QA360History {
51
51
  // Display table
52
52
  console.log(chalk.bold('\nšŸ“‹ QA360 Run History\n'));
53
53
  const table = runs.map((run) => {
54
- const duration = run.ended_at ? run.ended_at - run.started_at : null;
55
- const durationStr = duration ? `${Math.round(duration / 1000)}s` : 'running';
54
+ const duration = run.ended_at && run.started_at ? run.ended_at - run.started_at : null;
55
+ let durationStr = 'running';
56
+ if (duration !== null) {
57
+ const durationSec = Math.round(duration / 1000);
58
+ durationStr = durationSec > 0 ? `${durationSec}s` : '< 1s';
59
+ }
56
60
  // Format status without chalk for console.table compatibility
57
61
  const statusIcon = run.status === 'passed' ? 'āœ…' :
58
62
  run.status === 'failed' ? 'āŒ' :
@@ -425,8 +429,8 @@ export class QA360History {
425
429
  }
426
430
  // 1. Find runs to delete (beyond keepLast, not pinned)
427
431
  const allRuns = await vault.listRuns({ limit: 1000 });
428
- const pinnedRuns = allRuns.filter(r => r.pinned);
429
- const unpinnedRuns = allRuns.filter(r => !r.pinned);
432
+ const pinnedRuns = allRuns.filter((r) => r.pinned);
433
+ const unpinnedRuns = allRuns.filter((r) => !r.pinned);
430
434
  console.log(chalk.gray(`šŸ“Š Total runs: ${allRuns.length}`));
431
435
  console.log(chalk.gray(`šŸ“Œ Pinned runs: ${pinnedRuns.length}`));
432
436
  console.log(chalk.gray(`šŸ“¦ Unpinned runs: ${unpinnedRuns.length}`));
package/dist/index.js CHANGED
@@ -22,7 +22,7 @@ import { runCommand } from './commands/run.js';
22
22
  import { reportCommand } from './commands/report.js';
23
23
  import { verifyCommand } from './commands/verify.js';
24
24
  import { explainCommand } from './commands/explain.js';
25
- // import { packValidateCommand, packLintCommand, packMigrateCommand } from './commands/pack.js'; // TODO: fix pack v2 imports
25
+ import { packValidateCommand, packLintCommand, packMigrateCommand } from './commands/pack.js';
26
26
  import { secretsAddCommand, secretsListCommand, secretsRemoveCommand, secretsDoctorCommand, secretsExportCommand } from './commands/secrets.js';
27
27
  import { createHistoryCommands } from './commands/history.js';
28
28
  import { createAICommands } from './commands/ai.js';
@@ -138,36 +138,30 @@ program
138
138
  await explainCommand(input, options);
139
139
  });
140
140
  // Pack commands (Phase 2)
141
- /*
142
- // TODO: Re-enable after fixing pack v2 imports
143
141
  const packCommand = program
144
- .command('pack')
145
- .description('Pack configuration management');
146
-
142
+ .command('pack')
143
+ .description('Pack configuration management');
147
144
  packCommand
148
- .command('validate [pack]')
149
- .description('Validate pack.yml (auto-detects v1 or v2)')
150
- .option('--check-files', 'Verify that referenced test files exist')
151
- .action(async (pack, options) => {
145
+ .command('validate [pack]')
146
+ .description('Validate pack.yml (auto-detects v1 or v2)')
147
+ .option('--check-files', 'Verify that referenced test files exist')
148
+ .action(async (pack, options) => {
152
149
  await packValidateCommand(pack, options);
153
- });
154
-
150
+ });
155
151
  packCommand
156
- .command('lint [pack]')
157
- .description('Auto-fix pack.yml formatting and structure')
158
- .action(async (pack) => {
152
+ .command('lint [pack]')
153
+ .description('Auto-fix pack.yml formatting and structure')
154
+ .action(async (pack) => {
159
155
  await packLintCommand(pack);
160
- });
161
-
156
+ });
162
157
  packCommand
163
- .command('migrate [pack]')
164
- .description('Migrate pack v1 to v2 format')
165
- .option('--output <file>', 'Output file path')
166
- .option('--dry-run', 'Preview changes without writing files')
167
- .action(async (pack, options) => {
158
+ .command('migrate [pack]')
159
+ .description('Migrate pack v1 to v2 format')
160
+ .option('--output <file>', 'Output file path')
161
+ .option('--dry-run', 'Preview changes without writing files')
162
+ .action(async (pack, options) => {
168
163
  await packMigrateCommand(pack, options);
169
- });
170
- */
164
+ });
171
165
  // Secrets commands (Phase 2)
172
166
  const secretsCommand = program
173
167
  .command('secrets')
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "qa360",
3
- "version": "2.0.7",
3
+ "version": "2.0.8",
4
4
  "description": "QA360 Proof CLI - Quality as Cryptographic Proof",
5
5
  "type": "module",
6
6
  "main": "dist/index.js",