hzl-cli 1.5.1 → 1.7.0
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/README.md +307 -127
- package/dist/__tests__/integration/cli-integration.test.js +10 -9
- package/dist/__tests__/integration/cli-integration.test.js.map +1 -1
- package/dist/__tests__/integration/config.test.js +1 -1
- package/dist/__tests__/integration/config.test.js.map +1 -1
- package/dist/__tests__/integration/helpers.d.ts +1 -0
- package/dist/__tests__/integration/helpers.d.ts.map +1 -1
- package/dist/__tests__/integration/helpers.js +2 -0
- package/dist/__tests__/integration/helpers.js.map +1 -1
- package/dist/__tests__/integration/project-workflow.test.js +6 -5
- package/dist/__tests__/integration/project-workflow.test.js.map +1 -1
- package/dist/commands/config.test.js +2 -2
- package/dist/commands/config.test.js.map +1 -1
- package/dist/commands/doctor.d.ts +39 -0
- package/dist/commands/doctor.d.ts.map +1 -0
- package/dist/commands/doctor.js +249 -0
- package/dist/commands/doctor.js.map +1 -0
- package/dist/commands/doctor.test.d.ts +2 -0
- package/dist/commands/doctor.test.d.ts.map +1 -0
- package/dist/commands/doctor.test.js +54 -0
- package/dist/commands/doctor.test.js.map +1 -0
- package/dist/commands/export-events.js +3 -3
- package/dist/commands/export-events.js.map +1 -1
- package/dist/commands/export-events.test.js +2 -2
- package/dist/commands/export-events.test.js.map +1 -1
- package/dist/commands/init.d.ts +13 -7
- package/dist/commands/init.d.ts.map +1 -1
- package/dist/commands/init.js +97 -34
- package/dist/commands/init.js.map +1 -1
- package/dist/commands/init.test.js +83 -81
- package/dist/commands/init.test.js.map +1 -1
- package/dist/commands/lock.d.ts +39 -0
- package/dist/commands/lock.d.ts.map +1 -0
- package/dist/commands/lock.js +142 -0
- package/dist/commands/lock.js.map +1 -0
- package/dist/commands/lock.test.d.ts +2 -0
- package/dist/commands/lock.test.d.ts.map +1 -0
- package/dist/commands/lock.test.js +130 -0
- package/dist/commands/lock.test.js.map +1 -0
- package/dist/commands/project/create.js +3 -3
- package/dist/commands/project/create.js.map +1 -1
- package/dist/commands/project/create.test.js +2 -2
- package/dist/commands/project/create.test.js.map +1 -1
- package/dist/commands/project/delete.js +12 -12
- package/dist/commands/project/delete.js.map +1 -1
- package/dist/commands/project/delete.test.js +2 -2
- package/dist/commands/project/delete.test.js.map +1 -1
- package/dist/commands/project/list.js +4 -4
- package/dist/commands/project/list.js.map +1 -1
- package/dist/commands/project/list.test.js +2 -2
- package/dist/commands/project/list.test.js.map +1 -1
- package/dist/commands/project/rename.js +3 -3
- package/dist/commands/project/rename.js.map +1 -1
- package/dist/commands/project/rename.test.js +2 -2
- package/dist/commands/project/rename.test.js.map +1 -1
- package/dist/commands/project/show.js +4 -4
- package/dist/commands/project/show.js.map +1 -1
- package/dist/commands/project/show.test.js +2 -2
- package/dist/commands/project/show.test.js.map +1 -1
- package/dist/commands/sample-project.d.ts +10 -6
- package/dist/commands/sample-project.d.ts.map +1 -1
- package/dist/commands/sample-project.js +23 -13
- package/dist/commands/sample-project.js.map +1 -1
- package/dist/commands/sample-project.test.js +26 -24
- package/dist/commands/sample-project.test.js.map +1 -1
- package/dist/commands/stats.js +12 -12
- package/dist/commands/stats.js.map +1 -1
- package/dist/commands/stats.test.js +2 -2
- package/dist/commands/stats.test.js.map +1 -1
- package/dist/commands/status.d.ts +28 -0
- package/dist/commands/status.d.ts.map +1 -0
- package/dist/commands/status.js +88 -0
- package/dist/commands/status.js.map +1 -0
- package/dist/commands/status.test.d.ts +2 -0
- package/dist/commands/status.test.d.ts.map +1 -0
- package/dist/commands/status.test.js +47 -0
- package/dist/commands/status.test.js.map +1 -0
- package/dist/commands/sync.d.ts +47 -0
- package/dist/commands/sync.d.ts.map +1 -0
- package/dist/commands/sync.js +218 -0
- package/dist/commands/sync.js.map +1 -0
- package/dist/commands/sync.test.d.ts +2 -0
- package/dist/commands/sync.test.d.ts.map +1 -0
- package/dist/commands/sync.test.js +49 -0
- package/dist/commands/sync.test.js.map +1 -0
- package/dist/commands/task/add-dep.js +5 -5
- package/dist/commands/task/add-dep.js.map +1 -1
- package/dist/commands/task/add-dep.test.js +2 -2
- package/dist/commands/task/add-dep.test.js.map +1 -1
- package/dist/commands/task/add.js +3 -3
- package/dist/commands/task/add.js.map +1 -1
- package/dist/commands/task/add.test.js +2 -2
- package/dist/commands/task/add.test.js.map +1 -1
- package/dist/commands/task/archive.js +3 -3
- package/dist/commands/task/archive.js.map +1 -1
- package/dist/commands/task/archive.test.js +2 -2
- package/dist/commands/task/archive.test.js.map +1 -1
- package/dist/commands/task/checkpoint.js +3 -3
- package/dist/commands/task/checkpoint.js.map +1 -1
- package/dist/commands/task/checkpoint.test.js +2 -2
- package/dist/commands/task/checkpoint.test.js.map +1 -1
- package/dist/commands/task/claim.js +3 -3
- package/dist/commands/task/claim.js.map +1 -1
- package/dist/commands/task/claim.test.js +2 -2
- package/dist/commands/task/claim.test.js.map +1 -1
- package/dist/commands/task/comment.js +3 -3
- package/dist/commands/task/comment.js.map +1 -1
- package/dist/commands/task/comment.test.js +2 -2
- package/dist/commands/task/comment.test.js.map +1 -1
- package/dist/commands/task/complete.js +3 -3
- package/dist/commands/task/complete.js.map +1 -1
- package/dist/commands/task/complete.test.js +2 -2
- package/dist/commands/task/complete.test.js.map +1 -1
- package/dist/commands/task/history.js +3 -3
- package/dist/commands/task/history.js.map +1 -1
- package/dist/commands/task/history.test.js +2 -2
- package/dist/commands/task/history.test.js.map +1 -1
- package/dist/commands/task/list.js +4 -4
- package/dist/commands/task/list.js.map +1 -1
- package/dist/commands/task/list.test.js +2 -2
- package/dist/commands/task/list.test.js.map +1 -1
- package/dist/commands/task/move.js +3 -3
- package/dist/commands/task/move.js.map +1 -1
- package/dist/commands/task/move.test.js +2 -2
- package/dist/commands/task/move.test.js.map +1 -1
- package/dist/commands/task/next.js +3 -3
- package/dist/commands/task/next.js.map +1 -1
- package/dist/commands/task/next.test.js +2 -2
- package/dist/commands/task/next.test.js.map +1 -1
- package/dist/commands/task/release.js +3 -3
- package/dist/commands/task/release.js.map +1 -1
- package/dist/commands/task/release.test.js +2 -2
- package/dist/commands/task/release.test.js.map +1 -1
- package/dist/commands/task/remove-dep.js +3 -3
- package/dist/commands/task/remove-dep.js.map +1 -1
- package/dist/commands/task/remove-dep.test.js +2 -2
- package/dist/commands/task/remove-dep.test.js.map +1 -1
- package/dist/commands/task/reopen.js +3 -3
- package/dist/commands/task/reopen.js.map +1 -1
- package/dist/commands/task/reopen.test.js +2 -2
- package/dist/commands/task/reopen.test.js.map +1 -1
- package/dist/commands/task/search.js +4 -4
- package/dist/commands/task/search.js.map +1 -1
- package/dist/commands/task/search.test.js +2 -2
- package/dist/commands/task/search.test.js.map +1 -1
- package/dist/commands/task/set-status.js +3 -3
- package/dist/commands/task/set-status.js.map +1 -1
- package/dist/commands/task/set-status.test.js +2 -2
- package/dist/commands/task/set-status.test.js.map +1 -1
- package/dist/commands/task/show.js +3 -3
- package/dist/commands/task/show.js.map +1 -1
- package/dist/commands/task/show.test.js +2 -2
- package/dist/commands/task/show.test.js.map +1 -1
- package/dist/commands/task/steal.js +3 -3
- package/dist/commands/task/steal.js.map +1 -1
- package/dist/commands/task/steal.test.js +2 -2
- package/dist/commands/task/steal.test.js.map +1 -1
- package/dist/commands/task/stuck.js +4 -4
- package/dist/commands/task/stuck.js.map +1 -1
- package/dist/commands/task/stuck.test.js +2 -2
- package/dist/commands/task/stuck.test.js.map +1 -1
- package/dist/commands/task/update.js +3 -3
- package/dist/commands/task/update.js.map +1 -1
- package/dist/commands/task/update.test.js +2 -2
- package/dist/commands/task/update.test.js.map +1 -1
- package/dist/commands/validate.js +3 -3
- package/dist/commands/validate.js.map +1 -1
- package/dist/commands/validate.test.js +3 -3
- package/dist/commands/validate.test.js.map +1 -1
- package/dist/commands/which-db.d.ts +4 -4
- package/dist/commands/which-db.d.ts.map +1 -1
- package/dist/commands/which-db.js +8 -11
- package/dist/commands/which-db.js.map +1 -1
- package/dist/commands/which-db.test.js +9 -8
- package/dist/commands/which-db.test.js.map +1 -1
- package/dist/config.d.ts +18 -4
- package/dist/config.d.ts.map +1 -1
- package/dist/config.js +120 -13
- package/dist/config.js.map +1 -1
- package/dist/config.test.js +34 -110
- package/dist/config.test.js.map +1 -1
- package/dist/db.d.ts +16 -2
- package/dist/db.d.ts.map +1 -1
- package/dist/db.js +47 -17
- package/dist/db.js.map +1 -1
- package/dist/index.d.ts +2 -2
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +10 -2
- package/dist/index.js.map +1 -1
- package/dist/index.test.js +1 -1
- package/dist/index.test.js.map +1 -1
- package/dist/types.d.ts +22 -0
- package/dist/types.d.ts.map +1 -1
- package/package.json +6 -6
|
@@ -0,0 +1,142 @@
|
|
|
1
|
+
import { Command } from 'commander';
|
|
2
|
+
import { z } from 'zod';
|
|
3
|
+
import { DatabaseLock } from 'hzl-core';
|
|
4
|
+
import { GlobalOptionsSchema } from '../types.js';
|
|
5
|
+
import { resolveDbPaths } from '../config.js';
|
|
6
|
+
export function runLockClear(options) {
|
|
7
|
+
const { eventsDbPath, json, force = false } = options;
|
|
8
|
+
const lockPath = `${eventsDbPath}.lock`;
|
|
9
|
+
const lock = new DatabaseLock(lockPath);
|
|
10
|
+
const metadata = lock.readMetadata();
|
|
11
|
+
if (!metadata) {
|
|
12
|
+
const result = {
|
|
13
|
+
success: true,
|
|
14
|
+
cleared: false,
|
|
15
|
+
message: 'No lock file exists',
|
|
16
|
+
lockPath,
|
|
17
|
+
};
|
|
18
|
+
if (!json) {
|
|
19
|
+
console.log('No lock file exists.');
|
|
20
|
+
}
|
|
21
|
+
return result;
|
|
22
|
+
}
|
|
23
|
+
const isStale = lock.isStale();
|
|
24
|
+
if (!isStale && !force) {
|
|
25
|
+
const result = {
|
|
26
|
+
success: false,
|
|
27
|
+
cleared: false,
|
|
28
|
+
message: `Lock is held by active process PID ${metadata.pid}. Use --force to clear anyway.`,
|
|
29
|
+
lockPath,
|
|
30
|
+
wasStale: false,
|
|
31
|
+
metadata,
|
|
32
|
+
};
|
|
33
|
+
if (!json) {
|
|
34
|
+
console.error(`Lock is held by active process PID ${metadata.pid} (${metadata.command ?? 'unknown'}).`);
|
|
35
|
+
console.error('Use --force to clear anyway (may cause data corruption if process is still running).');
|
|
36
|
+
}
|
|
37
|
+
return result;
|
|
38
|
+
}
|
|
39
|
+
// Clear the lock
|
|
40
|
+
lock.clear();
|
|
41
|
+
const result = {
|
|
42
|
+
success: true,
|
|
43
|
+
cleared: true,
|
|
44
|
+
message: isStale
|
|
45
|
+
? `Cleared stale lock from PID ${metadata.pid}`
|
|
46
|
+
: `Force-cleared lock from PID ${metadata.pid}`,
|
|
47
|
+
lockPath,
|
|
48
|
+
wasStale: isStale,
|
|
49
|
+
metadata,
|
|
50
|
+
};
|
|
51
|
+
if (!json) {
|
|
52
|
+
if (isStale) {
|
|
53
|
+
console.log(`✓ Cleared stale lock from PID ${metadata.pid} (${metadata.command ?? 'unknown'})`);
|
|
54
|
+
}
|
|
55
|
+
else {
|
|
56
|
+
console.log(`✓ Force-cleared lock from PID ${metadata.pid} (${metadata.command ?? 'unknown'})`);
|
|
57
|
+
console.log(' Warning: If this process is still running, database corruption may occur.');
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
return result;
|
|
61
|
+
}
|
|
62
|
+
export function runLockStatus(options) {
|
|
63
|
+
const { eventsDbPath, json } = options;
|
|
64
|
+
const lockPath = `${eventsDbPath}.lock`;
|
|
65
|
+
const lock = new DatabaseLock(lockPath);
|
|
66
|
+
const metadata = lock.readMetadata();
|
|
67
|
+
if (!metadata) {
|
|
68
|
+
const result = {
|
|
69
|
+
success: true,
|
|
70
|
+
locked: false,
|
|
71
|
+
lockPath,
|
|
72
|
+
};
|
|
73
|
+
if (!json) {
|
|
74
|
+
console.log('Database is not locked.');
|
|
75
|
+
}
|
|
76
|
+
return result;
|
|
77
|
+
}
|
|
78
|
+
const isStale = lock.isStale();
|
|
79
|
+
const result = {
|
|
80
|
+
success: true,
|
|
81
|
+
locked: true,
|
|
82
|
+
lockPath,
|
|
83
|
+
isStale,
|
|
84
|
+
metadata,
|
|
85
|
+
};
|
|
86
|
+
if (!json) {
|
|
87
|
+
const startedAt = new Date(metadata.startedAt).toISOString();
|
|
88
|
+
console.log('Database Lock Status');
|
|
89
|
+
console.log('--------------------');
|
|
90
|
+
console.log(`Locked: Yes${isStale ? ' (stale)' : ''}`);
|
|
91
|
+
console.log(`PID: ${metadata.pid}`);
|
|
92
|
+
console.log(`Hostname: ${metadata.hostname}`);
|
|
93
|
+
console.log(`Command: ${metadata.command ?? 'unknown'}`);
|
|
94
|
+
console.log(`Started: ${startedAt}`);
|
|
95
|
+
if (isStale) {
|
|
96
|
+
console.log('');
|
|
97
|
+
console.log('This lock appears stale (process no longer running).');
|
|
98
|
+
console.log('Run: hzl lock clear');
|
|
99
|
+
}
|
|
100
|
+
}
|
|
101
|
+
return result;
|
|
102
|
+
}
|
|
103
|
+
export function createLockCommand() {
|
|
104
|
+
const lockCommand = new Command('lock')
|
|
105
|
+
.description('Manage database lock');
|
|
106
|
+
lockCommand
|
|
107
|
+
.command('status')
|
|
108
|
+
.description('Show current lock status')
|
|
109
|
+
.action(function () {
|
|
110
|
+
const globalOpts = GlobalOptionsSchema.parse(this.optsWithGlobals());
|
|
111
|
+
const { eventsDbPath } = resolveDbPaths(globalOpts.db);
|
|
112
|
+
const result = runLockStatus({
|
|
113
|
+
eventsDbPath,
|
|
114
|
+
json: globalOpts.json,
|
|
115
|
+
});
|
|
116
|
+
if (globalOpts.json) {
|
|
117
|
+
console.log(JSON.stringify(result, null, 2));
|
|
118
|
+
}
|
|
119
|
+
});
|
|
120
|
+
lockCommand
|
|
121
|
+
.command('clear')
|
|
122
|
+
.description('Clear a stale database lock')
|
|
123
|
+
.option('-f, --force', 'Clear lock even if process appears active (dangerous)')
|
|
124
|
+
.action(function () {
|
|
125
|
+
const globalOpts = GlobalOptionsSchema.parse(this.optsWithGlobals());
|
|
126
|
+
const localOpts = z.object({
|
|
127
|
+
force: z.boolean().optional(),
|
|
128
|
+
}).parse(this.opts());
|
|
129
|
+
const { eventsDbPath } = resolveDbPaths(globalOpts.db);
|
|
130
|
+
const result = runLockClear({
|
|
131
|
+
eventsDbPath,
|
|
132
|
+
json: globalOpts.json,
|
|
133
|
+
force: localOpts.force,
|
|
134
|
+
});
|
|
135
|
+
if (globalOpts.json) {
|
|
136
|
+
console.log(JSON.stringify(result, null, 2));
|
|
137
|
+
}
|
|
138
|
+
process.exit(result.success ? 0 : 1);
|
|
139
|
+
});
|
|
140
|
+
return lockCommand;
|
|
141
|
+
}
|
|
142
|
+
//# sourceMappingURL=lock.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"lock.js","sourceRoot":"","sources":["../../src/commands/lock.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"lock.test.d.ts","sourceRoot":"","sources":["../../src/commands/lock.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,130 @@
|
|
|
1
|
+
import { describe, it, expect, beforeEach, afterEach } from 'vitest';
|
|
2
|
+
import { runLockClear, runLockStatus, createLockCommand } from './lock.js';
|
|
3
|
+
import fs from 'fs';
|
|
4
|
+
import path from 'path';
|
|
5
|
+
import os from 'os';
|
|
6
|
+
describe('hzl lock command', () => {
|
|
7
|
+
const testDir = path.join(os.tmpdir(), `lock-test-${Date.now()}`);
|
|
8
|
+
const eventsDb = path.join(testDir, 'events.db');
|
|
9
|
+
const lockPath = `${eventsDb}.lock`;
|
|
10
|
+
beforeEach(() => {
|
|
11
|
+
fs.mkdirSync(testDir, { recursive: true });
|
|
12
|
+
});
|
|
13
|
+
afterEach(() => {
|
|
14
|
+
fs.rmSync(testDir, { recursive: true, force: true });
|
|
15
|
+
});
|
|
16
|
+
describe('runLockStatus', () => {
|
|
17
|
+
it('reports no lock when none exists', () => {
|
|
18
|
+
const result = runLockStatus({
|
|
19
|
+
eventsDbPath: eventsDb,
|
|
20
|
+
json: true,
|
|
21
|
+
});
|
|
22
|
+
expect(result.success).toBe(true);
|
|
23
|
+
expect(result.locked).toBe(false);
|
|
24
|
+
});
|
|
25
|
+
it('reports lock details when lock exists', () => {
|
|
26
|
+
// Create a lock file manually (simulating a stale lock from dead process)
|
|
27
|
+
const metadata = {
|
|
28
|
+
pid: 99999, // Non-existent PID
|
|
29
|
+
hostname: os.hostname(),
|
|
30
|
+
startedAt: Date.now(),
|
|
31
|
+
command: 'test-command',
|
|
32
|
+
};
|
|
33
|
+
fs.writeFileSync(lockPath, JSON.stringify(metadata, null, 2));
|
|
34
|
+
const result = runLockStatus({
|
|
35
|
+
eventsDbPath: eventsDb,
|
|
36
|
+
json: true,
|
|
37
|
+
});
|
|
38
|
+
expect(result.success).toBe(true);
|
|
39
|
+
expect(result.locked).toBe(true);
|
|
40
|
+
expect(result.metadata?.pid).toBe(99999);
|
|
41
|
+
expect(result.metadata?.command).toBe('test-command');
|
|
42
|
+
});
|
|
43
|
+
});
|
|
44
|
+
describe('runLockClear', () => {
|
|
45
|
+
it('reports no lock when none exists', () => {
|
|
46
|
+
const result = runLockClear({
|
|
47
|
+
eventsDbPath: eventsDb,
|
|
48
|
+
json: true,
|
|
49
|
+
});
|
|
50
|
+
expect(result.success).toBe(true);
|
|
51
|
+
expect(result.cleared).toBe(false);
|
|
52
|
+
expect(result.message).toContain('No lock file exists');
|
|
53
|
+
});
|
|
54
|
+
it('clears stale lock without --force', () => {
|
|
55
|
+
// Create a stale lock (non-existent PID)
|
|
56
|
+
const metadata = {
|
|
57
|
+
pid: 99999,
|
|
58
|
+
hostname: os.hostname(),
|
|
59
|
+
startedAt: Date.now(),
|
|
60
|
+
command: 'dead-process',
|
|
61
|
+
};
|
|
62
|
+
fs.writeFileSync(lockPath, JSON.stringify(metadata, null, 2));
|
|
63
|
+
const result = runLockClear({
|
|
64
|
+
eventsDbPath: eventsDb,
|
|
65
|
+
json: true,
|
|
66
|
+
});
|
|
67
|
+
expect(result.success).toBe(true);
|
|
68
|
+
expect(result.cleared).toBe(true);
|
|
69
|
+
expect(result.wasStale).toBe(true);
|
|
70
|
+
expect(fs.existsSync(lockPath)).toBe(false);
|
|
71
|
+
});
|
|
72
|
+
it('refuses to clear active lock without --force', () => {
|
|
73
|
+
// Create a lock with current process PID (definitely active)
|
|
74
|
+
const metadata = {
|
|
75
|
+
pid: process.pid,
|
|
76
|
+
hostname: os.hostname(),
|
|
77
|
+
startedAt: Date.now(),
|
|
78
|
+
command: 'current-process',
|
|
79
|
+
};
|
|
80
|
+
fs.writeFileSync(lockPath, JSON.stringify(metadata, null, 2));
|
|
81
|
+
const result = runLockClear({
|
|
82
|
+
eventsDbPath: eventsDb,
|
|
83
|
+
json: true,
|
|
84
|
+
force: false,
|
|
85
|
+
});
|
|
86
|
+
expect(result.success).toBe(false);
|
|
87
|
+
expect(result.cleared).toBe(false);
|
|
88
|
+
expect(result.message).toContain('Use --force');
|
|
89
|
+
expect(fs.existsSync(lockPath)).toBe(true);
|
|
90
|
+
});
|
|
91
|
+
it('clears active lock with --force', () => {
|
|
92
|
+
// Create a lock with current process PID
|
|
93
|
+
const metadata = {
|
|
94
|
+
pid: process.pid,
|
|
95
|
+
hostname: os.hostname(),
|
|
96
|
+
startedAt: Date.now(),
|
|
97
|
+
command: 'current-process',
|
|
98
|
+
};
|
|
99
|
+
fs.writeFileSync(lockPath, JSON.stringify(metadata, null, 2));
|
|
100
|
+
const result = runLockClear({
|
|
101
|
+
eventsDbPath: eventsDb,
|
|
102
|
+
json: true,
|
|
103
|
+
force: true,
|
|
104
|
+
});
|
|
105
|
+
expect(result.success).toBe(true);
|
|
106
|
+
expect(result.cleared).toBe(true);
|
|
107
|
+
expect(result.wasStale).toBe(false);
|
|
108
|
+
expect(fs.existsSync(lockPath)).toBe(false);
|
|
109
|
+
});
|
|
110
|
+
});
|
|
111
|
+
describe('createLockCommand', () => {
|
|
112
|
+
it('creates a command with correct name', () => {
|
|
113
|
+
const cmd = createLockCommand();
|
|
114
|
+
expect(cmd.name()).toBe('lock');
|
|
115
|
+
});
|
|
116
|
+
it('has status and clear subcommands', () => {
|
|
117
|
+
const cmd = createLockCommand();
|
|
118
|
+
const subcommands = cmd.commands.map((c) => c.name());
|
|
119
|
+
expect(subcommands).toContain('status');
|
|
120
|
+
expect(subcommands).toContain('clear');
|
|
121
|
+
});
|
|
122
|
+
it('clear subcommand has --force option', () => {
|
|
123
|
+
const cmd = createLockCommand();
|
|
124
|
+
const clearCmd = cmd.commands.find((c) => c.name() === 'clear');
|
|
125
|
+
const opts = clearCmd?.options.map((o) => o.long);
|
|
126
|
+
expect(opts).toContain('--force');
|
|
127
|
+
});
|
|
128
|
+
});
|
|
129
|
+
});
|
|
130
|
+
//# sourceMappingURL=lock.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"lock.test.js","sourceRoot":"","sources":["../../src/commands/lock.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { Command } from 'commander';
|
|
2
|
-
import {
|
|
2
|
+
import { resolveDbPaths } from '../../config.js';
|
|
3
3
|
import { initializeDb, closeDb } from '../../db.js';
|
|
4
4
|
import { handleError } from '../../errors.js';
|
|
5
5
|
import { GlobalOptionsSchema } from '../../types.js';
|
|
@@ -29,8 +29,8 @@ export function createProjectCreateCommand() {
|
|
|
29
29
|
.option('-d, --description <desc>', 'Project description')
|
|
30
30
|
.action(function (name, opts) {
|
|
31
31
|
const globalOpts = GlobalOptionsSchema.parse(this.optsWithGlobals());
|
|
32
|
-
const
|
|
33
|
-
const services = initializeDb(
|
|
32
|
+
const { eventsDbPath, cacheDbPath } = resolveDbPaths(globalOpts.db);
|
|
33
|
+
const services = initializeDb({ eventsDbPath, cacheDbPath });
|
|
34
34
|
try {
|
|
35
35
|
runProjectCreate({
|
|
36
36
|
services,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"create.js","sourceRoot":"","sources":["../../../src/commands/project/create.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"create.js","sourceRoot":"","sources":["../../../src/commands/project/create.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,OAAO,EAAE,cAAc,EAAE,MAAM,iBAAiB,CAAC;AACjD,OAAO,EAAE,YAAY,EAAE,OAAO,EAAiB,MAAM,aAAa,CAAC;AACnE,OAAO,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAC;AAC9C,OAAO,EAAE,mBAAmB,EAAE,MAAM,gBAAgB,CAAC;AAoBrD,MAAM,UAAU,gBAAgB,CAC9B,OAA6B;IAE7B,MAAM,EAAE,QAAQ,EAAE,IAAI,EAAE,WAAW,EAAE,IAAI,EAAE,GAAG,OAAO,CAAC;IAEtD,MAAM,OAAO,GAAG,QAAQ,CAAC,cAAc,CAAC,aAAa,CAAC,IAAI,EAAE;QAC1D,WAAW;KACZ,CAAC,CAAC;IAEH,MAAM,MAAM,GAAwB;QAClC,IAAI,EAAE,OAAO,CAAC,IAAI;QAClB,WAAW,EAAE,OAAO,CAAC,WAAW;QAChC,YAAY,EAAE,OAAO,CAAC,YAAY;QAClC,UAAU,EAAE,OAAO,CAAC,UAAU;KAC/B,CAAC;IAEF,IAAI,IAAI,EAAE,CAAC;QACT,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC,CAAC;IACtC,CAAC;SAAM,CAAC;QACN,OAAO,CAAC,GAAG,CAAC,qBAAqB,OAAO,CAAC,IAAI,EAAE,CAAC,CAAC;IACnD,CAAC;IAED,OAAO,MAAM,CAAC;AAChB,CAAC;AAED,MAAM,UAAU,0BAA0B;IACxC,OAAO,IAAI,OAAO,CAAC,QAAQ,CAAC;SACzB,WAAW,CAAC,sBAAsB,CAAC;SACnC,QAAQ,CAAC,QAAQ,EAAE,cAAc,CAAC;SAClC,MAAM,CAAC,0BAA0B,EAAE,qBAAqB,CAAC;SACzD,MAAM,CAAC,UAAyB,IAAY,EAAE,IAAiC;QAC9E,MAAM,UAAU,GAAG,mBAAmB,CAAC,KAAK,CAAC,IAAI,CAAC,eAAe,EAAE,CAAC,CAAC;QACrE,MAAM,EAAE,YAAY,EAAE,WAAW,EAAE,GAAG,cAAc,CAAC,UAAU,CAAC,EAAE,CAAC,CAAC;QACpE,MAAM,QAAQ,GAAG,YAAY,CAAC,EAAE,YAAY,EAAE,WAAW,EAAE,CAAC,CAAC;QAC7D,IAAI,CAAC;YACH,gBAAgB,CAAC;gBACf,QAAQ;gBACR,IAAI;gBACJ,WAAW,EAAE,IAAI,CAAC,WAAW;gBAC7B,IAAI,EAAE,UAAU,CAAC,IAAI,IAAI,KAAK;aAC/B,CAAC,CAAC;QACL,CAAC;QAAC,OAAO,CAAC,EAAE,CAAC;YACX,WAAW,CAAC,CAAC,EAAE,UAAU,CAAC,IAAI,CAAC,CAAC;QAClC,CAAC;gBAAS,CAAC;YACT,OAAO,CAAC,QAAQ,CAAC,CAAC;QACpB,CAAC;IACH,CAAC,CAAC,CAAC;AACP,CAAC"}
|
|
@@ -3,7 +3,7 @@ import fs from 'fs';
|
|
|
3
3
|
import path from 'path';
|
|
4
4
|
import os from 'os';
|
|
5
5
|
import { runProjectCreate } from './create.js';
|
|
6
|
-
import {
|
|
6
|
+
import { initializeDbFromPath, closeDb } from '../../db.js';
|
|
7
7
|
describe('runProjectCreate', () => {
|
|
8
8
|
let tempDir;
|
|
9
9
|
let dbPath;
|
|
@@ -11,7 +11,7 @@ describe('runProjectCreate', () => {
|
|
|
11
11
|
beforeEach(() => {
|
|
12
12
|
tempDir = fs.mkdtempSync(path.join(os.tmpdir(), 'hzl-project-create-test-'));
|
|
13
13
|
dbPath = path.join(tempDir, 'test.db');
|
|
14
|
-
services =
|
|
14
|
+
services = initializeDbFromPath(dbPath);
|
|
15
15
|
});
|
|
16
16
|
afterEach(() => {
|
|
17
17
|
closeDb(services);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"create.test.js","sourceRoot":"","sources":["../../../src/commands/project/create.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,EAAE,EAAE,MAAM,EAAE,UAAU,EAAE,SAAS,EAAE,MAAM,QAAQ,CAAC;AACrE,OAAO,EAAE,MAAM,IAAI,CAAC;AACpB,OAAO,IAAI,MAAM,MAAM,CAAC;AACxB,OAAO,EAAE,MAAM,IAAI,CAAC;AACpB,OAAO,EAAE,gBAAgB,EAAE,MAAM,aAAa,CAAC;AAC/C,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"create.test.js","sourceRoot":"","sources":["../../../src/commands/project/create.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,EAAE,EAAE,MAAM,EAAE,UAAU,EAAE,SAAS,EAAE,MAAM,QAAQ,CAAC;AACrE,OAAO,EAAE,MAAM,IAAI,CAAC;AACpB,OAAO,IAAI,MAAM,MAAM,CAAC;AACxB,OAAO,EAAE,MAAM,IAAI,CAAC;AACpB,OAAO,EAAE,gBAAgB,EAAE,MAAM,aAAa,CAAC;AAC/C,OAAO,EAAE,oBAAoB,EAAE,OAAO,EAAiB,MAAM,aAAa,CAAC;AAE3E,QAAQ,CAAC,kBAAkB,EAAE,GAAG,EAAE;IAChC,IAAI,OAAe,CAAC;IACpB,IAAI,MAAc,CAAC;IACnB,IAAI,QAAkB,CAAC;IAEvB,UAAU,CAAC,GAAG,EAAE;QACd,OAAO,GAAG,EAAE,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,MAAM,EAAE,EAAE,0BAA0B,CAAC,CAAC,CAAC;QAC7E,MAAM,GAAG,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,SAAS,CAAC,CAAC;QACvC,QAAQ,GAAG,oBAAoB,CAAC,MAAM,CAAC,CAAC;IAC1C,CAAC,CAAC,CAAC;IAEH,SAAS,CAAC,GAAG,EAAE;QACb,OAAO,CAAC,QAAQ,CAAC,CAAC;QAClB,EAAE,CAAC,MAAM,CAAC,OAAO,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC,CAAC;IACvD,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,kCAAkC,EAAE,GAAG,EAAE;QAC1C,MAAM,MAAM,GAAG,gBAAgB,CAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,WAAW,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC,CAAC;QAE9E,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;QACtC,MAAM,CAAC,MAAM,CAAC,WAAW,CAAC,CAAC,QAAQ,EAAE,CAAC;QACtC,MAAM,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC1C,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,oCAAoC,EAAE,GAAG,EAAE;QAC5C,MAAM,MAAM,GAAG,gBAAgB,CAAC;YAC9B,QAAQ;YACR,IAAI,EAAE,WAAW;YACjB,WAAW,EAAE,cAAc;YAC3B,IAAI,EAAE,KAAK;SACZ,CAAC,CAAC;QAEH,MAAM,CAAC,MAAM,CAAC,WAAW,CAAC,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;IAClD,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -1,10 +1,10 @@
|
|
|
1
1
|
import { Command } from 'commander';
|
|
2
|
-
import {
|
|
2
|
+
import { resolveDbPaths } from '../../config.js';
|
|
3
3
|
import { initializeDb, closeDb } from '../../db.js';
|
|
4
4
|
import { CLIError, ExitCode, handleError } from '../../errors.js';
|
|
5
5
|
import { GlobalOptionsSchema } from '../../types.js';
|
|
6
6
|
import { EventType, PROJECT_EVENT_TASK_ID } from 'hzl-core/events/types.js';
|
|
7
|
-
import { withWriteTransaction } from 'hzl-core/db/
|
|
7
|
+
import { withWriteTransaction } from 'hzl-core/db/transaction.js';
|
|
8
8
|
/**
|
|
9
9
|
* Deletes tasks directly from projection tables without recording events.
|
|
10
10
|
*
|
|
@@ -20,22 +20,22 @@ function deleteTasksFromProjections(services, taskIds) {
|
|
|
20
20
|
if (taskIds.length === 0)
|
|
21
21
|
return 0;
|
|
22
22
|
const placeholders = taskIds.map(() => '?').join(', ');
|
|
23
|
-
services.
|
|
23
|
+
services.cacheDb
|
|
24
24
|
.prepare(`DELETE FROM task_dependencies WHERE task_id IN (${placeholders}) OR depends_on_id IN (${placeholders})`)
|
|
25
25
|
.run(...taskIds, ...taskIds);
|
|
26
|
-
services.
|
|
26
|
+
services.cacheDb
|
|
27
27
|
.prepare(`DELETE FROM task_tags WHERE task_id IN (${placeholders})`)
|
|
28
28
|
.run(...taskIds);
|
|
29
|
-
services.
|
|
29
|
+
services.cacheDb
|
|
30
30
|
.prepare(`DELETE FROM task_comments WHERE task_id IN (${placeholders})`)
|
|
31
31
|
.run(...taskIds);
|
|
32
|
-
services.
|
|
32
|
+
services.cacheDb
|
|
33
33
|
.prepare(`DELETE FROM task_checkpoints WHERE task_id IN (${placeholders})`)
|
|
34
34
|
.run(...taskIds);
|
|
35
|
-
services.
|
|
35
|
+
services.cacheDb
|
|
36
36
|
.prepare(`DELETE FROM task_search WHERE task_id IN (${placeholders})`)
|
|
37
37
|
.run(...taskIds);
|
|
38
|
-
services.
|
|
38
|
+
services.cacheDb
|
|
39
39
|
.prepare(`DELETE FROM tasks_current WHERE task_id IN (${placeholders})`)
|
|
40
40
|
.run(...taskIds);
|
|
41
41
|
return taskIds.length;
|
|
@@ -53,7 +53,7 @@ export function runProjectDelete(options) {
|
|
|
53
53
|
if (project.is_protected) {
|
|
54
54
|
throw new CLIError(`Cannot delete protected project: ${name}`, ExitCode.InvalidUsage);
|
|
55
55
|
}
|
|
56
|
-
const taskRows = services.
|
|
56
|
+
const taskRows = services.cacheDb
|
|
57
57
|
.prepare('SELECT task_id, status, project FROM tasks_current WHERE project = ?')
|
|
58
58
|
.all(name);
|
|
59
59
|
const archivedCount = taskRows.filter((row) => row.status === 'archived').length;
|
|
@@ -66,7 +66,7 @@ export function runProjectDelete(options) {
|
|
|
66
66
|
services.projectService.requireProject(moveTo);
|
|
67
67
|
}
|
|
68
68
|
// Wrap all mutations in a single atomic transaction
|
|
69
|
-
const result = withWriteTransaction(services.
|
|
69
|
+
const result = withWriteTransaction(services.cacheDb, () => {
|
|
70
70
|
if (moveTo) {
|
|
71
71
|
// Move each task by appending TaskMoved events
|
|
72
72
|
for (const row of taskRows) {
|
|
@@ -138,8 +138,8 @@ export function createProjectDeleteCommand() {
|
|
|
138
138
|
.option('--delete-tasks', 'Delete tasks before deleting project')
|
|
139
139
|
.action(function (name, opts) {
|
|
140
140
|
const globalOpts = GlobalOptionsSchema.parse(this.optsWithGlobals());
|
|
141
|
-
const
|
|
142
|
-
const services = initializeDb(
|
|
141
|
+
const { eventsDbPath, cacheDbPath } = resolveDbPaths(globalOpts.db);
|
|
142
|
+
const services = initializeDb({ eventsDbPath, cacheDbPath });
|
|
143
143
|
try {
|
|
144
144
|
runProjectDelete({
|
|
145
145
|
services,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"delete.js","sourceRoot":"","sources":["../../../src/commands/project/delete.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"delete.js","sourceRoot":"","sources":["../../../src/commands/project/delete.ts"],"names":[],"mappings":"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"}
|
|
@@ -3,7 +3,7 @@ import fs from 'fs';
|
|
|
3
3
|
import path from 'path';
|
|
4
4
|
import os from 'os';
|
|
5
5
|
import { runProjectDelete } from './delete.js';
|
|
6
|
-
import {
|
|
6
|
+
import { initializeDbFromPath, closeDb } from '../../db.js';
|
|
7
7
|
import { CLIError } from '../../errors.js';
|
|
8
8
|
describe('runProjectDelete', () => {
|
|
9
9
|
let tempDir;
|
|
@@ -12,7 +12,7 @@ describe('runProjectDelete', () => {
|
|
|
12
12
|
beforeEach(() => {
|
|
13
13
|
tempDir = fs.mkdtempSync(path.join(os.tmpdir(), 'hzl-project-delete-test-'));
|
|
14
14
|
dbPath = path.join(tempDir, 'test.db');
|
|
15
|
-
services =
|
|
15
|
+
services = initializeDbFromPath(dbPath);
|
|
16
16
|
services.projectService.createProject('source');
|
|
17
17
|
services.projectService.createProject('target');
|
|
18
18
|
});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"delete.test.js","sourceRoot":"","sources":["../../../src/commands/project/delete.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,EAAE,EAAE,MAAM,EAAE,UAAU,EAAE,SAAS,EAAE,MAAM,QAAQ,CAAC;AACrE,OAAO,EAAE,MAAM,IAAI,CAAC;AACpB,OAAO,IAAI,MAAM,MAAM,CAAC;AACxB,OAAO,EAAE,MAAM,IAAI,CAAC;AACpB,OAAO,EAAE,gBAAgB,EAAE,MAAM,aAAa,CAAC;AAC/C,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"delete.test.js","sourceRoot":"","sources":["../../../src/commands/project/delete.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,11 +1,11 @@
|
|
|
1
1
|
import { Command } from 'commander';
|
|
2
|
-
import {
|
|
2
|
+
import { resolveDbPaths } from '../../config.js';
|
|
3
3
|
import { initializeDb, closeDb } from '../../db.js';
|
|
4
4
|
import { handleError } from '../../errors.js';
|
|
5
5
|
import { GlobalOptionsSchema } from '../../types.js';
|
|
6
6
|
export function runProjectList(options) {
|
|
7
7
|
const { services, json } = options;
|
|
8
|
-
const rows = services.
|
|
8
|
+
const rows = services.cacheDb
|
|
9
9
|
.prepare(`
|
|
10
10
|
SELECT
|
|
11
11
|
p.name,
|
|
@@ -53,8 +53,8 @@ export function createProjectListCommand() {
|
|
|
53
53
|
.description('List projects with task counts')
|
|
54
54
|
.action(function () {
|
|
55
55
|
const globalOpts = GlobalOptionsSchema.parse(this.optsWithGlobals());
|
|
56
|
-
const
|
|
57
|
-
const services = initializeDb(
|
|
56
|
+
const { eventsDbPath, cacheDbPath } = resolveDbPaths(globalOpts.db);
|
|
57
|
+
const services = initializeDb({ eventsDbPath, cacheDbPath });
|
|
58
58
|
try {
|
|
59
59
|
runProjectList({ services, json: globalOpts.json ?? false });
|
|
60
60
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"list.js","sourceRoot":"","sources":["../../../src/commands/project/list.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"list.js","sourceRoot":"","sources":["../../../src/commands/project/list.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,OAAO,EAAE,cAAc,EAAE,MAAM,iBAAiB,CAAC;AACjD,OAAO,EAAE,YAAY,EAAE,OAAO,EAAiB,MAAM,aAAa,CAAC;AACnE,OAAO,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAC;AAC9C,OAAO,EAAE,mBAAmB,EAAE,MAAM,gBAAgB,CAAC;AAerD,MAAM,UAAU,cAAc,CAAC,OAG9B;IACC,MAAM,EAAE,QAAQ,EAAE,IAAI,EAAE,GAAG,OAAO,CAAC;IAEnC,MAAM,IAAI,GAAG,QAAQ,CAAC,OAAO;SAC1B,OAAO,CACN;;;;;;;;;;;KAWD,CACA;SACA,GAAG,EAMH,CAAC;IAEJ,MAAM,QAAQ,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE;QAChC,MAAM,aAAa,GAAG,GAAG,CAAC,mBAAmB,IAAI,CAAC,CAAC;QACnD,MAAM,UAAU,GAAG,GAAG,CAAC,UAAU,IAAI,CAAC,CAAC;QACvC,OAAO;YACL,IAAI,EAAE,GAAG,CAAC,IAAI;YACd,WAAW,EAAE,GAAG,CAAC,WAAW;YAC5B,YAAY,EAAE,GAAG,CAAC,YAAY,KAAK,CAAC;YACpC,UAAU,EAAE,UAAU;YACtB,mBAAmB,EAAE,aAAa;YAClC,iBAAiB,EAAE,UAAU,GAAG,aAAa;SAC9C,CAAC;IACJ,CAAC,CAAC,CAAC;IAEH,MAAM,MAAM,GAAsB,EAAE,QAAQ,EAAE,CAAC;IAE/C,IAAI,IAAI,EAAE,CAAC;QACT,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC,CAAC;IACtC,CAAC;SAAM,CAAC;QACN,IAAI,QAAQ,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YAC1B,OAAO,CAAC,GAAG,CAAC,mBAAmB,CAAC,CAAC;QACnC,CAAC;aAAM,CAAC;YACN,OAAO,CAAC,GAAG,CAAC,WAAW,CAAC,CAAC;YACzB,KAAK,MAAM,OAAO,IAAI,QAAQ,EAAE,CAAC;gBAC/B,OAAO,CAAC,GAAG,CACT,KAAK,OAAO,CAAC,IAAI,KAAK,OAAO,CAAC,iBAAiB,YAAY,OAAO,CAAC,mBAAmB,WAAW,CAClG,CAAC;YACJ,CAAC;QACH,CAAC;IACH,CAAC;IAED,OAAO,MAAM,CAAC;AAChB,CAAC;AAED,MAAM,UAAU,wBAAwB;IACtC,OAAO,IAAI,OAAO,CAAC,MAAM,CAAC;SACvB,WAAW,CAAC,gCAAgC,CAAC;SAC7C,MAAM,CAAC;QACN,MAAM,UAAU,GAAG,mBAAmB,CAAC,KAAK,CAAC,IAAI,CAAC,eAAe,EAAE,CAAC,CAAC;QACrE,MAAM,EAAE,YAAY,EAAE,WAAW,EAAE,GAAG,cAAc,CAAC,UAAU,CAAC,EAAE,CAAC,CAAC;QACpE,MAAM,QAAQ,GAAG,YAAY,CAAC,EAAE,YAAY,EAAE,WAAW,EAAE,CAAC,CAAC;QAC7D,IAAI,CAAC;YACH,cAAc,CAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,UAAU,CAAC,IAAI,IAAI,KAAK,EAAE,CAAC,CAAC;QAC/D,CAAC;QAAC,OAAO,CAAC,EAAE,CAAC;YACX,WAAW,CAAC,CAAC,EAAE,UAAU,CAAC,IAAI,CAAC,CAAC;QAClC,CAAC;gBAAS,CAAC;YACT,OAAO,CAAC,QAAQ,CAAC,CAAC;QACpB,CAAC;IACH,CAAC,CAAC,CAAC;AACP,CAAC"}
|
|
@@ -3,7 +3,7 @@ import fs from 'fs';
|
|
|
3
3
|
import path from 'path';
|
|
4
4
|
import os from 'os';
|
|
5
5
|
import { runProjectList } from './list.js';
|
|
6
|
-
import {
|
|
6
|
+
import { initializeDbFromPath, closeDb } from '../../db.js';
|
|
7
7
|
describe('runProjectList', () => {
|
|
8
8
|
let tempDir;
|
|
9
9
|
let dbPath;
|
|
@@ -11,7 +11,7 @@ describe('runProjectList', () => {
|
|
|
11
11
|
beforeEach(() => {
|
|
12
12
|
tempDir = fs.mkdtempSync(path.join(os.tmpdir(), 'hzl-project-list-test-'));
|
|
13
13
|
dbPath = path.join(tempDir, 'test.db');
|
|
14
|
-
services =
|
|
14
|
+
services = initializeDbFromPath(dbPath);
|
|
15
15
|
});
|
|
16
16
|
afterEach(() => {
|
|
17
17
|
closeDb(services);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"list.test.js","sourceRoot":"","sources":["../../../src/commands/project/list.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,EAAE,EAAE,MAAM,EAAE,UAAU,EAAE,SAAS,EAAE,MAAM,QAAQ,CAAC;AACrE,OAAO,EAAE,MAAM,IAAI,CAAC;AACpB,OAAO,IAAI,MAAM,MAAM,CAAC;AACxB,OAAO,EAAE,MAAM,IAAI,CAAC;AACpB,OAAO,EAAE,cAAc,EAAE,MAAM,WAAW,CAAC;AAC3C,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"list.test.js","sourceRoot":"","sources":["../../../src/commands/project/list.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { Command } from 'commander';
|
|
2
|
-
import {
|
|
2
|
+
import { resolveDbPaths } from '../../config.js';
|
|
3
3
|
import { initializeDb, closeDb } from '../../db.js';
|
|
4
4
|
import { handleError } from '../../errors.js';
|
|
5
5
|
import { GlobalOptionsSchema } from '../../types.js';
|
|
@@ -25,8 +25,8 @@ export function createProjectRenameCommand() {
|
|
|
25
25
|
.argument('<newName>', 'New project name')
|
|
26
26
|
.action(function (oldName, newName) {
|
|
27
27
|
const globalOpts = GlobalOptionsSchema.parse(this.optsWithGlobals());
|
|
28
|
-
const
|
|
29
|
-
const services = initializeDb(
|
|
28
|
+
const { eventsDbPath, cacheDbPath } = resolveDbPaths(globalOpts.db);
|
|
29
|
+
const services = initializeDb({ eventsDbPath, cacheDbPath });
|
|
30
30
|
try {
|
|
31
31
|
runProjectRename({
|
|
32
32
|
services,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"rename.js","sourceRoot":"","sources":["../../../src/commands/project/rename.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"rename.js","sourceRoot":"","sources":["../../../src/commands/project/rename.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,OAAO,EAAE,cAAc,EAAE,MAAM,iBAAiB,CAAC;AACjD,OAAO,EAAE,YAAY,EAAE,OAAO,EAAiB,MAAM,aAAa,CAAC;AACnE,OAAO,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAC;AAC9C,OAAO,EAAE,mBAAmB,EAAE,MAAM,gBAAgB,CAAC;AAcrD,MAAM,UAAU,gBAAgB,CAC9B,OAA6B;IAE7B,MAAM,EAAE,QAAQ,EAAE,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,GAAG,OAAO,CAAC;IAErD,QAAQ,CAAC,cAAc,CAAC,aAAa,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC;IAExD,MAAM,MAAM,GAAwB;QAClC,QAAQ,EAAE,OAAO;QACjB,QAAQ,EAAE,OAAO;KAClB,CAAC;IAEF,IAAI,IAAI,EAAE,CAAC;QACT,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC,CAAC;IACtC,CAAC;SAAM,CAAC;QACN,OAAO,CAAC,GAAG,CAAC,sBAAsB,OAAO,SAAS,OAAO,GAAG,CAAC,CAAC;IAChE,CAAC;IAED,OAAO,MAAM,CAAC;AAChB,CAAC;AAED,MAAM,UAAU,0BAA0B;IACxC,OAAO,IAAI,OAAO,CAAC,QAAQ,CAAC;SACzB,WAAW,CAAC,kBAAkB,CAAC;SAC/B,QAAQ,CAAC,WAAW,EAAE,sBAAsB,CAAC;SAC7C,QAAQ,CAAC,WAAW,EAAE,kBAAkB,CAAC;SACzC,MAAM,CAAC,UAAyB,OAAe,EAAE,OAAe;QAC/D,MAAM,UAAU,GAAG,mBAAmB,CAAC,KAAK,CAAC,IAAI,CAAC,eAAe,EAAE,CAAC,CAAC;QACrE,MAAM,EAAE,YAAY,EAAE,WAAW,EAAE,GAAG,cAAc,CAAC,UAAU,CAAC,EAAE,CAAC,CAAC;QACpE,MAAM,QAAQ,GAAG,YAAY,CAAC,EAAE,YAAY,EAAE,WAAW,EAAE,CAAC,CAAC;QAC7D,IAAI,CAAC;YACH,gBAAgB,CAAC;gBACf,QAAQ;gBACR,OAAO;gBACP,OAAO;gBACP,IAAI,EAAE,UAAU,CAAC,IAAI,IAAI,KAAK;aAC/B,CAAC,CAAC;QACL,CAAC;QAAC,OAAO,CAAC,EAAE,CAAC;YACX,WAAW,CAAC,CAAC,EAAE,UAAU,CAAC,IAAI,CAAC,CAAC;QAClC,CAAC;gBAAS,CAAC;YACT,OAAO,CAAC,QAAQ,CAAC,CAAC;QACpB,CAAC;IACH,CAAC,CAAC,CAAC;AACP,CAAC"}
|
|
@@ -3,7 +3,7 @@ import fs from 'fs';
|
|
|
3
3
|
import path from 'path';
|
|
4
4
|
import os from 'os';
|
|
5
5
|
import { runProjectRename } from './rename.js';
|
|
6
|
-
import {
|
|
6
|
+
import { initializeDbFromPath, closeDb } from '../../db.js';
|
|
7
7
|
import { ProjectAlreadyExistsError } from 'hzl-core/services/project-service.js';
|
|
8
8
|
describe('runProjectRename', () => {
|
|
9
9
|
let tempDir;
|
|
@@ -12,7 +12,7 @@ describe('runProjectRename', () => {
|
|
|
12
12
|
beforeEach(() => {
|
|
13
13
|
tempDir = fs.mkdtempSync(path.join(os.tmpdir(), 'hzl-project-rename-test-'));
|
|
14
14
|
dbPath = path.join(tempDir, 'test.db');
|
|
15
|
-
services =
|
|
15
|
+
services = initializeDbFromPath(dbPath);
|
|
16
16
|
});
|
|
17
17
|
afterEach(() => {
|
|
18
18
|
closeDb(services);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"rename.test.js","sourceRoot":"","sources":["../../../src/commands/project/rename.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,EAAE,EAAE,MAAM,EAAE,UAAU,EAAE,SAAS,EAAE,MAAM,QAAQ,CAAC;AACrE,OAAO,EAAE,MAAM,IAAI,CAAC;AACpB,OAAO,IAAI,MAAM,MAAM,CAAC;AACxB,OAAO,EAAE,MAAM,IAAI,CAAC;AACpB,OAAO,EAAE,gBAAgB,EAAE,MAAM,aAAa,CAAC;AAC/C,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"rename.test.js","sourceRoot":"","sources":["../../../src/commands/project/rename.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,EAAE,EAAE,MAAM,EAAE,UAAU,EAAE,SAAS,EAAE,MAAM,QAAQ,CAAC;AACrE,OAAO,EAAE,MAAM,IAAI,CAAC;AACpB,OAAO,IAAI,MAAM,MAAM,CAAC;AACxB,OAAO,EAAE,MAAM,IAAI,CAAC;AACpB,OAAO,EAAE,gBAAgB,EAAE,MAAM,aAAa,CAAC;AAC/C,OAAO,EAAE,oBAAoB,EAAE,OAAO,EAAiB,MAAM,aAAa,CAAC;AAC3E,OAAO,EAAE,yBAAyB,EAAE,MAAM,sCAAsC,CAAC;AAEjF,QAAQ,CAAC,kBAAkB,EAAE,GAAG,EAAE;IAChC,IAAI,OAAe,CAAC;IACpB,IAAI,MAAc,CAAC;IACnB,IAAI,QAAkB,CAAC;IAEvB,UAAU,CAAC,GAAG,EAAE;QACd,OAAO,GAAG,EAAE,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,MAAM,EAAE,EAAE,0BAA0B,CAAC,CAAC,CAAC;QAC7E,MAAM,GAAG,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,SAAS,CAAC,CAAC;QACvC,QAAQ,GAAG,oBAAoB,CAAC,MAAM,CAAC,CAAC;IAC1C,CAAC,CAAC,CAAC;IAEH,SAAS,CAAC,GAAG,EAAE;QACb,OAAO,CAAC,QAAQ,CAAC,CAAC;QAClB,EAAE,CAAC,MAAM,CAAC,OAAO,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC,CAAC;IACvD,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,mBAAmB,EAAE,GAAG,EAAE;QAC3B,QAAQ,CAAC,cAAc,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;QAE7C,MAAM,MAAM,GAAG,gBAAgB,CAAC,EAAE,QAAQ,EAAE,OAAO,EAAE,KAAK,EAAE,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC,CAAC;QAE3F,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACpC,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACpC,MAAM,CAAC,QAAQ,CAAC,cAAc,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC,CAAC,QAAQ,EAAE,CAAC;QAC7D,MAAM,CAAC,QAAQ,CAAC,cAAc,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC;IACnE,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,2CAA2C,EAAE,GAAG,EAAE;QACnD,QAAQ,CAAC,cAAc,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;QAC7C,QAAQ,CAAC,cAAc,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;QAE7C,MAAM,CAAC,GAAG,EAAE,CAAC,gBAAgB,CAAC,EAAE,QAAQ,EAAE,OAAO,EAAE,KAAK,EAAE,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC,CAAC;aACtF,OAAO,CAAC,yBAAyB,CAAC,CAAC;IACxC,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|