@x12i/catalox 3.1.1 → 3.3.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 +6 -1
- package/dist/src/catalox/backup-data.d.ts +1 -6
- package/dist/src/catalox/backup-data.d.ts.map +1 -1
- package/dist/src/catalox/backup-data.js +71 -418
- package/dist/src/catalox/backup-data.js.map +1 -1
- package/dist/src/catalox/catalox-bound.d.ts +1 -2
- package/dist/src/catalox/catalox-bound.d.ts.map +1 -1
- package/dist/src/catalox/catalox-bound.js +0 -3
- package/dist/src/catalox/catalox-bound.js.map +1 -1
- package/dist/src/catalox/catalox.d.ts +2 -7
- package/dist/src/catalox/catalox.d.ts.map +1 -1
- package/dist/src/catalox/catalox.js +2 -16
- package/dist/src/catalox/catalox.js.map +1 -1
- package/dist/src/catalox/create-catalox.d.ts.map +1 -1
- package/dist/src/catalox/create-catalox.js +4 -1
- package/dist/src/catalox/create-catalox.js.map +1 -1
- package/dist/src/catalox/index.d.ts +2 -2
- package/dist/src/catalox/index.d.ts.map +1 -1
- package/dist/src/catalox/index.js +2 -2
- package/dist/src/catalox/index.js.map +1 -1
- package/dist/src/catalox/record-history.d.ts.map +1 -1
- package/dist/src/catalox/record-history.js +34 -0
- package/dist/src/catalox/record-history.js.map +1 -1
- package/dist/src/catalox/restore-firestore-backup.d.ts +6 -3
- package/dist/src/catalox/restore-firestore-backup.d.ts.map +1 -1
- package/dist/src/catalox/restore-firestore-backup.js +3 -224
- package/dist/src/catalox/restore-firestore-backup.js.map +1 -1
- package/dist/src/cli/index.js +27 -66
- package/dist/src/cli/index.js.map +1 -1
- package/dist/src/contracts/backup.d.ts +2 -2
- package/dist/src/contracts/backup.d.ts.map +1 -1
- package/dist/src/contracts/index.d.ts +1 -1
- package/dist/src/contracts/index.d.ts.map +1 -1
- package/dist/src/contracts/index.js.map +1 -1
- package/dist/src/contracts/restore.d.ts +0 -39
- package/dist/src/contracts/restore.d.ts.map +1 -1
- package/dist/src/firebase/catalog-item-history-store.d.ts.map +1 -1
- package/dist/src/firebase/catalog-item-history-store.js +35 -6
- package/dist/src/firebase/catalog-item-history-store.js.map +1 -1
- package/package.json +6 -3
- package/dist/adapters/api/api-adapter.d.ts +0 -22
- package/dist/adapters/api/api-adapter.d.ts.map +0 -1
- package/dist/adapters/api/api-adapter.js +0 -60
- package/dist/adapters/api/api-adapter.js.map +0 -1
- package/dist/adapters/api/index.d.ts +0 -2
- package/dist/adapters/api/index.d.ts.map +0 -1
- package/dist/adapters/api/index.js +0 -2
- package/dist/adapters/api/index.js.map +0 -1
- package/dist/adapters/mongo/index.d.ts +0 -3
- package/dist/adapters/mongo/index.d.ts.map +0 -1
- package/dist/adapters/mongo/index.js +0 -3
- package/dist/adapters/mongo/index.js.map +0 -1
- package/dist/adapters/mongo/mongo-adapter.d.ts +0 -21
- package/dist/adapters/mongo/mongo-adapter.d.ts.map +0 -1
- package/dist/adapters/mongo/mongo-adapter.js +0 -57
- package/dist/adapters/mongo/mongo-adapter.js.map +0 -1
- package/dist/adapters/mongo/resolve-db.d.ts +0 -4
- package/dist/adapters/mongo/resolve-db.d.ts.map +0 -1
- package/dist/adapters/mongo/resolve-db.js +0 -10
- package/dist/adapters/mongo/resolve-db.js.map +0 -1
- package/dist/bindings/index.d.ts +0 -2
- package/dist/bindings/index.d.ts.map +0 -1
- package/dist/bindings/index.js +0 -3
- package/dist/bindings/index.js.map +0 -1
- package/dist/catalox/authorization.d.ts +0 -11
- package/dist/catalox/authorization.d.ts.map +0 -1
- package/dist/catalox/authorization.js +0 -37
- package/dist/catalox/authorization.js.map +0 -1
- package/dist/catalox/catalox.d.ts +0 -80
- package/dist/catalox/catalox.d.ts.map +0 -1
- package/dist/catalox/catalox.js +0 -492
- package/dist/catalox/catalox.js.map +0 -1
- package/dist/catalox/context.d.ts +0 -17
- package/dist/catalox/context.d.ts.map +0 -1
- package/dist/catalox/context.js +0 -21
- package/dist/catalox/context.js.map +0 -1
- package/dist/catalox/identity.d.ts +0 -7
- package/dist/catalox/identity.d.ts.map +0 -1
- package/dist/catalox/identity.js +0 -26
- package/dist/catalox/identity.js.map +0 -1
- package/dist/catalox/index.d.ts +0 -6
- package/dist/catalox/index.d.ts.map +0 -1
- package/dist/catalox/index.js +0 -6
- package/dist/catalox/index.js.map +0 -1
- package/dist/catalox/json-io.d.ts +0 -3
- package/dist/catalox/json-io.d.ts.map +0 -1
- package/dist/catalox/json-io.js +0 -7
- package/dist/catalox/json-io.js.map +0 -1
- package/dist/contracts/adapters.d.ts +0 -40
- package/dist/contracts/adapters.d.ts.map +0 -1
- package/dist/contracts/adapters.js +0 -2
- package/dist/contracts/adapters.js.map +0 -1
- package/dist/contracts/apps.d.ts +0 -11
- package/dist/contracts/apps.d.ts.map +0 -1
- package/dist/contracts/apps.js +0 -2
- package/dist/contracts/apps.js.map +0 -1
- package/dist/contracts/bindings.d.ts +0 -26
- package/dist/contracts/bindings.d.ts.map +0 -1
- package/dist/contracts/bindings.js +0 -2
- package/dist/contracts/bindings.js.map +0 -1
- package/dist/contracts/bootstrap.d.ts +0 -7
- package/dist/contracts/bootstrap.d.ts.map +0 -1
- package/dist/contracts/bootstrap.js +0 -2
- package/dist/contracts/bootstrap.js.map +0 -1
- package/dist/contracts/catalogs.d.ts +0 -51
- package/dist/contracts/catalogs.d.ts.map +0 -1
- package/dist/contracts/catalogs.js +0 -2
- package/dist/contracts/catalogs.js.map +0 -1
- package/dist/contracts/config.d.ts +0 -14
- package/dist/contracts/config.d.ts.map +0 -1
- package/dist/contracts/config.js +0 -2
- package/dist/contracts/config.js.map +0 -1
- package/dist/contracts/context.d.ts +0 -11
- package/dist/contracts/context.d.ts.map +0 -1
- package/dist/contracts/context.js +0 -2
- package/dist/contracts/context.js.map +0 -1
- package/dist/contracts/descriptors.d.ts +0 -73
- package/dist/contracts/descriptors.d.ts.map +0 -1
- package/dist/contracts/descriptors.js +0 -2
- package/dist/contracts/descriptors.js.map +0 -1
- package/dist/contracts/discovery.d.ts +0 -25
- package/dist/contracts/discovery.d.ts.map +0 -1
- package/dist/contracts/discovery.js +0 -2
- package/dist/contracts/discovery.js.map +0 -1
- package/dist/contracts/errors.d.ts +0 -32
- package/dist/contracts/errors.d.ts.map +0 -1
- package/dist/contracts/errors.js +0 -53
- package/dist/contracts/errors.js.map +0 -1
- package/dist/contracts/ids.d.ts +0 -7
- package/dist/contracts/ids.d.ts.map +0 -1
- package/dist/contracts/ids.js +0 -2
- package/dist/contracts/ids.js.map +0 -1
- package/dist/contracts/index.d.ts +0 -21
- package/dist/contracts/index.d.ts.map +0 -1
- package/dist/contracts/index.js +0 -2
- package/dist/contracts/index.js.map +0 -1
- package/dist/contracts/inputs.d.ts +0 -19
- package/dist/contracts/inputs.d.ts.map +0 -1
- package/dist/contracts/inputs.js +0 -2
- package/dist/contracts/inputs.js.map +0 -1
- package/dist/contracts/item-validation.d.ts +0 -11
- package/dist/contracts/item-validation.d.ts.map +0 -1
- package/dist/contracts/item-validation.js +0 -2
- package/dist/contracts/item-validation.js.map +0 -1
- package/dist/contracts/items.d.ts +0 -49
- package/dist/contracts/items.d.ts.map +0 -1
- package/dist/contracts/items.js +0 -2
- package/dist/contracts/items.js.map +0 -1
- package/dist/contracts/mappings.d.ts +0 -35
- package/dist/contracts/mappings.d.ts.map +0 -1
- package/dist/contracts/mappings.js +0 -2
- package/dist/contracts/mappings.js.map +0 -1
- package/dist/contracts/query.d.ts +0 -10
- package/dist/contracts/query.d.ts.map +0 -1
- package/dist/contracts/query.js +0 -2
- package/dist/contracts/query.js.map +0 -1
- package/dist/contracts/references.d.ts +0 -11
- package/dist/contracts/references.d.ts.map +0 -1
- package/dist/contracts/references.js +0 -2
- package/dist/contracts/references.js.map +0 -1
- package/dist/contracts/sync.d.ts +0 -7
- package/dist/contracts/sync.d.ts.map +0 -1
- package/dist/contracts/sync.js +0 -2
- package/dist/contracts/sync.js.map +0 -1
- package/dist/contracts/validation.d.ts +0 -12
- package/dist/contracts/validation.d.ts.map +0 -1
- package/dist/contracts/validation.js +0 -2
- package/dist/contracts/validation.js.map +0 -1
- package/dist/errors/index.d.ts +0 -2
- package/dist/errors/index.d.ts.map +0 -1
- package/dist/errors/index.js +0 -3
- package/dist/errors/index.js.map +0 -1
- package/dist/firebase/adapter-store.d.ts +0 -15
- package/dist/firebase/adapter-store.d.ts.map +0 -1
- package/dist/firebase/adapter-store.js +0 -18
- package/dist/firebase/adapter-store.js.map +0 -1
- package/dist/firebase/app-store.d.ts +0 -11
- package/dist/firebase/app-store.d.ts.map +0 -1
- package/dist/firebase/app-store.js +0 -18
- package/dist/firebase/app-store.js.map +0 -1
- package/dist/firebase/binding-store.d.ts +0 -13
- package/dist/firebase/binding-store.d.ts.map +0 -1
- package/dist/firebase/binding-store.js +0 -35
- package/dist/firebase/binding-store.js.map +0 -1
- package/dist/firebase/catalog-store.d.ts +0 -12
- package/dist/firebase/catalog-store.d.ts.map +0 -1
- package/dist/firebase/catalog-store.js +0 -22
- package/dist/firebase/catalog-store.js.map +0 -1
- package/dist/firebase/definition-store.d.ts +0 -39
- package/dist/firebase/definition-store.d.ts.map +0 -1
- package/dist/firebase/definition-store.js +0 -18
- package/dist/firebase/definition-store.js.map +0 -1
- package/dist/firebase/descriptor-store.d.ts +0 -11
- package/dist/firebase/descriptor-store.d.ts.map +0 -1
- package/dist/firebase/descriptor-store.js +0 -18
- package/dist/firebase/descriptor-store.js.map +0 -1
- package/dist/firebase/firestore-store.d.ts +0 -14
- package/dist/firebase/firestore-store.d.ts.map +0 -1
- package/dist/firebase/firestore-store.js +0 -15
- package/dist/firebase/firestore-store.js.map +0 -1
- package/dist/firebase/index.d.ts +0 -12
- package/dist/firebase/index.d.ts.map +0 -1
- package/dist/firebase/index.js +0 -12
- package/dist/firebase/index.js.map +0 -1
- package/dist/firebase/mapping-store.d.ts +0 -11
- package/dist/firebase/mapping-store.d.ts.map +0 -1
- package/dist/firebase/mapping-store.js +0 -18
- package/dist/firebase/mapping-store.js.map +0 -1
- package/dist/firebase/native-item-store.d.ts +0 -20
- package/dist/firebase/native-item-store.d.ts.map +0 -1
- package/dist/firebase/native-item-store.js +0 -55
- package/dist/firebase/native-item-store.js.map +0 -1
- package/dist/firebase/reference-store.d.ts +0 -17
- package/dist/firebase/reference-store.d.ts.map +0 -1
- package/dist/firebase/reference-store.js +0 -27
- package/dist/firebase/reference-store.js.map +0 -1
- package/dist/firebase/snapshot-store.d.ts +0 -11
- package/dist/firebase/snapshot-store.d.ts.map +0 -1
- package/dist/firebase/snapshot-store.js +0 -22
- package/dist/firebase/snapshot-store.js.map +0 -1
- package/dist/index.d.ts +0 -10
- package/dist/index.d.ts.map +0 -1
- package/dist/index.js +0 -10
- package/dist/index.js.map +0 -1
- package/dist/mapping/execute-mapping.d.ts +0 -8
- package/dist/mapping/execute-mapping.d.ts.map +0 -1
- package/dist/mapping/execute-mapping.js +0 -78
- package/dist/mapping/execute-mapping.js.map +0 -1
- package/dist/mapping/helper-gap-report.d.ts +0 -7
- package/dist/mapping/helper-gap-report.d.ts.map +0 -1
- package/dist/mapping/helper-gap-report.js +0 -2
- package/dist/mapping/helper-gap-report.js.map +0 -1
- package/dist/mapping/index.d.ts +0 -4
- package/dist/mapping/index.d.ts.map +0 -1
- package/dist/mapping/index.js +0 -4
- package/dist/mapping/index.js.map +0 -1
- package/dist/mapping/validate-mapping.d.ts +0 -3
- package/dist/mapping/validate-mapping.d.ts.map +0 -1
- package/dist/mapping/validate-mapping.js +0 -32
- package/dist/mapping/validate-mapping.js.map +0 -1
- package/dist/test/integration/firestore.emulator.test.d.ts +0 -2
- package/dist/test/integration/firestore.emulator.test.d.ts.map +0 -1
- package/dist/test/integration/firestore.emulator.test.js +0 -117
- package/dist/test/integration/firestore.emulator.test.js.map +0 -1
- package/dist/test/integration/record-history.live.test.d.ts +0 -2
- package/dist/test/integration/record-history.live.test.d.ts.map +0 -1
- package/dist/test/integration/record-history.live.test.js +0 -126
- package/dist/test/integration/record-history.live.test.js.map +0 -1
- package/dist/test/unit/backup-timestamp.test.d.ts +0 -2
- package/dist/test/unit/backup-timestamp.test.d.ts.map +0 -1
- package/dist/test/unit/backup-timestamp.test.js +0 -11
- package/dist/test/unit/backup-timestamp.test.js.map +0 -1
- package/dist/test/unit/catalox-gcs-backup-export-manifest.test.d.ts +0 -2
- package/dist/test/unit/catalox-gcs-backup-export-manifest.test.d.ts.map +0 -1
- package/dist/test/unit/catalox-gcs-backup-export-manifest.test.js +0 -20
- package/dist/test/unit/catalox-gcs-backup-export-manifest.test.js.map +0 -1
- package/dist/test/unit/compact-catalog-filter.test.d.ts +0 -2
- package/dist/test/unit/compact-catalog-filter.test.d.ts.map +0 -1
- package/dist/test/unit/compact-catalog-filter.test.js +0 -18
- package/dist/test/unit/compact-catalog-filter.test.js.map +0 -1
- package/dist/test/unit/field-source-resolution.test.d.ts +0 -2
- package/dist/test/unit/field-source-resolution.test.d.ts.map +0 -1
- package/dist/test/unit/field-source-resolution.test.js +0 -45
- package/dist/test/unit/field-source-resolution.test.js.map +0 -1
- package/dist/test/unit/gcs-backup-run-folder.test.d.ts +0 -2
- package/dist/test/unit/gcs-backup-run-folder.test.d.ts.map +0 -1
- package/dist/test/unit/gcs-backup-run-folder.test.js +0 -10
- package/dist/test/unit/gcs-backup-run-folder.test.js.map +0 -1
- package/dist/test/unit/gcs-firestore-compare.test.d.ts +0 -2
- package/dist/test/unit/gcs-firestore-compare.test.d.ts.map +0 -1
- package/dist/test/unit/gcs-firestore-compare.test.js +0 -14
- package/dist/test/unit/gcs-firestore-compare.test.js.map +0 -1
- package/dist/test/unit/gcs-firestore-paths.test.d.ts +0 -2
- package/dist/test/unit/gcs-firestore-paths.test.d.ts.map +0 -1
- package/dist/test/unit/gcs-firestore-paths.test.js +0 -16
- package/dist/test/unit/gcs-firestore-paths.test.js.map +0 -1
- package/dist/test/unit/identity.test.d.ts +0 -2
- package/dist/test/unit/identity.test.d.ts.map +0 -1
- package/dist/test/unit/identity.test.js +0 -18
- package/dist/test/unit/identity.test.js.map +0 -1
- package/dist/test/unit/jsx-snippets.test.d.ts +0 -2
- package/dist/test/unit/jsx-snippets.test.d.ts.map +0 -1
- package/dist/test/unit/jsx-snippets.test.js +0 -35
- package/dist/test/unit/jsx-snippets.test.js.map +0 -1
- package/dist/test/unit/mapping.test.d.ts +0 -2
- package/dist/test/unit/mapping.test.d.ts.map +0 -1
- package/dist/test/unit/mapping.test.js +0 -19
- package/dist/test/unit/mapping.test.js.map +0 -1
- package/dist/test/unit/markdown-and-diagrams.test.d.ts +0 -2
- package/dist/test/unit/markdown-and-diagrams.test.d.ts.map +0 -1
- package/dist/test/unit/markdown-and-diagrams.test.js +0 -62
- package/dist/test/unit/markdown-and-diagrams.test.js.map +0 -1
- package/dist/test/unit/native-catalog-merge.test.d.ts +0 -2
- package/dist/test/unit/native-catalog-merge.test.d.ts.map +0 -1
- package/dist/test/unit/native-catalog-merge.test.js +0 -33
- package/dist/test/unit/native-catalog-merge.test.js.map +0 -1
- package/dist/test/unit/native-scope.test.d.ts +0 -2
- package/dist/test/unit/native-scope.test.d.ts.map +0 -1
- package/dist/test/unit/native-scope.test.js +0 -29
- package/dist/test/unit/native-scope.test.js.map +0 -1
- package/dist/test/unit/record-history-path.test.d.ts +0 -2
- package/dist/test/unit/record-history-path.test.d.ts.map +0 -1
- package/dist/test/unit/record-history-path.test.js +0 -24
- package/dist/test/unit/record-history-path.test.js.map +0 -1
- package/dist/test/unit/renderer-metadata-migration.test.d.ts +0 -2
- package/dist/test/unit/renderer-metadata-migration.test.d.ts.map +0 -1
- package/dist/test/unit/renderer-metadata-migration.test.js +0 -33
- package/dist/test/unit/renderer-metadata-migration.test.js.map +0 -1
- package/dist/test/unit/renderer-metadata.test.d.ts +0 -2
- package/dist/test/unit/renderer-metadata.test.d.ts.map +0 -1
- package/dist/test/unit/renderer-metadata.test.js +0 -10
- package/dist/test/unit/renderer-metadata.test.js.map +0 -1
- package/dist/test/unit/resolve-native-items-layout.test.d.ts +0 -2
- package/dist/test/unit/resolve-native-items-layout.test.d.ts.map +0 -1
- package/dist/test/unit/resolve-native-items-layout.test.js +0 -50
- package/dist/test/unit/resolve-native-items-layout.test.js.map +0 -1
- package/dist/test/unit/ui-spec-validation.test.d.ts +0 -2
- package/dist/test/unit/ui-spec-validation.test.d.ts.map +0 -1
- package/dist/test/unit/ui-spec-validation.test.js +0 -90
- package/dist/test/unit/ui-spec-validation.test.js.map +0 -1
- package/dist/validation/index.d.ts +0 -2
- package/dist/validation/index.d.ts.map +0 -1
- package/dist/validation/index.js +0 -3
- package/dist/validation/index.js.map +0 -1
|
@@ -1,126 +0,0 @@
|
|
|
1
|
-
import test from "node:test";
|
|
2
|
-
import assert from "node:assert/strict";
|
|
3
|
-
import path from "node:path";
|
|
4
|
-
import { loadDotenv } from "@x12i/env";
|
|
5
|
-
import { initializeApp, cert, deleteApp } from "firebase-admin/app";
|
|
6
|
-
import { getFirestore } from "firebase-admin/firestore";
|
|
7
|
-
import { createCatalox } from "../../src/catalox/create-catalox.js";
|
|
8
|
-
import { buildRecordHistoryGcsClient, normalizeRecordHistoryGcsPrefix } from "../../src/catalox/record-history.js";
|
|
9
|
-
import { AppStore } from "../../src/firebase/app-store.js";
|
|
10
|
-
import { CatalogItemHistoryStore } from "../../src/firebase/catalog-item-history-store.js";
|
|
11
|
-
import { DescriptorStore } from "../../src/firebase/descriptor-store.js";
|
|
12
|
-
import { FirestoreStore } from "../../src/firebase/firestore-store.js";
|
|
13
|
-
loadDotenv(path.resolve(process.cwd(), ".env"));
|
|
14
|
-
function requireEnv(name) {
|
|
15
|
-
const v = process.env[name];
|
|
16
|
-
if (!v)
|
|
17
|
-
throw new Error(`Missing required env: ${name}`);
|
|
18
|
-
return v;
|
|
19
|
-
}
|
|
20
|
-
test("record history live: upsert, update, list, get, restore + GCS when bucket env is set", async (t) => {
|
|
21
|
-
if (process.env.FIRESTORE_LIVE_TESTS !== "1") {
|
|
22
|
-
t.skip("FIRESTORE_LIVE_TESTS not enabled");
|
|
23
|
-
return;
|
|
24
|
-
}
|
|
25
|
-
const historyBucket = String(process.env.CATALOX_RECORD_HISTORY_BUCKET ?? "").trim();
|
|
26
|
-
if (!historyBucket) {
|
|
27
|
-
t.skip("CATALOX_RECORD_HISTORY_BUCKET not set");
|
|
28
|
-
return;
|
|
29
|
-
}
|
|
30
|
-
const serviceAccountPath = requireEnv("FIREBASE_SERVICE_ACCOUNT_PATH");
|
|
31
|
-
const projectId = requireEnv("FIREBASE_PROJECT_ID");
|
|
32
|
-
const appName = `catalox-rh-${Date.now()}`;
|
|
33
|
-
const app = initializeApp({ credential: cert(serviceAccountPath), projectId }, appName);
|
|
34
|
-
const firestore = getFirestore(app);
|
|
35
|
-
const store = new FirestoreStore({ firestore, app });
|
|
36
|
-
const apps = new AppStore(store);
|
|
37
|
-
const descriptors = new DescriptorStore(store);
|
|
38
|
-
const historyStore = new CatalogItemHistoryStore(store);
|
|
39
|
-
const rhPrefix = normalizeRecordHistoryGcsPrefix(process.env.CATALOX_RECORD_HISTORY_PREFIX);
|
|
40
|
-
const catalox = createCatalox({
|
|
41
|
-
firestore,
|
|
42
|
-
firebaseApp: app,
|
|
43
|
-
recordHistory: {
|
|
44
|
-
gcsBucket: historyBucket,
|
|
45
|
-
gcsPrefix: rhPrefix,
|
|
46
|
-
failClosed: String(process.env.CATALOX_RECORD_HISTORY_FAIL_CLOSED ?? "").trim() === "1",
|
|
47
|
-
},
|
|
48
|
-
});
|
|
49
|
-
const historyGcs = buildRecordHistoryGcsClient({
|
|
50
|
-
store: historyStore,
|
|
51
|
-
gcsBucket: historyBucket,
|
|
52
|
-
gcsBasePrefix: rhPrefix,
|
|
53
|
-
failClosed: false,
|
|
54
|
-
});
|
|
55
|
-
const runId = `${Date.now()}`;
|
|
56
|
-
const appId = `catalox_rh_${runId}`;
|
|
57
|
-
const catalogId = `rh_cat_${runId}`;
|
|
58
|
-
const ctx = { appId, superAdmin: true };
|
|
59
|
-
await apps.upsert({
|
|
60
|
-
appId,
|
|
61
|
-
name: "RH App",
|
|
62
|
-
status: "active",
|
|
63
|
-
createdAt: new Date().toISOString(),
|
|
64
|
-
updatedAt: new Date().toISOString(),
|
|
65
|
-
});
|
|
66
|
-
await catalox.createCatalog(ctx, {
|
|
67
|
-
catalogId,
|
|
68
|
-
name: "RH",
|
|
69
|
-
sourceMode: "native",
|
|
70
|
-
native: { type: "native" },
|
|
71
|
-
});
|
|
72
|
-
await catalox.bindCatalogToApp(ctx, {
|
|
73
|
-
appId,
|
|
74
|
-
catalogId,
|
|
75
|
-
access: { canRead: true, canWrite: true, canAdmin: true },
|
|
76
|
-
});
|
|
77
|
-
const descRec = await descriptors.get(catalogId);
|
|
78
|
-
assert.ok(descRec);
|
|
79
|
-
await descriptors.upsert({
|
|
80
|
-
...descRec,
|
|
81
|
-
descriptor: {
|
|
82
|
-
...descRec.descriptor,
|
|
83
|
-
identity: { itemIdStrategy: "natural", itemIdField: "id" },
|
|
84
|
-
queryableFields: [{ key: "id", label: "ID", type: "string", indexed: true, filterable: true }],
|
|
85
|
-
},
|
|
86
|
-
updatedAt: new Date().toISOString(),
|
|
87
|
-
});
|
|
88
|
-
await catalox.upsertNativeCatalogItem(ctx, catalogId, { id: "one", title: "A" });
|
|
89
|
-
await catalox.updateNativeCatalogItem(ctx, catalogId, "one", { title: "B" });
|
|
90
|
-
const hist = await catalox.listCatalogItemHistory(ctx, catalogId, {
|
|
91
|
-
itemId: "one",
|
|
92
|
-
limit: 20,
|
|
93
|
-
});
|
|
94
|
-
assert.ok(hist.events.length >= 2);
|
|
95
|
-
assert.equal(hist.events[0].catalogId, catalogId);
|
|
96
|
-
const latestEventId = hist.events[0].eventId;
|
|
97
|
-
const detail = await catalox.getCatalogItemHistoryEvent(ctx, latestEventId);
|
|
98
|
-
assert.ok(detail);
|
|
99
|
-
assert.equal(String(detail.payload.before?.data?.title ?? ""), "A");
|
|
100
|
-
assert.equal(String(detail.payload.after?.data?.title ?? ""), "B");
|
|
101
|
-
await catalox.restoreCatalogItemFromHistory(ctx, latestEventId, { mode: "before" });
|
|
102
|
-
const got = await catalox.getCatalogItem(ctx, catalogId, "one");
|
|
103
|
-
assert.equal(got.outcome, "found");
|
|
104
|
-
if (got.outcome === "found")
|
|
105
|
-
assert.equal(got.item.data.title, "A");
|
|
106
|
-
const histAfterRestore = await catalox.listCatalogItemHistory(ctx, catalogId, {
|
|
107
|
-
itemId: "one",
|
|
108
|
-
limit: 50,
|
|
109
|
-
});
|
|
110
|
-
await firestore.collection("apps").doc(appId).delete().catch(() => { });
|
|
111
|
-
await firestore.collection("catalogs").doc(catalogId).delete().catch(() => { });
|
|
112
|
-
await firestore.collection("catalogDefinitions").doc(catalogId).delete().catch(() => { });
|
|
113
|
-
await firestore.collection("catalogDescriptors").doc(catalogId).delete().catch(() => { });
|
|
114
|
-
await firestore.collection("catalogBindings").doc(`${appId}:${catalogId}`).delete().catch(() => { });
|
|
115
|
-
await firestore.collection("catalogData").doc(catalogId).delete().catch(() => { });
|
|
116
|
-
const flat = `catalogData-${catalogId}-items`;
|
|
117
|
-
const flatSnap = await firestore.collection(flat).get();
|
|
118
|
-
for (const d of flatSnap.docs)
|
|
119
|
-
await d.ref.delete();
|
|
120
|
-
for (const e of histAfterRestore.events) {
|
|
121
|
-
await firestore.collection("catalogItemHistory").doc(e.eventId).delete().catch(() => { });
|
|
122
|
-
await historyGcs.deleteObject(e.gcsRelativePath).catch(() => { });
|
|
123
|
-
}
|
|
124
|
-
await deleteApp(app);
|
|
125
|
-
});
|
|
126
|
-
//# sourceMappingURL=record-history.live.test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"record-history.live.test.js","sourceRoot":"","sources":["../../../test/integration/record-history.live.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"backup-timestamp.test.d.ts","sourceRoot":"","sources":["../../../test/unit/backup-timestamp.test.ts"],"names":[],"mappings":""}
|
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
import test from "node:test";
|
|
2
|
-
import assert from "node:assert/strict";
|
|
3
|
-
import { formatBackupTimestamp } from "../../src/catalox/backup-data.js";
|
|
4
|
-
test("formatBackupTimestamp uses filesystem-safe default", () => {
|
|
5
|
-
const ts = formatBackupTimestamp(undefined, new Date("2026-04-18T11:30:00.000Z"));
|
|
6
|
-
assert.match(ts, /^2026_04_18T11_30_00Z$/);
|
|
7
|
-
});
|
|
8
|
-
test("formatBackupTimestamp respects override", () => {
|
|
9
|
-
assert.equal(formatBackupTimestamp("custom_ts"), "custom_ts");
|
|
10
|
-
});
|
|
11
|
-
//# sourceMappingURL=backup-timestamp.test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"backup-timestamp.test.js","sourceRoot":"","sources":["../../../test/unit/backup-timestamp.test.ts"],"names":[],"mappings":"AAAA,OAAO,IAAI,MAAM,WAAW,CAAC;AAC7B,OAAO,MAAM,MAAM,oBAAoB,CAAC;AACxC,OAAO,EAAE,qBAAqB,EAAE,MAAM,kCAAkC,CAAC;AAEzE,IAAI,CAAC,oDAAoD,EAAE,GAAG,EAAE;IAC9D,MAAM,EAAE,GAAG,qBAAqB,CAAC,SAAS,EAAE,IAAI,IAAI,CAAC,0BAA0B,CAAC,CAAC,CAAC;IAClF,MAAM,CAAC,KAAK,CAAC,EAAE,EAAE,wBAAwB,CAAC,CAAC;AAC7C,CAAC,CAAC,CAAC;AAEH,IAAI,CAAC,yCAAyC,EAAE,GAAG,EAAE;IACnD,MAAM,CAAC,KAAK,CAAC,qBAAqB,CAAC,WAAW,CAAC,EAAE,WAAW,CAAC,CAAC;AAChE,CAAC,CAAC,CAAC"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"catalox-gcs-backup-export-manifest.test.d.ts","sourceRoot":"","sources":["../../../test/unit/catalox-gcs-backup-export-manifest.test.ts"],"names":[],"mappings":""}
|
|
@@ -1,20 +0,0 @@
|
|
|
1
|
-
import test from "node:test";
|
|
2
|
-
import assert from "node:assert/strict";
|
|
3
|
-
import { cataloxGcsBackupManifestToFirestoreExportManifest } from "../../src/catalox/catalox-gcs-backup-export-manifest.js";
|
|
4
|
-
test("cataloxGcsBackupManifestToFirestoreExportManifest maps metadata and native paths", () => {
|
|
5
|
-
const m = {
|
|
6
|
-
collectionsWritten: ["metadata/apps.ndjson", "native/catalogData--sig.ndjson"],
|
|
7
|
-
nativeItemSourceLayoutByCatalogId: { sig: "flat" },
|
|
8
|
-
counts: { "gcs:meta:apps": 2, "gcs:native:catalogData--sig": 5 },
|
|
9
|
-
};
|
|
10
|
-
const out = cataloxGcsBackupManifestToFirestoreExportManifest(m, "pre/r1");
|
|
11
|
-
assert.equal(out.catalog, "catalox-firestore-gcs-export");
|
|
12
|
-
assert.equal(out.gcsPrefix, "pre/r1/");
|
|
13
|
-
const apps = out.entries.find((e) => e.firestorePath === "apps");
|
|
14
|
-
assert.ok(apps);
|
|
15
|
-
assert.equal(apps.objectPath, "pre/r1/metadata/apps.ndjson");
|
|
16
|
-
const nat = out.entries.find((e) => e.firestorePath === "catalogData-sig-items");
|
|
17
|
-
assert.ok(nat);
|
|
18
|
-
assert.equal(nat.objectPath, "pre/r1/native/catalogData--sig.ndjson");
|
|
19
|
-
});
|
|
20
|
-
//# sourceMappingURL=catalox-gcs-backup-export-manifest.test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"catalox-gcs-backup-export-manifest.test.js","sourceRoot":"","sources":["../../../test/unit/catalox-gcs-backup-export-manifest.test.ts"],"names":[],"mappings":"AAAA,OAAO,IAAI,MAAM,WAAW,CAAC;AAC7B,OAAO,MAAM,MAAM,oBAAoB,CAAC;AAExC,OAAO,EAAE,iDAAiD,EAAE,MAAM,yDAAyD,CAAC;AAG5H,IAAI,CAAC,kFAAkF,EAAE,GAAG,EAAE;IAC5F,MAAM,CAAC,GAA+B;QACpC,kBAAkB,EAAE,CAAC,sBAAsB,EAAE,gCAAgC,CAAC;QAC9E,iCAAiC,EAAE,EAAE,GAAG,EAAE,MAAM,EAAE;QAClD,MAAM,EAAE,EAAE,eAAe,EAAE,CAAC,EAAE,6BAA6B,EAAE,CAAC,EAAE;KACjE,CAAC;IACF,MAAM,GAAG,GAAG,iDAAiD,CAAC,CAAC,EAAE,QAAQ,CAAC,CAAC;IAC3E,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,OAAO,EAAE,8BAA8B,CAAC,CAAC;IAC1D,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,SAAS,EAAE,SAAS,CAAC,CAAC;IACvC,MAAM,IAAI,GAAG,GAAG,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,aAAa,KAAK,MAAM,CAAC,CAAC;IACjE,MAAM,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC;IAChB,MAAM,CAAC,KAAK,CAAC,IAAK,CAAC,UAAU,EAAE,6BAA6B,CAAC,CAAC;IAC9D,MAAM,GAAG,GAAG,GAAG,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,aAAa,KAAK,uBAAuB,CAAC,CAAC;IACjF,MAAM,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC;IACf,MAAM,CAAC,KAAK,CAAC,GAAI,CAAC,UAAU,EAAE,uCAAuC,CAAC,CAAC;AACzE,CAAC,CAAC,CAAC"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"compact-catalog-filter.test.d.ts","sourceRoot":"","sources":["../../../test/unit/compact-catalog-filter.test.ts"],"names":[],"mappings":""}
|
|
@@ -1,18 +0,0 @@
|
|
|
1
|
-
import test from "node:test";
|
|
2
|
-
import assert from "node:assert/strict";
|
|
3
|
-
import { compactCatalogFilter } from "../../src/contracts/catalogs.js";
|
|
4
|
-
test("compactCatalogFilter drops null, undefined, and blank strings", () => {
|
|
5
|
-
assert.deepEqual(compactCatalogFilter({
|
|
6
|
-
a: "",
|
|
7
|
-
b: " ",
|
|
8
|
-
c: null,
|
|
9
|
-
d: undefined,
|
|
10
|
-
e: "x",
|
|
11
|
-
f: 0,
|
|
12
|
-
g: false,
|
|
13
|
-
}), { e: "x", f: 0, g: false });
|
|
14
|
-
});
|
|
15
|
-
test("compactCatalogFilter returns {} for undefined input", () => {
|
|
16
|
-
assert.deepEqual(compactCatalogFilter(undefined), {});
|
|
17
|
-
});
|
|
18
|
-
//# sourceMappingURL=compact-catalog-filter.test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"compact-catalog-filter.test.js","sourceRoot":"","sources":["../../../test/unit/compact-catalog-filter.test.ts"],"names":[],"mappings":"AAAA,OAAO,IAAI,MAAM,WAAW,CAAC;AAC7B,OAAO,MAAM,MAAM,oBAAoB,CAAC;AAExC,OAAO,EAAE,oBAAoB,EAAE,MAAM,iCAAiC,CAAC;AAEvE,IAAI,CAAC,+DAA+D,EAAE,GAAG,EAAE;IACzE,MAAM,CAAC,SAAS,CACd,oBAAoB,CAAC;QACnB,CAAC,EAAE,EAAE;QACL,CAAC,EAAE,IAAI;QACP,CAAC,EAAE,IAAI;QACP,CAAC,EAAE,SAAS;QACZ,CAAC,EAAE,GAAG;QACN,CAAC,EAAE,CAAC;QACJ,CAAC,EAAE,KAAK;KACT,CAAC,EACF,EAAE,CAAC,EAAE,GAAG,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,KAAK,EAAE,CAC3B,CAAC;AACJ,CAAC,CAAC,CAAC;AAEH,IAAI,CAAC,qDAAqD,EAAE,GAAG,EAAE;IAC/D,MAAM,CAAC,SAAS,CAAC,oBAAoB,CAAC,SAAS,CAAC,EAAE,EAAE,CAAC,CAAC;AACxD,CAAC,CAAC,CAAC"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"field-source-resolution.test.d.ts","sourceRoot":"","sources":["../../../test/unit/field-source-resolution.test.ts"],"names":[],"mappings":""}
|
|
@@ -1,45 +0,0 @@
|
|
|
1
|
-
import test from "node:test";
|
|
2
|
-
import assert from "node:assert/strict";
|
|
3
|
-
import { isDollarPath, resolveFilterBy, optionsFromStaticSource, optionsFromCatalogItems, } from "../../src/catalox/field-source-resolution.js";
|
|
4
|
-
function readPath(obj, path) {
|
|
5
|
-
const parts = path.split(".").filter(Boolean);
|
|
6
|
-
let cur = obj;
|
|
7
|
-
for (const p of parts) {
|
|
8
|
-
if (cur == null || typeof cur !== "object")
|
|
9
|
-
return undefined;
|
|
10
|
-
cur = cur[p];
|
|
11
|
-
}
|
|
12
|
-
return cur;
|
|
13
|
-
}
|
|
14
|
-
test("isDollarPath detects $.prefix", () => {
|
|
15
|
-
assert.equal(isDollarPath("$.a"), true);
|
|
16
|
-
assert.equal(isDollarPath("a"), false);
|
|
17
|
-
});
|
|
18
|
-
test("resolveFilterBy resolves $. paths from current item data", () => {
|
|
19
|
-
const filterBy = { countryCode: "$.country.code", status: "active" };
|
|
20
|
-
const currentItemData = { country: { code: "US" } };
|
|
21
|
-
const out = resolveFilterBy(filterBy, currentItemData, readPath);
|
|
22
|
-
assert.deepEqual(out, { countryCode: "US", status: "active" });
|
|
23
|
-
});
|
|
24
|
-
test("resolveFilterBy drops $. paths when no current item data", () => {
|
|
25
|
-
const filterBy = { countryCode: "$.country.code", status: "active" };
|
|
26
|
-
const out = resolveFilterBy(filterBy, undefined, readPath);
|
|
27
|
-
assert.deepEqual(out, { status: "active" });
|
|
28
|
-
});
|
|
29
|
-
test("optionsFromStaticSource maps values to resolved options", () => {
|
|
30
|
-
const out = optionsFromStaticSource({
|
|
31
|
-
type: "static",
|
|
32
|
-
values: [{ value: "P0", label: "Critical", color: "red" }],
|
|
33
|
-
});
|
|
34
|
-
assert.deepEqual(out, [{ value: "P0", label: "Critical", color: "red" }]);
|
|
35
|
-
});
|
|
36
|
-
test("optionsFromCatalogItems extracts values via dot paths", () => {
|
|
37
|
-
const out = optionsFromCatalogItems({
|
|
38
|
-
items: [{ data: { code: "P0", label: "Critical" } }],
|
|
39
|
-
valueField: "code",
|
|
40
|
-
labelField: "label",
|
|
41
|
-
readPath,
|
|
42
|
-
});
|
|
43
|
-
assert.deepEqual(out, [{ value: "P0", label: "Critical" }]);
|
|
44
|
-
});
|
|
45
|
-
//# sourceMappingURL=field-source-resolution.test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"field-source-resolution.test.js","sourceRoot":"","sources":["../../../test/unit/field-source-resolution.test.ts"],"names":[],"mappings":"AAAA,OAAO,IAAI,MAAM,WAAW,CAAC;AAC7B,OAAO,MAAM,MAAM,oBAAoB,CAAC;AAExC,OAAO,EACL,YAAY,EACZ,eAAe,EACf,uBAAuB,EACvB,uBAAuB,GACxB,MAAM,8CAA8C,CAAC;AAEtD,SAAS,QAAQ,CAAC,GAAY,EAAE,IAAY;IAC1C,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;IAC9C,IAAI,GAAG,GAAQ,GAAG,CAAC;IACnB,KAAK,MAAM,CAAC,IAAI,KAAK,EAAE,CAAC;QACtB,IAAI,GAAG,IAAI,IAAI,IAAI,OAAO,GAAG,KAAK,QAAQ;YAAE,OAAO,SAAS,CAAC;QAC7D,GAAG,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC;IACf,CAAC;IACD,OAAO,GAAG,CAAC;AACb,CAAC;AAED,IAAI,CAAC,+BAA+B,EAAE,GAAG,EAAE;IACzC,MAAM,CAAC,KAAK,CAAC,YAAY,CAAC,KAAK,CAAC,EAAE,IAAI,CAAC,CAAC;IACxC,MAAM,CAAC,KAAK,CAAC,YAAY,CAAC,GAAG,CAAC,EAAE,KAAK,CAAC,CAAC;AACzC,CAAC,CAAC,CAAC;AAEH,IAAI,CAAC,0DAA0D,EAAE,GAAG,EAAE;IACpE,MAAM,QAAQ,GAAG,EAAE,WAAW,EAAE,gBAAgB,EAAE,MAAM,EAAE,QAAQ,EAAE,CAAC;IACrE,MAAM,eAAe,GAAG,EAAE,OAAO,EAAE,EAAE,IAAI,EAAE,IAAI,EAAE,EAAE,CAAC;IACpD,MAAM,GAAG,GAAG,eAAe,CAAC,QAAQ,EAAE,eAAe,EAAE,QAAQ,CAAC,CAAC;IACjE,MAAM,CAAC,SAAS,CAAC,GAAG,EAAE,EAAE,WAAW,EAAE,IAAI,EAAE,MAAM,EAAE,QAAQ,EAAE,CAAC,CAAC;AACjE,CAAC,CAAC,CAAC;AAEH,IAAI,CAAC,0DAA0D,EAAE,GAAG,EAAE;IACpE,MAAM,QAAQ,GAAG,EAAE,WAAW,EAAE,gBAAgB,EAAE,MAAM,EAAE,QAAQ,EAAE,CAAC;IACrE,MAAM,GAAG,GAAG,eAAe,CAAC,QAAQ,EAAE,SAAS,EAAE,QAAQ,CAAC,CAAC;IAC3D,MAAM,CAAC,SAAS,CAAC,GAAG,EAAE,EAAE,MAAM,EAAE,QAAQ,EAAE,CAAC,CAAC;AAC9C,CAAC,CAAC,CAAC;AAEH,IAAI,CAAC,yDAAyD,EAAE,GAAG,EAAE;IACnE,MAAM,GAAG,GAAG,uBAAuB,CAAC;QAClC,IAAI,EAAE,QAAQ;QACd,MAAM,EAAE,CAAC,EAAE,KAAK,EAAE,IAAI,EAAE,KAAK,EAAE,UAAU,EAAE,KAAK,EAAE,KAAK,EAAE,CAAC;KAC3D,CAAC,CAAC;IACH,MAAM,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC,EAAE,KAAK,EAAE,IAAI,EAAE,KAAK,EAAE,UAAU,EAAE,KAAK,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC;AAC5E,CAAC,CAAC,CAAC;AAEH,IAAI,CAAC,uDAAuD,EAAE,GAAG,EAAE;IACjE,MAAM,GAAG,GAAG,uBAAuB,CAAC;QAClC,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,EAAE,IAAI,EAAE,IAAI,EAAE,KAAK,EAAE,UAAU,EAAE,EAAE,CAAC;QACpD,UAAU,EAAE,MAAM;QAClB,UAAU,EAAE,OAAO;QACnB,QAAQ;KACT,CAAC,CAAC;IACH,MAAM,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC,EAAE,KAAK,EAAE,IAAI,EAAE,KAAK,EAAE,UAAU,EAAE,CAAC,CAAC,CAAC;AAC9D,CAAC,CAAC,CAAC"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"gcs-backup-run-folder.test.d.ts","sourceRoot":"","sources":["../../../test/unit/gcs-backup-run-folder.test.ts"],"names":[],"mappings":""}
|
|
@@ -1,10 +0,0 @@
|
|
|
1
|
-
import test from "node:test";
|
|
2
|
-
import assert from "node:assert/strict";
|
|
3
|
-
import { gcsBackupRunFolder } from "../../src/catalox/backup-data.js";
|
|
4
|
-
test("gcsBackupRunFolder uses default base when prefix empty", () => {
|
|
5
|
-
assert.equal(gcsBackupRunFolder("2026_01_01T00_00_00Z"), "catalox-firestore-backups/2026_01_01T00_00_00Z");
|
|
6
|
-
});
|
|
7
|
-
test("gcsBackupRunFolder respects custom prefix", () => {
|
|
8
|
-
assert.equal(gcsBackupRunFolder("ts", "my/"), "my/ts");
|
|
9
|
-
});
|
|
10
|
-
//# sourceMappingURL=gcs-backup-run-folder.test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"gcs-backup-run-folder.test.js","sourceRoot":"","sources":["../../../test/unit/gcs-backup-run-folder.test.ts"],"names":[],"mappings":"AAAA,OAAO,IAAI,MAAM,WAAW,CAAC;AAC7B,OAAO,MAAM,MAAM,oBAAoB,CAAC;AAExC,OAAO,EAAE,kBAAkB,EAAE,MAAM,kCAAkC,CAAC;AAEtE,IAAI,CAAC,wDAAwD,EAAE,GAAG,EAAE;IAClE,MAAM,CAAC,KAAK,CAAC,kBAAkB,CAAC,sBAAsB,CAAC,EAAE,gDAAgD,CAAC,CAAC;AAC7G,CAAC,CAAC,CAAC;AAEH,IAAI,CAAC,2CAA2C,EAAE,GAAG,EAAE;IACrD,MAAM,CAAC,KAAK,CAAC,kBAAkB,CAAC,IAAI,EAAE,KAAK,CAAC,EAAE,OAAO,CAAC,CAAC;AACzD,CAAC,CAAC,CAAC"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"gcs-firestore-compare.test.d.ts","sourceRoot":"","sources":["../../../test/unit/gcs-firestore-compare.test.ts"],"names":[],"mappings":""}
|
|
@@ -1,14 +0,0 @@
|
|
|
1
|
-
import test from "node:test";
|
|
2
|
-
import assert from "node:assert/strict";
|
|
3
|
-
import { Timestamp } from "firebase-admin/firestore";
|
|
4
|
-
import { dataFingerprint, normalizeForCompare } from "../../src/catalox/firestore-gcs-compare.js";
|
|
5
|
-
test("normalizeForCompare maps Timestamp and JSON seconds shape consistently", () => {
|
|
6
|
-
const ts = new Timestamp(1700000000, 123000000);
|
|
7
|
-
const fromJson = { _seconds: 1700000000, _nanoseconds: 123000000 };
|
|
8
|
-
assert.equal(JSON.stringify(normalizeForCompare(ts)), JSON.stringify(normalizeForCompare(fromJson)));
|
|
9
|
-
assert.equal(dataFingerprint(ts), dataFingerprint(fromJson));
|
|
10
|
-
});
|
|
11
|
-
test("dataFingerprint differs when data differs", () => {
|
|
12
|
-
assert.notEqual(dataFingerprint({ a: 1 }), dataFingerprint({ a: 2 }));
|
|
13
|
-
});
|
|
14
|
-
//# sourceMappingURL=gcs-firestore-compare.test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"gcs-firestore-compare.test.js","sourceRoot":"","sources":["../../../test/unit/gcs-firestore-compare.test.ts"],"names":[],"mappings":"AAAA,OAAO,IAAI,MAAM,WAAW,CAAC;AAC7B,OAAO,MAAM,MAAM,oBAAoB,CAAC;AACxC,OAAO,EAAE,SAAS,EAAE,MAAM,0BAA0B,CAAC;AAErD,OAAO,EAAE,eAAe,EAAE,mBAAmB,EAAE,MAAM,4CAA4C,CAAC;AAElG,IAAI,CAAC,wEAAwE,EAAE,GAAG,EAAE;IAClF,MAAM,EAAE,GAAG,IAAI,SAAS,CAAC,UAAU,EAAE,SAAS,CAAC,CAAC;IAChD,MAAM,QAAQ,GAAG,EAAE,QAAQ,EAAE,UAAU,EAAE,YAAY,EAAE,SAAS,EAAE,CAAC;IACnE,MAAM,CAAC,KAAK,CACV,IAAI,CAAC,SAAS,CAAC,mBAAmB,CAAC,EAAE,CAAC,CAAC,EACvC,IAAI,CAAC,SAAS,CAAC,mBAAmB,CAAC,QAAQ,CAAC,CAAC,CAC9C,CAAC;IACF,MAAM,CAAC,KAAK,CAAC,eAAe,CAAC,EAAE,CAAC,EAAE,eAAe,CAAC,QAAQ,CAAC,CAAC,CAAC;AAC/D,CAAC,CAAC,CAAC;AAEH,IAAI,CAAC,2CAA2C,EAAE,GAAG,EAAE;IACrD,MAAM,CAAC,QAAQ,CAAC,eAAe,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,eAAe,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;AACxE,CAAC,CAAC,CAAC"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"gcs-firestore-paths.test.d.ts","sourceRoot":"","sources":["../../../test/unit/gcs-firestore-paths.test.ts"],"names":[],"mappings":""}
|
|
@@ -1,16 +0,0 @@
|
|
|
1
|
-
import test from "node:test";
|
|
2
|
-
import assert from "node:assert/strict";
|
|
3
|
-
import { firestoreCollectionPathToObjectBase, ndjsonObjectPath, normalizeGcsPrefix, } from "../../src/catalox/firestore-gcs-transfer.js";
|
|
4
|
-
test("normalizeGcsPrefix trims and adds trailing slash", () => {
|
|
5
|
-
assert.equal(normalizeGcsPrefix(""), "");
|
|
6
|
-
assert.equal(normalizeGcsPrefix(" a/b "), "a/b/");
|
|
7
|
-
});
|
|
8
|
-
test("firestoreCollectionPathToObjectBase flattens slashes", () => {
|
|
9
|
-
assert.equal(firestoreCollectionPathToObjectBase("apps"), "apps");
|
|
10
|
-
assert.equal(firestoreCollectionPathToObjectBase("catalogData/narratives/items"), "catalogData__narratives__items");
|
|
11
|
-
});
|
|
12
|
-
test("ndjsonObjectPath applies optional postfix", () => {
|
|
13
|
-
assert.equal(ndjsonObjectPath({ gcsPrefix: "p/", collectionPath: "apps" }), "p/apps.ndjson");
|
|
14
|
-
assert.equal(ndjsonObjectPath({ gcsPrefix: "", collectionPath: "apps", objectNamePostfix: "_v1" }), "apps_v1.ndjson");
|
|
15
|
-
});
|
|
16
|
-
//# sourceMappingURL=gcs-firestore-paths.test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"gcs-firestore-paths.test.js","sourceRoot":"","sources":["../../../test/unit/gcs-firestore-paths.test.ts"],"names":[],"mappings":"AAAA,OAAO,IAAI,MAAM,WAAW,CAAC;AAC7B,OAAO,MAAM,MAAM,oBAAoB,CAAC;AAExC,OAAO,EACL,mCAAmC,EACnC,gBAAgB,EAChB,kBAAkB,GACnB,MAAM,6CAA6C,CAAC;AAErD,IAAI,CAAC,kDAAkD,EAAE,GAAG,EAAE;IAC5D,MAAM,CAAC,KAAK,CAAC,kBAAkB,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC;IACzC,MAAM,CAAC,KAAK,CAAC,kBAAkB,CAAC,SAAS,CAAC,EAAE,MAAM,CAAC,CAAC;AACtD,CAAC,CAAC,CAAC;AAEH,IAAI,CAAC,sDAAsD,EAAE,GAAG,EAAE;IAChE,MAAM,CAAC,KAAK,CAAC,mCAAmC,CAAC,MAAM,CAAC,EAAE,MAAM,CAAC,CAAC;IAClE,MAAM,CAAC,KAAK,CAAC,mCAAmC,CAAC,8BAA8B,CAAC,EAAE,gCAAgC,CAAC,CAAC;AACtH,CAAC,CAAC,CAAC;AAEH,IAAI,CAAC,2CAA2C,EAAE,GAAG,EAAE;IACrD,MAAM,CAAC,KAAK,CACV,gBAAgB,CAAC,EAAE,SAAS,EAAE,IAAI,EAAE,cAAc,EAAE,MAAM,EAAE,CAAC,EAC7D,eAAe,CAChB,CAAC;IACF,MAAM,CAAC,KAAK,CACV,gBAAgB,CAAC,EAAE,SAAS,EAAE,EAAE,EAAE,cAAc,EAAE,MAAM,EAAE,iBAAiB,EAAE,KAAK,EAAE,CAAC,EACrF,gBAAgB,CACjB,CAAC;AACJ,CAAC,CAAC,CAAC"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"identity.test.d.ts","sourceRoot":"","sources":["../../../test/unit/identity.test.ts"],"names":[],"mappings":""}
|
|
@@ -1,18 +0,0 @@
|
|
|
1
|
-
import test from "node:test";
|
|
2
|
-
import assert from "node:assert/strict";
|
|
3
|
-
import { resolveCatalogItemId } from "../../src/catalox/identity.js";
|
|
4
|
-
test("resolveCatalogItemId natural strategy", () => {
|
|
5
|
-
const id = resolveCatalogItemId({
|
|
6
|
-
identity: { itemIdStrategy: "natural", itemIdField: "code" },
|
|
7
|
-
data: { code: "S1" },
|
|
8
|
-
});
|
|
9
|
-
assert.equal(id, "S1");
|
|
10
|
-
});
|
|
11
|
-
test("resolveCatalogItemId composite strategy", () => {
|
|
12
|
-
const id = resolveCatalogItemId({
|
|
13
|
-
identity: { itemIdStrategy: "composite", compositeFields: ["categoryId", "code"] },
|
|
14
|
-
data: { categoryId: "catA", code: "S1" },
|
|
15
|
-
});
|
|
16
|
-
assert.equal(id, "catA:S1");
|
|
17
|
-
});
|
|
18
|
-
//# sourceMappingURL=identity.test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"identity.test.js","sourceRoot":"","sources":["../../../test/unit/identity.test.ts"],"names":[],"mappings":"AAAA,OAAO,IAAI,MAAM,WAAW,CAAC;AAC7B,OAAO,MAAM,MAAM,oBAAoB,CAAC;AAExC,OAAO,EAAE,oBAAoB,EAAE,MAAM,+BAA+B,CAAC;AAErE,IAAI,CAAC,uCAAuC,EAAE,GAAG,EAAE;IACjD,MAAM,EAAE,GAAG,oBAAoB,CAAC;QAC9B,QAAQ,EAAE,EAAE,cAAc,EAAE,SAAS,EAAE,WAAW,EAAE,MAAM,EAAE;QAC5D,IAAI,EAAE,EAAE,IAAI,EAAE,IAAI,EAAE;KACrB,CAAC,CAAC;IACH,MAAM,CAAC,KAAK,CAAC,EAAE,EAAE,IAAI,CAAC,CAAC;AACzB,CAAC,CAAC,CAAC;AAEH,IAAI,CAAC,yCAAyC,EAAE,GAAG,EAAE;IACnD,MAAM,EAAE,GAAG,oBAAoB,CAAC;QAC9B,QAAQ,EAAE,EAAE,cAAc,EAAE,WAAW,EAAE,eAAe,EAAE,CAAC,YAAY,EAAE,MAAM,CAAC,EAAE;QAClF,IAAI,EAAE,EAAE,UAAU,EAAE,MAAM,EAAE,IAAI,EAAE,IAAI,EAAE;KACzC,CAAC,CAAC;IACH,MAAM,CAAC,KAAK,CAAC,EAAE,EAAE,SAAS,CAAC,CAAC;AAC9B,CAAC,CAAC,CAAC"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"jsx-snippets.test.d.ts","sourceRoot":"","sources":["../../../test/unit/jsx-snippets.test.ts"],"names":[],"mappings":""}
|
|
@@ -1,35 +0,0 @@
|
|
|
1
|
-
import test from "node:test";
|
|
2
|
-
import assert from "node:assert/strict";
|
|
3
|
-
import { transpileRendererSourceToModuleSource, typecheckRendererSnippetIo, unsafeCreateRendererFunction, } from "../../src/jsx/index.js";
|
|
4
|
-
test("transpileRendererSourceToModuleSource returns ESM code", async () => {
|
|
5
|
-
const src = `export default function Renderer(){ return <div>Hello</div>; }`;
|
|
6
|
-
const code = await transpileRendererSourceToModuleSource({ rendererSource: src, syntax: "tsx", sourceFileName: "snippet.tsx" });
|
|
7
|
-
assert.ok(code.includes("export"), "should contain export in transpiled output");
|
|
8
|
-
});
|
|
9
|
-
test("typecheckRendererSnippetIo accepts list component signature", async () => {
|
|
10
|
-
const src = `
|
|
11
|
-
export default function Renderer(props: { map: import("../contracts/render-map.js").CatalogListRenderMap }) {
|
|
12
|
-
return <div>{String(props.map.catalogId)}</div>;
|
|
13
|
-
}
|
|
14
|
-
`;
|
|
15
|
-
const res = await typecheckRendererSnippetIo({ rendererSource: src, syntax: "tsx", role: "list", strict: true });
|
|
16
|
-
assert.equal(res.isValid, true, JSON.stringify(res.errors, null, 2));
|
|
17
|
-
});
|
|
18
|
-
test("typecheckRendererSnippetIo rejects wrong surface I/O", async () => {
|
|
19
|
-
const src = `
|
|
20
|
-
export default function Renderer(props: { map: import("../contracts/render-map.js").CatalogListRenderMap }) {
|
|
21
|
-
return <div>{String(props.map.catalogId)}</div>;
|
|
22
|
-
}
|
|
23
|
-
`;
|
|
24
|
-
const res = await typecheckRendererSnippetIo({ rendererSource: src, syntax: "tsx", role: "item", strict: true });
|
|
25
|
-
assert.equal(res.isValid, false);
|
|
26
|
-
assert.ok(res.errors.length > 0);
|
|
27
|
-
});
|
|
28
|
-
test("unsafeCreateRendererFunction can load module default export", async () => {
|
|
29
|
-
const src = `export default (props) => "ok";`;
|
|
30
|
-
const code = await transpileRendererSourceToModuleSource({ rendererSource: src, syntax: "jsx" });
|
|
31
|
-
const fn = await unsafeCreateRendererFunction({ transpiledModuleSource: code });
|
|
32
|
-
assert.equal(typeof fn, "function");
|
|
33
|
-
assert.equal(fn({}), "ok");
|
|
34
|
-
});
|
|
35
|
-
//# sourceMappingURL=jsx-snippets.test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"jsx-snippets.test.js","sourceRoot":"","sources":["../../../test/unit/jsx-snippets.test.ts"],"names":[],"mappings":"AAAA,OAAO,IAAI,MAAM,WAAW,CAAC;AAC7B,OAAO,MAAM,MAAM,oBAAoB,CAAC;AAExC,OAAO,EACL,qCAAqC,EACrC,0BAA0B,EAC1B,4BAA4B,GAC7B,MAAM,wBAAwB,CAAC;AAEhC,IAAI,CAAC,wDAAwD,EAAE,KAAK,IAAI,EAAE;IACxE,MAAM,GAAG,GAAG,gEAAgE,CAAC;IAC7E,MAAM,IAAI,GAAG,MAAM,qCAAqC,CAAC,EAAE,cAAc,EAAE,GAAG,EAAE,MAAM,EAAE,KAAK,EAAE,cAAc,EAAE,aAAa,EAAE,CAAC,CAAC;IAChI,MAAM,CAAC,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,EAAE,4CAA4C,CAAC,CAAC;AACnF,CAAC,CAAC,CAAC;AAEH,IAAI,CAAC,6DAA6D,EAAE,KAAK,IAAI,EAAE;IAC7E,MAAM,GAAG,GAAG;;;;CAIb,CAAC;IACA,MAAM,GAAG,GAAG,MAAM,0BAA0B,CAAC,EAAE,cAAc,EAAE,GAAG,EAAE,MAAM,EAAE,KAAK,EAAE,IAAI,EAAE,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,CAAC,CAAC;IACjH,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,OAAO,EAAE,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,MAAM,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC;AACvE,CAAC,CAAC,CAAC;AAEH,IAAI,CAAC,sDAAsD,EAAE,KAAK,IAAI,EAAE;IACtE,MAAM,GAAG,GAAG;;;;CAIb,CAAC;IACA,MAAM,GAAG,GAAG,MAAM,0BAA0B,CAAC,EAAE,cAAc,EAAE,GAAG,EAAE,MAAM,EAAE,KAAK,EAAE,IAAI,EAAE,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,CAAC,CAAC;IACjH,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,OAAO,EAAE,KAAK,CAAC,CAAC;IACjC,MAAM,CAAC,EAAE,CAAC,GAAG,CAAC,MAAM,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;AACnC,CAAC,CAAC,CAAC;AAEH,IAAI,CAAC,6DAA6D,EAAE,KAAK,IAAI,EAAE;IAC7E,MAAM,GAAG,GAAG,iCAAiC,CAAC;IAC9C,MAAM,IAAI,GAAG,MAAM,qCAAqC,CAAC,EAAE,cAAc,EAAE,GAAG,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,CAAC;IACjG,MAAM,EAAE,GAAQ,MAAM,4BAA4B,CAAC,EAAE,sBAAsB,EAAE,IAAI,EAAE,CAAC,CAAC;IACrF,MAAM,CAAC,KAAK,CAAC,OAAO,EAAE,EAAE,UAAU,CAAC,CAAC;IACpC,MAAM,CAAC,KAAK,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,IAAI,CAAC,CAAC;AAC7B,CAAC,CAAC,CAAC"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"mapping.test.d.ts","sourceRoot":"","sources":["../../../test/unit/mapping.test.ts"],"names":[],"mappings":""}
|
|
@@ -1,19 +0,0 @@
|
|
|
1
|
-
import test from "node:test";
|
|
2
|
-
import assert from "node:assert/strict";
|
|
3
|
-
import { executeMapping } from "../../src/mapping/execute-mapping.js";
|
|
4
|
-
import { validateMappingSpec } from "../../src/mapping/validate-mapping.js";
|
|
5
|
-
test("validateMappingSpec rejects invalid string mapping", () => {
|
|
6
|
-
const issues = validateMappingSpec(["bad mapping"]);
|
|
7
|
-
assert.equal(issues.length, 1);
|
|
8
|
-
assert.equal(issues[0]?.severity, "error");
|
|
9
|
-
});
|
|
10
|
-
test("executeMapping maps shallow strings and templates", () => {
|
|
11
|
-
const source = { first: "Ada", last: "Lovelace", code: "X" };
|
|
12
|
-
const res = executeMapping(source, [
|
|
13
|
-
"code -> codeCopy",
|
|
14
|
-
{ template: "{first} {last}", to: "display" },
|
|
15
|
-
]);
|
|
16
|
-
assert.equal(res.data.codeCopy, "X");
|
|
17
|
-
assert.equal(res.data.display, "Ada Lovelace");
|
|
18
|
-
});
|
|
19
|
-
//# sourceMappingURL=mapping.test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"mapping.test.js","sourceRoot":"","sources":["../../../test/unit/mapping.test.ts"],"names":[],"mappings":"AAAA,OAAO,IAAI,MAAM,WAAW,CAAC;AAC7B,OAAO,MAAM,MAAM,oBAAoB,CAAC;AAExC,OAAO,EAAE,cAAc,EAAE,MAAM,sCAAsC,CAAC;AACtE,OAAO,EAAE,mBAAmB,EAAE,MAAM,uCAAuC,CAAC;AAE5E,IAAI,CAAC,oDAAoD,EAAE,GAAG,EAAE;IAC9D,MAAM,MAAM,GAAG,mBAAmB,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC;IACpD,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;IAC/B,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,QAAQ,EAAE,OAAO,CAAC,CAAC;AAC7C,CAAC,CAAC,CAAC;AAEH,IAAI,CAAC,mDAAmD,EAAE,GAAG,EAAE;IAC7D,MAAM,MAAM,GAAG,EAAE,KAAK,EAAE,KAAK,EAAE,IAAI,EAAE,UAAU,EAAE,IAAI,EAAE,GAAG,EAAS,CAAC;IACpE,MAAM,GAAG,GAAG,cAAc,CAAC,MAAM,EAAE;QACjC,kBAAkB;QAClB,EAAE,QAAQ,EAAE,gBAAgB,EAAE,EAAE,EAAE,SAAS,EAAE;KAC9C,CAAC,CAAC;IACH,MAAM,CAAC,KAAK,CAAE,GAAG,CAAC,IAAY,CAAC,QAAQ,EAAE,GAAG,CAAC,CAAC;IAC9C,MAAM,CAAC,KAAK,CAAE,GAAG,CAAC,IAAY,CAAC,OAAO,EAAE,cAAc,CAAC,CAAC;AAC1D,CAAC,CAAC,CAAC"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"markdown-and-diagrams.test.d.ts","sourceRoot":"","sources":["../../../test/unit/markdown-and-diagrams.test.ts"],"names":[],"mappings":""}
|
|
@@ -1,62 +0,0 @@
|
|
|
1
|
-
import test from "node:test";
|
|
2
|
-
import assert from "node:assert/strict";
|
|
3
|
-
import { buildCatalogListMarkdownMap, renderCatalogListMarkdown, } from "../../src/markdown/render-list-markdown.js";
|
|
4
|
-
import { buildCatalogItemMarkdownMap, renderCatalogItemMarkdown, } from "../../src/markdown/render-item-markdown.js";
|
|
5
|
-
import { renderCatalogRelationsMermaid } from "../../src/diagrams/render-catalog-diagram.js";
|
|
6
|
-
import { renderItemRelationsMermaid } from "../../src/diagrams/render-item-diagram.js";
|
|
7
|
-
test("list markdown renderer produces a table", () => {
|
|
8
|
-
const map = {
|
|
9
|
-
catalogId: "orders",
|
|
10
|
-
label: "Orders",
|
|
11
|
-
items: [{ itemId: "1", data: { name: "A" }, title: "Order A" }],
|
|
12
|
-
resolvedSources: {},
|
|
13
|
-
filters: { active: {} },
|
|
14
|
-
sort: null,
|
|
15
|
-
pagination: { page: 1, pageSize: 10, hasMore: false },
|
|
16
|
-
selection: [],
|
|
17
|
-
capabilities: { canList: true, canGet: true, canCreate: false, canEdit: false, canDelete: false },
|
|
18
|
-
context: { mode: "view", displayContext: "grid" },
|
|
19
|
-
actions: {},
|
|
20
|
-
};
|
|
21
|
-
const doc = buildCatalogListMarkdownMap(map, { maxRows: 10 });
|
|
22
|
-
const md = renderCatalogListMarkdown(doc);
|
|
23
|
-
assert.ok(md.includes("# Orders"));
|
|
24
|
-
assert.ok(md.includes("| itemId |"));
|
|
25
|
-
assert.ok(md.includes("| 1 |"));
|
|
26
|
-
});
|
|
27
|
-
test("item markdown renderer produces fields table", () => {
|
|
28
|
-
const map = {
|
|
29
|
-
catalogId: "orders",
|
|
30
|
-
itemId: "1",
|
|
31
|
-
item: { data: { name: "A" }, title: "Order A" },
|
|
32
|
-
resolvedSources: {},
|
|
33
|
-
capabilities: { canList: true, canGet: true, canCreate: false, canEdit: false, canDelete: false },
|
|
34
|
-
context: { mode: "view", displayContext: "form" },
|
|
35
|
-
actions: {},
|
|
36
|
-
};
|
|
37
|
-
const doc = buildCatalogItemMarkdownMap(map, {});
|
|
38
|
-
const md = renderCatalogItemMarkdown(doc);
|
|
39
|
-
assert.ok(md.includes("# Order A"));
|
|
40
|
-
assert.ok(md.includes("| field | value |"));
|
|
41
|
-
});
|
|
42
|
-
test("catalog mermaid renderer escapes labels and uses flowchart", () => {
|
|
43
|
-
const mermaid = renderCatalogRelationsMermaid({
|
|
44
|
-
title: "t",
|
|
45
|
-
catalogs: [{ id: "order-statuses", label: "Order Statuses" }],
|
|
46
|
-
relations: [],
|
|
47
|
-
});
|
|
48
|
-
assert.ok(mermaid.startsWith("flowchart LR"));
|
|
49
|
-
assert.ok(mermaid.includes('order_statuses["Order Statuses"]'));
|
|
50
|
-
});
|
|
51
|
-
test("item mermaid renderer outputs edges with labels", () => {
|
|
52
|
-
const mermaid = renderItemRelationsMermaid({
|
|
53
|
-
title: "t",
|
|
54
|
-
items: [
|
|
55
|
-
{ id: "orders:1", label: "Order 1" },
|
|
56
|
-
{ id: "customers:2", label: "Customer 2" },
|
|
57
|
-
],
|
|
58
|
-
relations: [{ from: "orders:1", to: "customers:2", label: "customer" }],
|
|
59
|
-
});
|
|
60
|
-
assert.ok(mermaid.includes('orders_1 -->|"customer"| customers_2'));
|
|
61
|
-
});
|
|
62
|
-
//# sourceMappingURL=markdown-and-diagrams.test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"markdown-and-diagrams.test.js","sourceRoot":"","sources":["../../../test/unit/markdown-and-diagrams.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"native-catalog-merge.test.d.ts","sourceRoot":"","sources":["../../../test/unit/native-catalog-merge.test.ts"],"names":[],"mappings":""}
|
|
@@ -1,33 +0,0 @@
|
|
|
1
|
-
import test from "node:test";
|
|
2
|
-
import assert from "node:assert/strict";
|
|
3
|
-
import { mergeNativePhysicalRows, pickWinningPhysicalRow } from "../../src/catalox/native-catalog-merge.js";
|
|
4
|
-
const compositeIdentity = {
|
|
5
|
-
itemIdStrategy: "composite",
|
|
6
|
-
compositeFields: ["categoryId", "code"],
|
|
7
|
-
};
|
|
8
|
-
function row(scope, data, itemId = "core:S1") {
|
|
9
|
-
return {
|
|
10
|
-
itemId,
|
|
11
|
-
catalogId: "c1",
|
|
12
|
-
data,
|
|
13
|
-
createdAt: "2020-01-01T00:00:00.000Z",
|
|
14
|
-
updatedAt: "2020-01-02T00:00:00.000Z",
|
|
15
|
-
...(scope != null ? { scope } : {}),
|
|
16
|
-
indexed: { scopeLayer: "global" },
|
|
17
|
-
};
|
|
18
|
-
}
|
|
19
|
-
test("mergeNativePhysicalRows overlays user over global by composite identity", () => {
|
|
20
|
-
const g = row({ kind: "global" }, { categoryId: "core", code: "S1", title: "Global" });
|
|
21
|
-
const u = row({ kind: "user", accountId: "a1", userId: "u1" }, { categoryId: "core", code: "S1", title: "User" }, "core:S1");
|
|
22
|
-
u.indexed = { scopeLayer: "user", scopeAccountId: "a1", scopeUserId: "u1" };
|
|
23
|
-
const merged = mergeNativePhysicalRows([g, u], compositeIdentity, "app1", false);
|
|
24
|
-
assert.equal(merged.length, 1);
|
|
25
|
-
assert.equal(merged[0].data.title, "User");
|
|
26
|
-
});
|
|
27
|
-
test("pickWinningPhysicalRow prefers user scoped row", () => {
|
|
28
|
-
const g = row({ kind: "global" }, { x: 1 });
|
|
29
|
-
const u = row({ kind: "user", accountId: "a1", userId: "u1" }, { x: 2 });
|
|
30
|
-
const w = pickWinningPhysicalRow([g, u], { accountId: "a1", userId: "u1" });
|
|
31
|
-
assert.equal(w?.scope?.kind, "user");
|
|
32
|
-
});
|
|
33
|
-
//# sourceMappingURL=native-catalog-merge.test.js.map
|