sqlew 4.1.1 → 4.1.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.
- package/CHANGELOG.md +1830 -1817
- package/dist/database/initialization/schema-version.js +1 -1
- package/dist/database/initialization/schema-version.js.map +1 -1
- package/dist/database/migrations/v4/20251126000000_v4_bootstrap.js +32 -32
- package/dist/database/migrations/v4/20251225000000_v4_seed_missing_help_data.d.ts +14 -0
- package/dist/database/migrations/v4/20251225000000_v4_seed_missing_help_data.d.ts.map +1 -0
- package/dist/database/migrations/v4/20251225000000_v4_seed_missing_help_data.js +201 -0
- package/dist/database/migrations/v4/20251225000000_v4_seed_missing_help_data.js.map +1 -0
- package/dist/database/migrations/v4/20251225000001_v4_fix_help_params.d.ts +12 -0
- package/dist/database/migrations/v4/20251225000001_v4_fix_help_params.d.ts.map +1 -0
- package/dist/database/migrations/v4/20251225000001_v4_fix_help_params.js +61 -0
- package/dist/database/migrations/v4/20251225000001_v4_fix_help_params.js.map +1 -0
- package/dist/server/setup.d.ts.map +1 -1
- package/dist/server/setup.js +28 -6
- package/dist/server/setup.js.map +1 -1
- package/dist/tests/database/sql-dump/table-ordering.test.js +6 -1
- package/dist/tests/database/sql-dump/table-ordering.test.js.map +1 -1
- package/dist/tests/docker/native/constraint-operations.test.js +74 -137
- package/dist/tests/docker/native/constraint-operations.test.js.map +1 -1
- package/dist/tests/docker/native/decision-operations.test.js +52 -40
- package/dist/tests/docker/native/decision-operations.test.js.map +1 -1
- package/dist/tests/docker/native/help-system.test.d.ts +3 -2
- package/dist/tests/docker/native/help-system.test.d.ts.map +1 -1
- package/dist/tests/docker/native/help-system.test.js +90 -80
- package/dist/tests/docker/native/help-system.test.js.map +1 -1
- package/dist/tests/docker/native/suggest-tool.test.d.ts +2 -2
- package/dist/tests/docker/native/suggest-tool.test.js +130 -63
- package/dist/tests/docker/native/suggest-tool.test.js.map +1 -1
- package/dist/tests/docker/native/task-operations.test.js +9 -19
- package/dist/tests/docker/native/task-operations.test.js.map +1 -1
- package/dist/tests/docker/native/test-harness.d.ts.map +1 -1
- package/dist/tests/docker/native/test-harness.js +6 -5
- package/dist/tests/docker/native/test-harness.js.map +1 -1
- package/dist/tests/feature/decision/batch-validation-comprehensive.test.js +7 -8
- package/dist/tests/feature/decision/batch-validation-comprehensive.test.js.map +1 -1
- package/dist/tests/feature/decision/context-modular.test.js +1 -3
- package/dist/tests/feature/decision/context-modular.test.js.map +1 -1
- package/dist/tests/feature/help/help-system.test.d.ts +1 -13
- package/dist/tests/feature/help/help-system.test.d.ts.map +1 -1
- package/dist/tests/feature/help/help-system.test.js +107 -331
- package/dist/tests/feature/help/help-system.test.js.map +1 -1
- package/dist/tests/feature/task/auto-pruning-decision-link.test.js +2 -4
- package/dist/tests/feature/task/auto-pruning-decision-link.test.js.map +1 -1
- package/dist/tests/integration/all-features.standalone.js +1 -3
- package/dist/tests/integration/all-features.standalone.js.map +1 -1
- package/dist/tests/migrations/test-all-versions-real.js +2 -4
- package/dist/tests/migrations/test-all-versions-real.js.map +1 -1
- package/dist/tests/migrations/test-all-versions.js +3 -7
- package/dist/tests/migrations/test-all-versions.js.map +1 -1
- package/dist/tests/unit/universal-knex.test.js +3 -0
- package/dist/tests/unit/universal-knex.test.js.map +1 -1
- package/dist/tests/unit/utils/config-loader.test.js +130 -191
- package/dist/tests/unit/utils/config-loader.test.js.map +1 -1
- package/dist/tests/unit/utils/project-detector.test.js +24 -0
- package/dist/tests/unit/utils/project-detector.test.js.map +1 -1
- package/dist/tests/unit/validation/parameter-validation.test.js +2 -2
- package/dist/tests/unit/validation/parameter-validation.test.js.map +1 -1
- package/dist/tests/unit/validation/policy-validation.test.js +1 -3
- package/dist/tests/unit/validation/policy-validation.test.js.map +1 -1
- package/dist/tools/files/help/example.js +8 -8
- package/dist/tools/files/help/example.js.map +1 -1
- package/dist/tools/files/help/help.js +4 -4
- package/dist/tools/files/help/help.js.map +1 -1
- package/dist/tools/files/internal/validation.d.ts.map +1 -1
- package/dist/tools/files/internal/validation.js +1 -2
- package/dist/tools/files/internal/validation.js.map +1 -1
- package/dist/tools/help-queries.d.ts.map +1 -1
- package/dist/tools/help-queries.js +57 -27
- package/dist/tools/help-queries.js.map +1 -1
- package/dist/tools/suggest/actions/by-tags.d.ts.map +1 -1
- package/dist/tools/suggest/actions/by-tags.js +3 -1
- package/dist/tools/suggest/actions/by-tags.js.map +1 -1
- package/dist/tools/suggest/help/constraint-help.js +2 -2
- package/dist/tools/suggest/help/constraint-help.js.map +1 -1
- package/dist/tools/tasks/help/example.d.ts.map +1 -1
- package/dist/tools/tasks/help/example.js +10 -0
- package/dist/tools/tasks/help/example.js.map +1 -1
- package/dist/tools/tasks/help/help.d.ts.map +1 -1
- package/dist/tools/tasks/help/help.js +10 -0
- package/dist/tools/tasks/help/help.js.map +1 -1
- package/dist/tools/use_case/actions/search.js +5 -5
- package/dist/tools/use_case/actions/search.js.map +1 -1
- package/dist/tools/use_case/help/example.d.ts +2 -7
- package/dist/tools/use_case/help/example.d.ts.map +1 -1
- package/dist/tools/use_case/help/example.js +24 -37
- package/dist/tools/use_case/help/example.js.map +1 -1
- package/dist/tools/use_case/help/help.js +1 -1
- package/dist/tools/use_case/help/help.js.map +1 -1
- package/dist/types.d.ts +2 -2
- package/dist/types.d.ts.map +1 -1
- package/dist/utils/action-specs/decision-specs.d.ts.map +1 -1
- package/dist/utils/action-specs/decision-specs.js +2 -3
- package/dist/utils/action-specs/decision-specs.js.map +1 -1
- package/dist/utils/action-specs/file-specs.d.ts.map +1 -1
- package/dist/utils/action-specs/file-specs.js +4 -6
- package/dist/utils/action-specs/file-specs.js.map +1 -1
- package/dist/utils/db-aggregations.d.ts.map +1 -1
- package/dist/utils/db-aggregations.js +44 -1
- package/dist/utils/db-aggregations.js.map +1 -1
- package/dist/utils/project-detector.js +21 -6
- package/dist/utils/project-detector.js.map +1 -1
- package/dist/utils/suggestion-scorer.d.ts.map +1 -1
- package/dist/utils/suggestion-scorer.js +5 -0
- package/dist/utils/suggestion-scorer.js.map +1 -1
- package/package.json +87 -123
- package/dist/tests/feature/vcs/git-aware-completion.test.d.ts +0 -6
- package/dist/tests/feature/vcs/git-aware-completion.test.d.ts.map +0 -1
- package/dist/tests/feature/vcs/git-aware-completion.test.js +0 -197
- package/dist/tests/feature/vcs/git-aware-completion.test.js.map +0 -1
- package/dist/tests/feature/vcs/two-step-git-completion.test.d.ts +0 -6
- package/dist/tests/feature/vcs/two-step-git-completion.test.d.ts.map +0 -1
- package/dist/tests/feature/vcs/two-step-git-completion.test.js +0 -305
- package/dist/tests/feature/vcs/two-step-git-completion.test.js.map +0 -1
- package/dist/tests/feature/vcs/vcs-staging.test.d.ts +0 -6
- package/dist/tests/feature/vcs/vcs-staging.test.d.ts.map +0 -1
- package/dist/tests/feature/vcs/vcs-staging.test.js +0 -142
- package/dist/tests/feature/vcs/vcs-staging.test.js.map +0 -1
|
@@ -161,6 +161,6 @@ export const TableNames = {
|
|
|
161
161
|
helpActionParams: () => cachedVersionInfo?.version === 'v4' ? 'v4_help_action_params' : 'm_help_action_params',
|
|
162
162
|
helpActionExamples: () => cachedVersionInfo?.version === 'v4' ? 'v4_help_action_examples' : 'm_help_action_examples',
|
|
163
163
|
helpUseCases: () => cachedVersionInfo?.version === 'v4' ? 'v4_help_use_cases' : 'm_help_use_cases',
|
|
164
|
-
helpUseCaseCategories: () => cachedVersionInfo?.version === 'v4' ? '
|
|
164
|
+
helpUseCaseCategories: () => cachedVersionInfo?.version === 'v4' ? 'v4_help_use_case_cats' : 'v4_help_use_case_cats',
|
|
165
165
|
};
|
|
166
166
|
//# sourceMappingURL=schema-version.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"schema-version.js","sourceRoot":"","sources":["../../../src/database/initialization/schema-version.ts"],"names":[],"mappings":"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
|
|
1
|
+
{"version":3,"file":"schema-version.js","sourceRoot":"","sources":["../../../src/database/initialization/schema-version.ts"],"names":[],"mappings":"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"}
|
|
@@ -484,18 +484,18 @@ export async function up(knex) {
|
|
|
484
484
|
const existingLayers = await knex('v4_layers').count('* as count').first();
|
|
485
485
|
if (!existingLayers || Number(existingLayers.count) === 0) {
|
|
486
486
|
if (db.isPostgreSQL) {
|
|
487
|
-
await knex.raw(`
|
|
488
|
-
INSERT INTO v4_layers (id, name) VALUES
|
|
489
|
-
(1, 'presentation'), (2, 'business'), (3, 'data'), (4, 'infrastructure'),
|
|
490
|
-
(5, 'cross-cutting'), (6, 'documentation'), (7, 'planning'), (8, 'coordination'), (9, 'review')
|
|
491
|
-
ON CONFLICT (id) DO NOTHING
|
|
487
|
+
await knex.raw(`
|
|
488
|
+
INSERT INTO v4_layers (id, name) VALUES
|
|
489
|
+
(1, 'presentation'), (2, 'business'), (3, 'data'), (4, 'infrastructure'),
|
|
490
|
+
(5, 'cross-cutting'), (6, 'documentation'), (7, 'planning'), (8, 'coordination'), (9, 'review')
|
|
491
|
+
ON CONFLICT (id) DO NOTHING
|
|
492
492
|
`);
|
|
493
493
|
}
|
|
494
494
|
else {
|
|
495
|
-
await knex.raw(`
|
|
496
|
-
INSERT ${insertIgnore} INTO v4_layers (id, name) VALUES
|
|
497
|
-
(1, 'presentation'), (2, 'business'), (3, 'data'), (4, 'infrastructure'),
|
|
498
|
-
(5, 'cross-cutting'), (6, 'documentation'), (7, 'planning'), (8, 'coordination'), (9, 'review')
|
|
495
|
+
await knex.raw(`
|
|
496
|
+
INSERT ${insertIgnore} INTO v4_layers (id, name) VALUES
|
|
497
|
+
(1, 'presentation'), (2, 'business'), (3, 'data'), (4, 'infrastructure'),
|
|
498
|
+
(5, 'cross-cutting'), (6, 'documentation'), (7, 'planning'), (8, 'coordination'), (9, 'review')
|
|
499
499
|
`);
|
|
500
500
|
}
|
|
501
501
|
console.error(' ✓ Layers seeded (9)');
|
|
@@ -504,16 +504,16 @@ export async function up(knex) {
|
|
|
504
504
|
const existingCategories = await knex('v4_constraint_categories').count('* as count').first();
|
|
505
505
|
if (!existingCategories || Number(existingCategories.count) === 0) {
|
|
506
506
|
if (db.isPostgreSQL) {
|
|
507
|
-
await knex.raw(`
|
|
508
|
-
INSERT INTO v4_constraint_categories (name) VALUES
|
|
509
|
-
('architecture'), ('security'), ('performance'), ('compatibility'), ('maintainability')
|
|
510
|
-
ON CONFLICT (name) DO NOTHING
|
|
507
|
+
await knex.raw(`
|
|
508
|
+
INSERT INTO v4_constraint_categories (name) VALUES
|
|
509
|
+
('architecture'), ('security'), ('performance'), ('compatibility'), ('maintainability')
|
|
510
|
+
ON CONFLICT (name) DO NOTHING
|
|
511
511
|
`);
|
|
512
512
|
}
|
|
513
513
|
else {
|
|
514
|
-
await knex.raw(`
|
|
515
|
-
INSERT ${insertIgnore} INTO v4_constraint_categories (name) VALUES
|
|
516
|
-
('architecture'), ('security'), ('performance'), ('compatibility'), ('maintainability')
|
|
514
|
+
await knex.raw(`
|
|
515
|
+
INSERT ${insertIgnore} INTO v4_constraint_categories (name) VALUES
|
|
516
|
+
('architecture'), ('security'), ('performance'), ('compatibility'), ('maintainability')
|
|
517
517
|
`);
|
|
518
518
|
}
|
|
519
519
|
console.error(' ✓ Constraint categories seeded (5)');
|
|
@@ -522,16 +522,16 @@ export async function up(knex) {
|
|
|
522
522
|
const existingStatuses = await knex('v4_task_statuses').count('* as count').first();
|
|
523
523
|
if (!existingStatuses || Number(existingStatuses.count) === 0) {
|
|
524
524
|
if (db.isPostgreSQL) {
|
|
525
|
-
await knex.raw(`
|
|
526
|
-
INSERT INTO v4_task_statuses (id, name) VALUES
|
|
527
|
-
(1, 'todo'), (2, 'in_progress'), (3, 'waiting_review'), (4, 'blocked'), (5, 'done'), (6, 'archived'), (7, 'rejected')
|
|
528
|
-
ON CONFLICT (id) DO NOTHING
|
|
525
|
+
await knex.raw(`
|
|
526
|
+
INSERT INTO v4_task_statuses (id, name) VALUES
|
|
527
|
+
(1, 'todo'), (2, 'in_progress'), (3, 'waiting_review'), (4, 'blocked'), (5, 'done'), (6, 'archived'), (7, 'rejected')
|
|
528
|
+
ON CONFLICT (id) DO NOTHING
|
|
529
529
|
`);
|
|
530
530
|
}
|
|
531
531
|
else {
|
|
532
|
-
await knex.raw(`
|
|
533
|
-
INSERT ${insertIgnore} INTO v4_task_statuses (id, name) VALUES
|
|
534
|
-
(1, 'todo'), (2, 'in_progress'), (3, 'waiting_review'), (4, 'blocked'), (5, 'done'), (6, 'archived'), (7, 'rejected')
|
|
532
|
+
await knex.raw(`
|
|
533
|
+
INSERT ${insertIgnore} INTO v4_task_statuses (id, name) VALUES
|
|
534
|
+
(1, 'todo'), (2, 'in_progress'), (3, 'waiting_review'), (4, 'blocked'), (5, 'done'), (6, 'archived'), (7, 'rejected')
|
|
535
535
|
`);
|
|
536
536
|
}
|
|
537
537
|
console.error(' ✓ Task statuses seeded (7)');
|
|
@@ -554,18 +554,18 @@ export async function up(knex) {
|
|
|
554
554
|
const existingTags = await knex('v4_tags').count('* as count').first();
|
|
555
555
|
if (!existingTags || Number(existingTags.count) === 0) {
|
|
556
556
|
if (db.isPostgreSQL) {
|
|
557
|
-
await knex.raw(`
|
|
558
|
-
INSERT INTO v4_tags (project_id, name) VALUES
|
|
559
|
-
(1, 'authentication'), (1, 'authorization'), (1, 'validation'), (1, 'error-handling'),
|
|
560
|
-
(1, 'logging'), (1, 'performance'), (1, 'security'), (1, 'testing')
|
|
561
|
-
ON CONFLICT (project_id, name) DO NOTHING
|
|
557
|
+
await knex.raw(`
|
|
558
|
+
INSERT INTO v4_tags (project_id, name) VALUES
|
|
559
|
+
(1, 'authentication'), (1, 'authorization'), (1, 'validation'), (1, 'error-handling'),
|
|
560
|
+
(1, 'logging'), (1, 'performance'), (1, 'security'), (1, 'testing')
|
|
561
|
+
ON CONFLICT (project_id, name) DO NOTHING
|
|
562
562
|
`);
|
|
563
563
|
}
|
|
564
564
|
else {
|
|
565
|
-
await knex.raw(`
|
|
566
|
-
INSERT ${insertIgnore} INTO v4_tags (project_id, name) VALUES
|
|
567
|
-
(1, 'authentication'), (1, 'authorization'), (1, 'validation'), (1, 'error-handling'),
|
|
568
|
-
(1, 'logging'), (1, 'performance'), (1, 'security'), (1, 'testing')
|
|
565
|
+
await knex.raw(`
|
|
566
|
+
INSERT ${insertIgnore} INTO v4_tags (project_id, name) VALUES
|
|
567
|
+
(1, 'authentication'), (1, 'authorization'), (1, 'validation'), (1, 'error-handling'),
|
|
568
|
+
(1, 'logging'), (1, 'performance'), (1, 'security'), (1, 'testing')
|
|
569
569
|
`);
|
|
570
570
|
}
|
|
571
571
|
console.error(' ✓ Common tags seeded (8)');
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* v4 Seed Missing Help Data Migration
|
|
3
|
+
*
|
|
4
|
+
* Adds missing help system data:
|
|
5
|
+
* - v4_help_action_params for analytics, by_key, by_tags, check_duplicate
|
|
6
|
+
* - v4_help_action_examples (initial examples)
|
|
7
|
+
*
|
|
8
|
+
* This migration supplements the original seed migration with
|
|
9
|
+
* data that was missing in v4.1.1 clean installs.
|
|
10
|
+
*/
|
|
11
|
+
import type { Knex } from 'knex';
|
|
12
|
+
export declare function up(knex: Knex): Promise<void>;
|
|
13
|
+
export declare function down(knex: Knex): Promise<void>;
|
|
14
|
+
//# sourceMappingURL=20251225000000_v4_seed_missing_help_data.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"20251225000000_v4_seed_missing_help_data.d.ts","sourceRoot":"","sources":["../../../../src/database/migrations/v4/20251225000000_v4_seed_missing_help_data.ts"],"names":[],"mappings":"AAAA;;;;;;;;;GASG;AAEH,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,MAAM,CAAC;AAEjC,wBAAsB,EAAE,CAAC,IAAI,EAAE,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC,CA4LlD;AAED,wBAAsB,IAAI,CAAC,IAAI,EAAE,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC,CAiBpD"}
|
|
@@ -0,0 +1,201 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* v4 Seed Missing Help Data Migration
|
|
3
|
+
*
|
|
4
|
+
* Adds missing help system data:
|
|
5
|
+
* - v4_help_action_params for analytics, by_key, by_tags, check_duplicate
|
|
6
|
+
* - v4_help_action_examples (initial examples)
|
|
7
|
+
*
|
|
8
|
+
* This migration supplements the original seed migration with
|
|
9
|
+
* data that was missing in v4.1.1 clean installs.
|
|
10
|
+
*/
|
|
11
|
+
export async function up(knex) {
|
|
12
|
+
console.error('🌱 Seeding missing help system data...');
|
|
13
|
+
// Get action IDs
|
|
14
|
+
const actions = await knex('v4_help_actions').select('id', 'tool_name', 'action_name');
|
|
15
|
+
const actionMap = actions.reduce((map, action) => {
|
|
16
|
+
map[`${action.tool_name}:${action.action_name}`] = action.id;
|
|
17
|
+
return map;
|
|
18
|
+
}, {});
|
|
19
|
+
// 1. Seed missing v4_help_action_params
|
|
20
|
+
const missingParams = [
|
|
21
|
+
// DECISION:ANALYTICS
|
|
22
|
+
{ action_id: actionMap['decision:analytics'], param_name: 'action', param_type: 'string', required: 1, description: 'Must be "analytics"', default_value: null },
|
|
23
|
+
{ action_id: actionMap['decision:analytics'], param_name: 'key_pattern', param_type: 'string', required: 1, description: 'SQL LIKE pattern for decision keys (e.g., "metric/%")', default_value: null },
|
|
24
|
+
{ action_id: actionMap['decision:analytics'], param_name: 'aggregation', param_type: 'string', required: 1, description: 'Aggregation type: avg, sum, max, min, count', default_value: null },
|
|
25
|
+
{ action_id: actionMap['decision:analytics'], param_name: 'layer', param_type: 'string', required: 0, description: 'Filter by layer', default_value: null },
|
|
26
|
+
{ action_id: actionMap['decision:analytics'], param_name: 'time_series', param_type: 'object', required: 0, description: 'Time series options: { bucket, start_ts, end_ts }', default_value: null },
|
|
27
|
+
{ action_id: actionMap['decision:analytics'], param_name: 'percentiles', param_type: 'number[]', required: 0, description: 'Percentiles to calculate (e.g., [50, 90, 95, 99])', default_value: null },
|
|
28
|
+
// SUGGEST:BY_KEY
|
|
29
|
+
{ action_id: actionMap['suggest:by_key'], param_name: 'action', param_type: 'string', required: 1, description: 'Must be "by_key"', default_value: null },
|
|
30
|
+
{ action_id: actionMap['suggest:by_key'], param_name: 'key', param_type: 'string', required: 1, description: 'Decision key pattern to search', default_value: null },
|
|
31
|
+
{ action_id: actionMap['suggest:by_key'], param_name: 'limit', param_type: 'number', required: 0, description: 'Max suggestions', default_value: '5' },
|
|
32
|
+
{ action_id: actionMap['suggest:by_key'], param_name: 'min_score', param_type: 'number', required: 0, description: 'Minimum relevance score', default_value: '30' },
|
|
33
|
+
// SUGGEST:BY_TAGS
|
|
34
|
+
{ action_id: actionMap['suggest:by_tags'], param_name: 'action', param_type: 'string', required: 1, description: 'Must be "by_tags"', default_value: null },
|
|
35
|
+
{ action_id: actionMap['suggest:by_tags'], param_name: 'tags', param_type: 'string[]', required: 1, description: 'Tags to search for', default_value: null },
|
|
36
|
+
{ action_id: actionMap['suggest:by_tags'], param_name: 'layer', param_type: 'string', required: 0, description: 'Filter by layer', default_value: null },
|
|
37
|
+
{ action_id: actionMap['suggest:by_tags'], param_name: 'limit', param_type: 'number', required: 0, description: 'Max suggestions', default_value: '5' },
|
|
38
|
+
{ action_id: actionMap['suggest:by_tags'], param_name: 'min_score', param_type: 'number', required: 0, description: 'Minimum relevance score', default_value: '15' },
|
|
39
|
+
// SUGGEST:CHECK_DUPLICATE
|
|
40
|
+
{ action_id: actionMap['suggest:check_duplicate'], param_name: 'action', param_type: 'string', required: 1, description: 'Must be "check_duplicate"', default_value: null },
|
|
41
|
+
{ action_id: actionMap['suggest:check_duplicate'], param_name: 'key', param_type: 'string', required: 1, description: 'Decision key to check', default_value: null },
|
|
42
|
+
{ action_id: actionMap['suggest:check_duplicate'], param_name: 'tags', param_type: 'string[]', required: 0, description: 'Tags for context matching', default_value: '[]' },
|
|
43
|
+
{ action_id: actionMap['suggest:check_duplicate'], param_name: 'layer', param_type: 'string', required: 0, description: 'Layer for context matching', default_value: null },
|
|
44
|
+
].filter(p => p.action_id);
|
|
45
|
+
if (missingParams.length > 0) {
|
|
46
|
+
// Check for existing params to avoid duplicates
|
|
47
|
+
for (const param of missingParams) {
|
|
48
|
+
const exists = await knex('v4_help_action_params')
|
|
49
|
+
.where({ action_id: param.action_id, param_name: param.param_name })
|
|
50
|
+
.first();
|
|
51
|
+
if (!exists) {
|
|
52
|
+
await knex('v4_help_action_params').insert(param);
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
console.error(` ✓ Missing help action params seeded`);
|
|
56
|
+
}
|
|
57
|
+
// 2. Seed v4_help_action_examples
|
|
58
|
+
const existingExamples = await knex('v4_help_action_examples').count('* as count').first();
|
|
59
|
+
if (!existingExamples || Number(existingExamples.count) === 0) {
|
|
60
|
+
const examples = [
|
|
61
|
+
// DECISION:SET examples
|
|
62
|
+
{
|
|
63
|
+
action_id: actionMap['decision:set'],
|
|
64
|
+
title: 'Basic decision',
|
|
65
|
+
code: JSON.stringify({
|
|
66
|
+
action: 'set',
|
|
67
|
+
key: 'auth/method',
|
|
68
|
+
value: 'JWT tokens with refresh',
|
|
69
|
+
tags: ['security', 'auth'],
|
|
70
|
+
layer: 'infrastructure'
|
|
71
|
+
}, null, 2),
|
|
72
|
+
explanation: 'Store a simple architectural decision with tags and layer'
|
|
73
|
+
},
|
|
74
|
+
{
|
|
75
|
+
action_id: actionMap['decision:set'],
|
|
76
|
+
title: 'Decision with context',
|
|
77
|
+
code: JSON.stringify({
|
|
78
|
+
action: 'set',
|
|
79
|
+
key: 'database/orm',
|
|
80
|
+
value: 'Prisma',
|
|
81
|
+
tags: ['database', 'orm'],
|
|
82
|
+
layer: 'data',
|
|
83
|
+
rationale: 'Type safety and migration support',
|
|
84
|
+
alternatives: 'TypeORM, Knex, raw SQL',
|
|
85
|
+
tradeoffs: 'Learning curve, but better DX'
|
|
86
|
+
}, null, 2),
|
|
87
|
+
explanation: 'Store a decision with full context (rationale, alternatives, tradeoffs)'
|
|
88
|
+
},
|
|
89
|
+
// DECISION:LIST examples
|
|
90
|
+
{
|
|
91
|
+
action_id: actionMap['decision:list'],
|
|
92
|
+
title: 'List all decisions',
|
|
93
|
+
code: JSON.stringify({
|
|
94
|
+
action: 'list'
|
|
95
|
+
}, null, 2),
|
|
96
|
+
explanation: 'Get all active decisions'
|
|
97
|
+
},
|
|
98
|
+
{
|
|
99
|
+
action_id: actionMap['decision:list'],
|
|
100
|
+
title: 'Filter by layer',
|
|
101
|
+
code: JSON.stringify({
|
|
102
|
+
action: 'list',
|
|
103
|
+
layer: 'infrastructure',
|
|
104
|
+
limit: 10
|
|
105
|
+
}, null, 2),
|
|
106
|
+
explanation: 'List decisions filtered by architecture layer'
|
|
107
|
+
},
|
|
108
|
+
// SUGGEST:BY_KEY examples
|
|
109
|
+
{
|
|
110
|
+
action_id: actionMap['suggest:by_key'],
|
|
111
|
+
title: 'Find similar by key',
|
|
112
|
+
code: JSON.stringify({
|
|
113
|
+
action: 'by_key',
|
|
114
|
+
key: 'auth'
|
|
115
|
+
}, null, 2),
|
|
116
|
+
explanation: 'Find decisions with keys similar to "auth" (e.g., auth/method, auth/provider)'
|
|
117
|
+
},
|
|
118
|
+
// SUGGEST:BY_TAGS examples
|
|
119
|
+
{
|
|
120
|
+
action_id: actionMap['suggest:by_tags'],
|
|
121
|
+
title: 'Find by tags',
|
|
122
|
+
code: JSON.stringify({
|
|
123
|
+
action: 'by_tags',
|
|
124
|
+
tags: ['security', 'auth']
|
|
125
|
+
}, null, 2),
|
|
126
|
+
explanation: 'Find decisions tagged with security or auth'
|
|
127
|
+
},
|
|
128
|
+
// DECISION:ANALYTICS examples
|
|
129
|
+
{
|
|
130
|
+
action_id: actionMap['decision:analytics'],
|
|
131
|
+
title: 'Count decisions',
|
|
132
|
+
code: JSON.stringify({
|
|
133
|
+
action: 'analytics',
|
|
134
|
+
key_pattern: '%',
|
|
135
|
+
aggregation: 'count'
|
|
136
|
+
}, null, 2),
|
|
137
|
+
explanation: 'Count all decisions in the database'
|
|
138
|
+
},
|
|
139
|
+
{
|
|
140
|
+
action_id: actionMap['decision:analytics'],
|
|
141
|
+
title: 'Average metric value',
|
|
142
|
+
code: JSON.stringify({
|
|
143
|
+
action: 'analytics',
|
|
144
|
+
key_pattern: 'metric/api-latency/%',
|
|
145
|
+
aggregation: 'avg',
|
|
146
|
+
layer: 'infrastructure'
|
|
147
|
+
}, null, 2),
|
|
148
|
+
explanation: 'Calculate average of numeric decisions matching pattern'
|
|
149
|
+
},
|
|
150
|
+
// TASK:CREATE examples
|
|
151
|
+
{
|
|
152
|
+
action_id: actionMap['task:create'],
|
|
153
|
+
title: 'Create simple task',
|
|
154
|
+
code: JSON.stringify({
|
|
155
|
+
action: 'create',
|
|
156
|
+
title: 'Implement user authentication',
|
|
157
|
+
priority: 3,
|
|
158
|
+
layer: 'business'
|
|
159
|
+
}, null, 2),
|
|
160
|
+
explanation: 'Create a high-priority task in the business layer'
|
|
161
|
+
},
|
|
162
|
+
// CONSTRAINT:ADD examples
|
|
163
|
+
{
|
|
164
|
+
action_id: actionMap['constraint:add'],
|
|
165
|
+
title: 'Add architectural constraint',
|
|
166
|
+
code: JSON.stringify({
|
|
167
|
+
action: 'add',
|
|
168
|
+
constraint_text: 'All API endpoints must validate input',
|
|
169
|
+
category: 'security',
|
|
170
|
+
priority: 3,
|
|
171
|
+
layer: 'infrastructure'
|
|
172
|
+
}, null, 2),
|
|
173
|
+
explanation: 'Add a security constraint to enforce input validation'
|
|
174
|
+
}
|
|
175
|
+
].filter(e => e.action_id);
|
|
176
|
+
if (examples.length > 0) {
|
|
177
|
+
await knex('v4_help_action_examples').insert(examples);
|
|
178
|
+
console.error(` ✓ Help action examples seeded (${examples.length})`);
|
|
179
|
+
}
|
|
180
|
+
}
|
|
181
|
+
else {
|
|
182
|
+
console.error(' ℹ Help action examples already exist, skipping');
|
|
183
|
+
}
|
|
184
|
+
console.error('🎉 Missing help system data seeded!');
|
|
185
|
+
}
|
|
186
|
+
export async function down(knex) {
|
|
187
|
+
// Remove examples added by this migration
|
|
188
|
+
await knex('v4_help_action_examples').del();
|
|
189
|
+
// Remove params added by this migration (analytics, by_key, by_tags, check_duplicate)
|
|
190
|
+
const actions = await knex('v4_help_actions')
|
|
191
|
+
.whereIn('action_name', ['analytics', 'by_key', 'by_tags', 'check_duplicate'])
|
|
192
|
+
.select('id');
|
|
193
|
+
const actionIds = actions.map(a => a.id);
|
|
194
|
+
if (actionIds.length > 0) {
|
|
195
|
+
await knex('v4_help_action_params')
|
|
196
|
+
.whereIn('action_id', actionIds)
|
|
197
|
+
.del();
|
|
198
|
+
}
|
|
199
|
+
console.error('🗑️ Missing help system data removed');
|
|
200
|
+
}
|
|
201
|
+
//# sourceMappingURL=20251225000000_v4_seed_missing_help_data.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"20251225000000_v4_seed_missing_help_data.js","sourceRoot":"","sources":["../../../../src/database/migrations/v4/20251225000000_v4_seed_missing_help_data.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* v4 Fix Help Params Migration
|
|
3
|
+
*
|
|
4
|
+
* Fixes incorrect parameter descriptions in the help system:
|
|
5
|
+
* - constraint:add priority: "Priority: 1-4" → "Priority level: low, medium, high, critical"
|
|
6
|
+
*
|
|
7
|
+
* NOTE: file:record agent_name is not in DB (handled in code only)
|
|
8
|
+
*/
|
|
9
|
+
import type { Knex } from 'knex';
|
|
10
|
+
export declare function up(knex: Knex): Promise<void>;
|
|
11
|
+
export declare function down(knex: Knex): Promise<void>;
|
|
12
|
+
//# sourceMappingURL=20251225000001_v4_fix_help_params.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"20251225000001_v4_fix_help_params.d.ts","sourceRoot":"","sources":["../../../../src/database/migrations/v4/20251225000001_v4_fix_help_params.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAEH,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,MAAM,CAAC;AAEjC,wBAAsB,EAAE,CAAC,IAAI,EAAE,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC,CAgClD;AAED,wBAAsB,IAAI,CAAC,IAAI,EAAE,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC,CAsBpD"}
|
|
@@ -0,0 +1,61 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* v4 Fix Help Params Migration
|
|
3
|
+
*
|
|
4
|
+
* Fixes incorrect parameter descriptions in the help system:
|
|
5
|
+
* - constraint:add priority: "Priority: 1-4" → "Priority level: low, medium, high, critical"
|
|
6
|
+
*
|
|
7
|
+
* NOTE: file:record agent_name is not in DB (handled in code only)
|
|
8
|
+
*/
|
|
9
|
+
export async function up(knex) {
|
|
10
|
+
console.error('🔧 Fixing help parameter descriptions...');
|
|
11
|
+
// Get constraint:add action ID
|
|
12
|
+
const constraintAddAction = await knex('v4_help_actions')
|
|
13
|
+
.where({ tool_name: 'constraint', action_name: 'add' })
|
|
14
|
+
.select('id')
|
|
15
|
+
.first();
|
|
16
|
+
if (constraintAddAction) {
|
|
17
|
+
// Fix priority description: "Priority: 1-4" → "Priority level: low, medium, high, critical"
|
|
18
|
+
const updated = await knex('v4_help_action_params')
|
|
19
|
+
.where({
|
|
20
|
+
action_id: constraintAddAction.id,
|
|
21
|
+
param_name: 'priority'
|
|
22
|
+
})
|
|
23
|
+
.update({
|
|
24
|
+
param_type: 'string',
|
|
25
|
+
description: 'Priority level: low, medium, high, critical',
|
|
26
|
+
default_value: 'medium'
|
|
27
|
+
});
|
|
28
|
+
if (updated > 0) {
|
|
29
|
+
console.error(' ✓ Fixed constraint:add priority parameter');
|
|
30
|
+
}
|
|
31
|
+
else {
|
|
32
|
+
console.error(' ℹ constraint:add priority parameter not found (may not exist)');
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
else {
|
|
36
|
+
console.error(' ⚠ constraint:add action not found');
|
|
37
|
+
}
|
|
38
|
+
console.error('🎉 Help parameter descriptions fixed!');
|
|
39
|
+
}
|
|
40
|
+
export async function down(knex) {
|
|
41
|
+
// Get constraint:add action ID
|
|
42
|
+
const constraintAddAction = await knex('v4_help_actions')
|
|
43
|
+
.where({ tool_name: 'constraint', action_name: 'add' })
|
|
44
|
+
.select('id')
|
|
45
|
+
.first();
|
|
46
|
+
if (constraintAddAction) {
|
|
47
|
+
// Revert to original values
|
|
48
|
+
await knex('v4_help_action_params')
|
|
49
|
+
.where({
|
|
50
|
+
action_id: constraintAddAction.id,
|
|
51
|
+
param_name: 'priority'
|
|
52
|
+
})
|
|
53
|
+
.update({
|
|
54
|
+
param_type: 'number',
|
|
55
|
+
description: 'Priority: 1-4',
|
|
56
|
+
default_value: '2'
|
|
57
|
+
});
|
|
58
|
+
}
|
|
59
|
+
console.error('🗑️ Help parameter descriptions reverted');
|
|
60
|
+
}
|
|
61
|
+
//# sourceMappingURL=20251225000001_v4_fix_help_params.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"20251225000001_v4_fix_help_params.js","sourceRoot":"","sources":["../../../../src/database/migrations/v4/20251225000001_v4_fix_help_params.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAIH,MAAM,CAAC,KAAK,UAAU,EAAE,CAAC,IAAU;IACjC,OAAO,CAAC,KAAK,CAAC,0CAA0C,CAAC,CAAC;IAE1D,+BAA+B;IAC/B,MAAM,mBAAmB,GAAG,MAAM,IAAI,CAAC,iBAAiB,CAAC;SACtD,KAAK,CAAC,EAAE,SAAS,EAAE,YAAY,EAAE,WAAW,EAAE,KAAK,EAAE,CAAC;SACtD,MAAM,CAAC,IAAI,CAAC;SACZ,KAAK,EAAE,CAAC;IAEX,IAAI,mBAAmB,EAAE,CAAC;QACxB,4FAA4F;QAC5F,MAAM,OAAO,GAAG,MAAM,IAAI,CAAC,uBAAuB,CAAC;aAChD,KAAK,CAAC;YACL,SAAS,EAAE,mBAAmB,CAAC,EAAE;YACjC,UAAU,EAAE,UAAU;SACvB,CAAC;aACD,MAAM,CAAC;YACN,UAAU,EAAE,QAAQ;YACpB,WAAW,EAAE,6CAA6C;YAC1D,aAAa,EAAE,QAAQ;SACxB,CAAC,CAAC;QAEL,IAAI,OAAO,GAAG,CAAC,EAAE,CAAC;YAChB,OAAO,CAAC,KAAK,CAAC,6CAA6C,CAAC,CAAC;QAC/D,CAAC;aAAM,CAAC;YACN,OAAO,CAAC,KAAK,CAAC,iEAAiE,CAAC,CAAC;QACnF,CAAC;IACH,CAAC;SAAM,CAAC;QACN,OAAO,CAAC,KAAK,CAAC,qCAAqC,CAAC,CAAC;IACvD,CAAC;IAED,OAAO,CAAC,KAAK,CAAC,uCAAuC,CAAC,CAAC;AACzD,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,IAAI,CAAC,IAAU;IACnC,+BAA+B;IAC/B,MAAM,mBAAmB,GAAG,MAAM,IAAI,CAAC,iBAAiB,CAAC;SACtD,KAAK,CAAC,EAAE,SAAS,EAAE,YAAY,EAAE,WAAW,EAAE,KAAK,EAAE,CAAC;SACtD,MAAM,CAAC,IAAI,CAAC;SACZ,KAAK,EAAE,CAAC;IAEX,IAAI,mBAAmB,EAAE,CAAC;QACxB,4BAA4B;QAC5B,MAAM,IAAI,CAAC,uBAAuB,CAAC;aAChC,KAAK,CAAC;YACL,SAAS,EAAE,mBAAmB,CAAC,EAAE;YACjC,UAAU,EAAE,UAAU;SACvB,CAAC;aACD,MAAM,CAAC;YACN,UAAU,EAAE,QAAQ;YACpB,WAAW,EAAE,eAAe;YAC5B,aAAa,EAAE,GAAG;SACnB,CAAC,CAAC;IACP,CAAC;IAED,OAAO,CAAC,KAAK,CAAC,0CAA0C,CAAC,CAAC;AAC5D,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"setup.d.ts","sourceRoot":"","sources":["../../src/server/setup.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;GAWG;AAIH,OAAO,EAAE,eAAe,EAAgE,MAAM,gBAAgB,CAAC;AAG/G,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,oBAAoB,CAAC;AAEtD,OAAO,EAAE,cAAc,EAAE,MAAM,6BAA6B,CAAC;AAO7D,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAC;
|
|
1
|
+
{"version":3,"file":"setup.d.ts","sourceRoot":"","sources":["../../src/server/setup.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;GAWG;AAIH,OAAO,EAAE,eAAe,EAAgE,MAAM,gBAAgB,CAAC;AAG/G,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,oBAAoB,CAAC;AAEtD,OAAO,EAAE,cAAc,EAAE,MAAM,6BAA6B,CAAC;AAO7D,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAC;AAkI7C,MAAM,WAAW,WAAW;IAC1B,EAAE,EAAE,eAAe,CAAC;IACpB,UAAU,EAAE,WAAW,CAAC;IACxB,WAAW,EAAE,MAAM,CAAC;IACpB,cAAc,EAAE,cAAc,CAAC;IAC/B,YAAY,EAAE;QACZ,aAAa,EAAE,OAAO,CAAC;QACvB,YAAY,EAAE,MAAM,CAAC;QACrB,eAAe,EAAE,MAAM,CAAC;KACzB,CAAC;IACF,eAAe,EAAE,KAAK,GAAG,QAAQ,GAAG,KAAK,GAAG,UAAU,GAAG,WAAW,CAAC;CACtE;AAED;;;GAGG;AACH,wBAAsB,gBAAgB,CAAC,UAAU,EAAE,UAAU,GAAG,OAAO,CAAC,WAAW,CAAC,CAsNnF;AAED;;;GAGG;AACH,wBAAsB,gBAAgB,IAAI,OAAO,CAAC,IAAI,CAAC,CAGtD"}
|
package/dist/server/setup.js
CHANGED
|
@@ -25,6 +25,30 @@ import { ensureSqlewDirectory } from '../config/example-generator.js';
|
|
|
25
25
|
import { determineProjectRoot } from '../utils/project-root.js';
|
|
26
26
|
import { initializeSqlewIntegrations } from '../init-skills.js';
|
|
27
27
|
import { loadGlobalConfig } from '../config/global-config.js';
|
|
28
|
+
/**
|
|
29
|
+
* Extract project name from a path, skipping hidden directories.
|
|
30
|
+
*
|
|
31
|
+
* This handles cases where --db-path points to ~/.sqlew/sqlew.db
|
|
32
|
+
* and we want to use the parent directory name (e.g., 'kitayama')
|
|
33
|
+
* instead of '.sqlew'.
|
|
34
|
+
*
|
|
35
|
+
* @param projectPath - Absolute path to extract project name from
|
|
36
|
+
* @returns Project name (non-hidden directory name)
|
|
37
|
+
*/
|
|
38
|
+
function extractProjectNameFromPath(projectPath) {
|
|
39
|
+
// Split by forward slash (paths are normalized to forward slashes)
|
|
40
|
+
const dirSegments = projectPath.split('/').filter(s => s.length > 0);
|
|
41
|
+
// Find the first non-hidden directory name from the end
|
|
42
|
+
// Skip directories starting with '.' (e.g., .sqlew, .git)
|
|
43
|
+
for (let i = dirSegments.length - 1; i >= 0; i--) {
|
|
44
|
+
const segment = dirSegments[i];
|
|
45
|
+
if (segment && !segment.startsWith('.')) {
|
|
46
|
+
return segment;
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
// Fallback to 'default' if all segments are hidden
|
|
50
|
+
return 'default';
|
|
51
|
+
}
|
|
28
52
|
/**
|
|
29
53
|
* Load config with priority order (v4.1.0+):
|
|
30
54
|
* 1. Main repo config (worktree parent)
|
|
@@ -231,17 +255,15 @@ export async function initializeServer(parsedArgs) {
|
|
|
231
255
|
debugLog('INFO', 'Project name detected from VCS', { projectName, vcs: vcsAdapter.getVCSType() });
|
|
232
256
|
}
|
|
233
257
|
else {
|
|
234
|
-
// Fallback to directory name
|
|
235
|
-
|
|
236
|
-
projectName = dirSegments[dirSegments.length - 1] || 'default';
|
|
258
|
+
// Fallback to directory name (skip hidden directories like .sqlew)
|
|
259
|
+
projectName = extractProjectNameFromPath(finalProjectRoot);
|
|
237
260
|
detectionSource = 'directory';
|
|
238
261
|
debugLog('INFO', 'Project name from directory', { projectName });
|
|
239
262
|
}
|
|
240
263
|
}
|
|
241
264
|
else {
|
|
242
|
-
// No VCS detected, use directory name
|
|
243
|
-
|
|
244
|
-
projectName = dirSegments[dirSegments.length - 1] || 'default';
|
|
265
|
+
// No VCS detected, use directory name (skip hidden directories like .sqlew)
|
|
266
|
+
projectName = extractProjectNameFromPath(finalProjectRoot);
|
|
245
267
|
detectionSource = 'directory';
|
|
246
268
|
debugLog('INFO', 'Project name from directory (no VCS)', { projectName });
|
|
247
269
|
}
|
package/dist/server/setup.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"setup.js","sourceRoot":"","sources":["../../src/server/setup.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;GAWG;AAEH,OAAO,EAAE,UAAU,EAAE,MAAM,IAAI,CAAC;AAChC,OAAO,EAAE,OAAO,EAAE,UAAU,EAAE,MAAM,MAAM,CAAC;AAC3C,OAAO,EAAmB,kBAAkB,EAAE,cAAc,EAAE,YAAY,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAC;AAC/G,OAAO,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAC;AAC9C,OAAO,EAAE,cAAc,EAAE,mBAAmB,EAAE,MAAM,qBAAqB,CAAC;AAE1E,OAAO,EAAE,mBAAmB,EAAE,MAAM,qBAAqB,CAAC;AAC1D,OAAO,EAAE,cAAc,EAAE,MAAM,6BAA6B,CAAC;AAC7D,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,MAAM,yBAAyB,CAAC;AAChE,OAAO,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AAClD,OAAO,EAAE,iBAAiB,EAAE,MAAM,6BAA6B,CAAC;AAChE,OAAO,EAAE,eAAe,EAAE,QAAQ,EAAE,MAAM,0BAA0B,CAAC;AACrE,OAAO,EAAE,oBAAoB,EAAE,MAAM,gCAAgC,CAAC;AACtE,OAAO,EAAE,oBAAoB,EAAE,MAAM,0BAA0B,CAAC;AAEhE,OAAO,EAAE,2BAA2B,EAAE,MAAM,mBAAmB,CAAC;AAChE,OAAO,EAAE,gBAAgB,EAAE,MAAM,4BAA4B,CAAC;
|
|
1
|
+
{"version":3,"file":"setup.js","sourceRoot":"","sources":["../../src/server/setup.ts"],"names":[],"mappings":"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"}
|
|
@@ -23,13 +23,18 @@
|
|
|
23
23
|
* - SQLite integration tests: Test FK extraction from real schema
|
|
24
24
|
* - End-to-end test: Validate with full production schema (requires maintenance)
|
|
25
25
|
*/
|
|
26
|
-
import { describe, it } from 'node:test';
|
|
26
|
+
import { describe, it, before } from 'node:test';
|
|
27
27
|
import assert from 'node:assert';
|
|
28
|
+
import { mkdirSync } from 'node:fs';
|
|
28
29
|
import { getTableDependencies, topologicalSort } from '../../../utils/sql-dump/index.js';
|
|
29
30
|
import { connectDb, disconnectDb, getDbConfig } from '../../utils/test-helpers.js';
|
|
30
31
|
describe('Topological Sort Unit Tests', () => {
|
|
31
32
|
// Generate unique database path for this test suite to avoid conflicts
|
|
32
33
|
const TEST_DB_PATH = `.tmp-test/table-ordering-${Date.now()}.db`;
|
|
34
|
+
// Ensure test directory exists
|
|
35
|
+
before(() => {
|
|
36
|
+
mkdirSync('.tmp-test', { recursive: true });
|
|
37
|
+
});
|
|
33
38
|
describe('topologicalSort() - Pure Algorithm Tests', () => {
|
|
34
39
|
it('should handle empty table list', () => {
|
|
35
40
|
const tables = [];
|