@dxos/echo-pipeline 0.4.8-next.fff1521 → 0.4.9-main.4fd47cd
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/dist/lib/browser/{chunk-3FVT6KX6.mjs → chunk-WAN2XUWE.mjs} +38 -698
- package/dist/lib/browser/chunk-WAN2XUWE.mjs.map +7 -0
- package/dist/lib/browser/index.mjs +633 -6
- package/dist/lib/browser/index.mjs.map +4 -4
- package/dist/lib/browser/meta.json +1 -1
- package/dist/lib/browser/testing/index.mjs +2 -274
- package/dist/lib/browser/testing/index.mjs.map +4 -4
- package/dist/lib/node/{chunk-WZ4WTAN6.cjs → chunk-U6J2HC4T.cjs} +39 -689
- package/dist/lib/node/chunk-U6J2HC4T.cjs.map +7 -0
- package/dist/lib/node/index.cjs +647 -30
- package/dist/lib/node/index.cjs.map +4 -4
- package/dist/lib/node/meta.json +1 -1
- package/dist/lib/node/testing/index.cjs +12 -282
- package/dist/lib/node/testing/index.cjs.map +4 -4
- package/dist/types/src/space/control-pipeline.d.ts.map +1 -1
- package/dist/types/src/space/data-pipeline.d.ts +0 -1
- package/dist/types/src/space/data-pipeline.d.ts.map +1 -1
- package/dist/types/src/testing/index.d.ts +0 -1
- package/dist/types/src/testing/index.d.ts.map +1 -1
- package/dist/types/src/testing/util.d.ts +2 -6
- package/dist/types/src/testing/util.d.ts.map +1 -1
- package/package.json +33 -33
- package/src/space/control-pipeline.ts +3 -1
- package/src/space/data-pipeline.ts +1 -44
- package/src/testing/index.ts +0 -1
- package/src/testing/util.ts +2 -26
- package/dist/lib/browser/chunk-3FVT6KX6.mjs.map +0 -7
- package/dist/lib/node/chunk-WZ4WTAN6.cjs.map +0 -7
- package/dist/types/src/testing/database-test-rig.d.ts +0 -67
- package/dist/types/src/testing/database-test-rig.d.ts.map +0 -1
- package/dist/types/src/tests/database.test.d.ts +0 -2
- package/dist/types/src/tests/database.test.d.ts.map +0 -1
- package/src/testing/database-test-rig.ts +0 -289
- package/src/tests/database.test.ts +0 -100
|
@@ -18,8 +18,6 @@ var __copyProps = (to, from, except, desc) => {
|
|
|
18
18
|
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
19
19
|
var testing_exports = {};
|
|
20
20
|
__export(testing_exports, {
|
|
21
|
-
DatabaseTestBuilder: () => DatabaseTestBuilder,
|
|
22
|
-
DatabaseTestPeer: () => DatabaseTestPeer,
|
|
23
21
|
MemoryNetworkManagerProvider: () => MemoryNetworkManagerProvider,
|
|
24
22
|
TestAgent: () => TestAgent,
|
|
25
23
|
TestAgentBuilder: () => TestAgentBuilder,
|
|
@@ -27,11 +25,10 @@ __export(testing_exports, {
|
|
|
27
25
|
WebsocketNetworkManagerProvider: () => WebsocketNetworkManagerProvider,
|
|
28
26
|
changeStorageVersionInMetadata: () => changeStorageVersionInMetadata,
|
|
29
27
|
createMemoryDatabase: () => createMemoryDatabase,
|
|
30
|
-
createRemoteDatabaseFromDataServiceHost: () => createRemoteDatabaseFromDataServiceHost,
|
|
31
28
|
testLocalDatabase: () => testLocalDatabase
|
|
32
29
|
});
|
|
33
30
|
module.exports = __toCommonJS(testing_exports);
|
|
34
|
-
var
|
|
31
|
+
var import_chunk_U6J2HC4T = require("../chunk-U6J2HC4T.cjs");
|
|
35
32
|
var import_log = require("@dxos/log");
|
|
36
33
|
var import_protocols = require("@dxos/protocols");
|
|
37
34
|
var import_context = require("@dxos/context");
|
|
@@ -53,18 +50,7 @@ var import_echo_db = require("@dxos/echo-db");
|
|
|
53
50
|
var import_testing2 = require("@dxos/feed-store/testing");
|
|
54
51
|
var import_keys2 = require("@dxos/keys");
|
|
55
52
|
var import_model_factory2 = require("@dxos/model-factory");
|
|
56
|
-
var import_random_access_storage2 = require("@dxos/random-access-storage");
|
|
57
53
|
var import_timeframe = require("@dxos/timeframe");
|
|
58
|
-
var import_async2 = require("@dxos/async");
|
|
59
|
-
var import_document_model3 = require("@dxos/document-model");
|
|
60
|
-
var import_echo_db2 = require("@dxos/echo-db");
|
|
61
|
-
var import_invariant = require("@dxos/invariant");
|
|
62
|
-
var import_keys3 = require("@dxos/keys");
|
|
63
|
-
var import_model_factory3 = require("@dxos/model-factory");
|
|
64
|
-
var import_protocols2 = require("@dxos/protocols");
|
|
65
|
-
var import_text_model = require("@dxos/text-model");
|
|
66
|
-
var import_timeframe2 = require("@dxos/timeframe");
|
|
67
|
-
var import_util2 = require("@dxos/util");
|
|
68
54
|
var __dxlog_file = "/home/runner/work/dxos/dxos/packages/core/echo/echo-pipeline/src/testing/change-metadata.ts";
|
|
69
55
|
var EchoMetadata = import_protocols.schema.getCodecForType("dxos.echo.metadata.EchoMetadata");
|
|
70
56
|
var changeStorageVersionInMetadata = async (storage, version) => {
|
|
@@ -74,7 +60,7 @@ var changeStorageVersionInMetadata = async (storage, version) => {
|
|
|
74
60
|
S: void 0,
|
|
75
61
|
C: (f, a) => f(...a)
|
|
76
62
|
});
|
|
77
|
-
const metadata = new
|
|
63
|
+
const metadata = new import_chunk_U6J2HC4T.MetadataStore(storage.createDirectory("metadata"));
|
|
78
64
|
await metadata.load();
|
|
79
65
|
const echoMetadata = metadata.metadata;
|
|
80
66
|
echoMetadata.version = version;
|
|
@@ -85,7 +71,7 @@ var changeStorageVersionInMetadata = async (storage, version) => {
|
|
|
85
71
|
var TestFeedBuilder = class extends import_testing.TestBuilder {
|
|
86
72
|
constructor() {
|
|
87
73
|
super({
|
|
88
|
-
valueEncoding:
|
|
74
|
+
valueEncoding: import_chunk_U6J2HC4T.valueEncoding
|
|
89
75
|
});
|
|
90
76
|
}
|
|
91
77
|
};
|
|
@@ -129,10 +115,10 @@ var TestAgentBuilder = class {
|
|
|
129
115
|
};
|
|
130
116
|
var TestAgent = class {
|
|
131
117
|
get metadataStore() {
|
|
132
|
-
return this._metadataStore ??= new
|
|
118
|
+
return this._metadataStore ??= new import_chunk_U6J2HC4T.MetadataStore(this.storage.createDirectory("metadata"));
|
|
133
119
|
}
|
|
134
120
|
get snapshotStore() {
|
|
135
|
-
return this._snapshotStore ??= new
|
|
121
|
+
return this._snapshotStore ??= new import_chunk_U6J2HC4T.SnapshotStore(this.storage.createDirectory("snapshots"));
|
|
136
122
|
}
|
|
137
123
|
get blobStore() {
|
|
138
124
|
return this._blobStore ??= new import_teleport_extension_object_sync.BlobStore(this.storage.createDirectory("blobs"));
|
|
@@ -160,7 +146,7 @@ var TestAgent = class {
|
|
|
160
146
|
return this._spaces.get(spaceKey);
|
|
161
147
|
}
|
|
162
148
|
get spaceManager() {
|
|
163
|
-
return this._spaceManager ??= new
|
|
149
|
+
return this._spaceManager ??= new import_chunk_U6J2HC4T.SpaceManager({
|
|
164
150
|
feedStore: this.feedStore,
|
|
165
151
|
networkManager: this._networkManagerProvider(),
|
|
166
152
|
modelFactory: this.modelFactory,
|
|
@@ -198,8 +184,8 @@ var TestAgent = class {
|
|
|
198
184
|
metadata,
|
|
199
185
|
swarmIdentity: {
|
|
200
186
|
peerKey: this.deviceKey,
|
|
201
|
-
credentialProvider:
|
|
202
|
-
credentialAuthenticator:
|
|
187
|
+
credentialProvider: import_chunk_U6J2HC4T.MOCK_AUTH_PROVIDER,
|
|
188
|
+
credentialAuthenticator: import_chunk_U6J2HC4T.MOCK_AUTH_VERIFIER
|
|
203
189
|
},
|
|
204
190
|
memberKey: identityKey,
|
|
205
191
|
onAuthorizedConnection: (session) => {
|
|
@@ -215,12 +201,12 @@ var TestAgent = class {
|
|
|
215
201
|
return space;
|
|
216
202
|
}
|
|
217
203
|
createSpaceProtocol(topic, gossip) {
|
|
218
|
-
return new
|
|
204
|
+
return new import_chunk_U6J2HC4T.SpaceProtocol({
|
|
219
205
|
topic,
|
|
220
206
|
swarmIdentity: {
|
|
221
207
|
peerKey: this.deviceKey,
|
|
222
|
-
credentialProvider:
|
|
223
|
-
credentialAuthenticator:
|
|
208
|
+
credentialProvider: import_chunk_U6J2HC4T.MOCK_AUTH_PROVIDER,
|
|
209
|
+
credentialAuthenticator: import_chunk_U6J2HC4T.MOCK_AUTH_VERIFIER
|
|
224
210
|
},
|
|
225
211
|
networkManager: this._networkManagerProvider(),
|
|
226
212
|
blobStore: this.blobStore,
|
|
@@ -262,7 +248,7 @@ var TestAgent = class {
|
|
|
262
248
|
};
|
|
263
249
|
var createMemoryDatabase = async (modelFactory) => {
|
|
264
250
|
const feed = new import_testing2.MockFeedWriter();
|
|
265
|
-
const backend = new
|
|
251
|
+
const backend = new import_chunk_U6J2HC4T.DatabaseHost(feed, async () => {
|
|
266
252
|
});
|
|
267
253
|
feed.written.on(([data, meta]) => backend.echoProcessor({
|
|
268
254
|
batch: data.batch,
|
|
@@ -284,28 +270,6 @@ var createMemoryDatabase = async (modelFactory) => {
|
|
|
284
270
|
itemManager
|
|
285
271
|
};
|
|
286
272
|
};
|
|
287
|
-
var createRemoteDatabaseFromDataServiceHost = async (modelFactory, dataServiceHost) => {
|
|
288
|
-
const dataServiceSubscriptions = new import_chunk_WZ4WTAN6.DataServiceSubscriptions();
|
|
289
|
-
const automergeHost = new import_chunk_WZ4WTAN6.AutomergeHost({
|
|
290
|
-
directory: (0, import_random_access_storage2.createStorage)({
|
|
291
|
-
type: import_random_access_storage2.StorageType.RAM
|
|
292
|
-
}).createDirectory()
|
|
293
|
-
});
|
|
294
|
-
const dataService = new import_chunk_WZ4WTAN6.DataServiceImpl(dataServiceSubscriptions, automergeHost);
|
|
295
|
-
const spaceKey = import_keys2.PublicKey.random();
|
|
296
|
-
await dataServiceSubscriptions.registerSpace(spaceKey, dataServiceHost);
|
|
297
|
-
const itemManager = new import_echo_db.ItemManager(modelFactory);
|
|
298
|
-
const backend = new import_echo_db.DatabaseProxy({
|
|
299
|
-
service: dataService,
|
|
300
|
-
itemManager,
|
|
301
|
-
spaceKey
|
|
302
|
-
});
|
|
303
|
-
await backend.open(new import_model_factory2.ModelFactory().registerModel(import_document_model2.DocumentModel));
|
|
304
|
-
return {
|
|
305
|
-
itemManager,
|
|
306
|
-
backend
|
|
307
|
-
};
|
|
308
|
-
};
|
|
309
273
|
var testLocalDatabase = async (create, check = create) => {
|
|
310
274
|
const objectId = import_keys2.PublicKey.random().toHex();
|
|
311
275
|
await create.databaseHost.getWriteStream()?.write({
|
|
@@ -322,241 +286,8 @@ var testLocalDatabase = async (create, check = create) => {
|
|
|
322
286
|
});
|
|
323
287
|
await (0, import_async.asyncTimeout)(check.databaseHost._itemDemuxer.mutation.waitForCondition(() => check.itemManager.entities.has(objectId)), 2e3);
|
|
324
288
|
};
|
|
325
|
-
var __dxlog_file2 = "/home/runner/work/dxos/dxos/packages/core/echo/echo-pipeline/src/testing/database-test-rig.ts";
|
|
326
|
-
var SPACE_KEY = import_keys3.PublicKey.random();
|
|
327
|
-
var DatabaseTestBuilder = class {
|
|
328
|
-
constructor() {
|
|
329
|
-
this.peers = new import_util2.ComplexMap(import_keys3.PublicKey.hash);
|
|
330
|
-
}
|
|
331
|
-
async createPeer(spaceKey = SPACE_KEY) {
|
|
332
|
-
const peer = new DatabaseTestPeer(this, spaceKey);
|
|
333
|
-
this.peers.set(peer.key, peer);
|
|
334
|
-
await peer.open();
|
|
335
|
-
return peer;
|
|
336
|
-
}
|
|
337
|
-
};
|
|
338
|
-
var DatabaseTestPeer = class {
|
|
339
|
-
constructor(rig, spaceKey) {
|
|
340
|
-
this.rig = rig;
|
|
341
|
-
this.spaceKey = spaceKey;
|
|
342
|
-
this.modelFactory = new import_model_factory3.ModelFactory().registerModel(import_document_model3.DocumentModel).registerModel(import_text_model.TextModel);
|
|
343
|
-
this.key = import_keys3.PublicKey.random();
|
|
344
|
-
this.feedMessages = [];
|
|
345
|
-
this.snapshots = /* @__PURE__ */ new Map();
|
|
346
|
-
this.confirmed = -1;
|
|
347
|
-
this.timeframe = new import_timeframe2.Timeframe();
|
|
348
|
-
this._onConfirm = new import_async2.Event();
|
|
349
|
-
this._writes = /* @__PURE__ */ new Set();
|
|
350
|
-
}
|
|
351
|
-
async open() {
|
|
352
|
-
this.hostItems = new import_echo_db2.ItemManager(this.modelFactory);
|
|
353
|
-
this.host = new import_chunk_WZ4WTAN6.DatabaseHost({
|
|
354
|
-
write: async (message, { afterWrite }) => {
|
|
355
|
-
const seq = this.feedMessages.push({
|
|
356
|
-
timeframe: this.timeframe,
|
|
357
|
-
payload: {
|
|
358
|
-
data: message
|
|
359
|
-
}
|
|
360
|
-
}) - 1;
|
|
361
|
-
const request = {
|
|
362
|
-
receipt: {
|
|
363
|
-
seq,
|
|
364
|
-
feedKey: this.key
|
|
365
|
-
},
|
|
366
|
-
options: {
|
|
367
|
-
afterWrite
|
|
368
|
-
},
|
|
369
|
-
trigger: new import_async2.Trigger()
|
|
370
|
-
};
|
|
371
|
-
this._writes.add(request);
|
|
372
|
-
await request.trigger.wait();
|
|
373
|
-
return request.receipt;
|
|
374
|
-
}
|
|
375
|
-
}, async () => {
|
|
376
|
-
});
|
|
377
|
-
await this.host.open(this.hostItems, this.modelFactory);
|
|
378
|
-
if (this.snapshot) {
|
|
379
|
-
this.host._itemDemuxer.restoreFromSnapshot(this.snapshot.database);
|
|
380
|
-
}
|
|
381
|
-
this.items = new import_echo_db2.ItemManager(this.modelFactory);
|
|
382
|
-
this.proxy = new import_echo_db2.DatabaseProxy({
|
|
383
|
-
service: this.host.createDataServiceHost({
|
|
384
|
-
deferEvents: false
|
|
385
|
-
}),
|
|
386
|
-
itemManager: this.items,
|
|
387
|
-
spaceKey: this.spaceKey
|
|
388
|
-
});
|
|
389
|
-
await this.proxy.open(this.modelFactory);
|
|
390
|
-
}
|
|
391
|
-
/**
|
|
392
|
-
* Confirm mutations written to the local feed.
|
|
393
|
-
* @param seq Sequence number of the mutation to confirm. If not specified, all mutations will be confirmed.
|
|
394
|
-
*/
|
|
395
|
-
async confirm(seq) {
|
|
396
|
-
this.confirmed = seq ?? this.feedMessages.length - 1;
|
|
397
|
-
this._onConfirm.emit();
|
|
398
|
-
for (const request of [
|
|
399
|
-
...this._writes
|
|
400
|
-
]) {
|
|
401
|
-
if (this.confirmed >= request.receipt.seq) {
|
|
402
|
-
this._writes.delete(request);
|
|
403
|
-
await request.options.afterWrite?.(request.receipt);
|
|
404
|
-
request.trigger.wake();
|
|
405
|
-
}
|
|
406
|
-
}
|
|
407
|
-
this._processMessages(import_timeframe2.Timeframe.merge(this.timeframe, new import_timeframe2.Timeframe([
|
|
408
|
-
[
|
|
409
|
-
this.key,
|
|
410
|
-
this.confirmed
|
|
411
|
-
]
|
|
412
|
-
])));
|
|
413
|
-
}
|
|
414
|
-
/**
|
|
415
|
-
* Replicate the database to the specified timeframe.
|
|
416
|
-
* @param to Timeframe to replicate to. If not specified, the database will be replicated to the latest timeframe (based on all other peers).
|
|
417
|
-
*/
|
|
418
|
-
replicate(to) {
|
|
419
|
-
const toTimeframe = import_timeframe2.Timeframe.merge(to ?? new import_timeframe2.Timeframe(Array.from(this.rig.peers.values()).map((peer) => [
|
|
420
|
-
peer.key,
|
|
421
|
-
peer.confirmed
|
|
422
|
-
])), this.timeframe);
|
|
423
|
-
toTimeframe.set(this.key, this.confirmed);
|
|
424
|
-
this._processMessages(toTimeframe);
|
|
425
|
-
}
|
|
426
|
-
/**
|
|
427
|
-
* Reload data from the feed. Wipes unconfirmed mutations.
|
|
428
|
-
*/
|
|
429
|
-
async reload() {
|
|
430
|
-
await this.open();
|
|
431
|
-
const timeframe = this.timeframe;
|
|
432
|
-
this.timeframe = this.snapshot?.timeframe ?? new import_timeframe2.Timeframe();
|
|
433
|
-
this._processMessages(timeframe);
|
|
434
|
-
}
|
|
435
|
-
/**
|
|
436
|
-
* Create snapshot and use it for the next reload.
|
|
437
|
-
*/
|
|
438
|
-
makeSnapshot() {
|
|
439
|
-
this.snapshot = {
|
|
440
|
-
spaceKey: SPACE_KEY.asUint8Array(),
|
|
441
|
-
database: this.host.createSnapshot(),
|
|
442
|
-
timeframe: this.timeframe
|
|
443
|
-
};
|
|
444
|
-
return this.snapshot;
|
|
445
|
-
}
|
|
446
|
-
createEpoch(mockSnapshot) {
|
|
447
|
-
const snapshot = this.makeSnapshot();
|
|
448
|
-
mockSnapshot && (snapshot.database = mockSnapshot);
|
|
449
|
-
const snapshotCid = import_keys3.PublicKey.from(import_protocols2.schema.getCodecForType("dxos.echo.snapshot.SpaceSnapshot").encode(snapshot)).toHex();
|
|
450
|
-
this.snapshots.set(snapshotCid, snapshot);
|
|
451
|
-
const epoch = {
|
|
452
|
-
previousId: import_keys3.PublicKey.random(),
|
|
453
|
-
timeframe: this.timeframe,
|
|
454
|
-
number: this.currentEpoch ? this.currentEpoch.number + 1 : 0,
|
|
455
|
-
snapshotCid
|
|
456
|
-
};
|
|
457
|
-
this.currentEpoch = epoch;
|
|
458
|
-
this.host._itemDemuxer.restoreFromSnapshot(snapshot.database);
|
|
459
|
-
}
|
|
460
|
-
/**
|
|
461
|
-
* Gets all candidate messages according to the current timeframe.
|
|
462
|
-
* Does not take into account the current snapshot, timeframe dependencies, or the confirmed, or replicated state.
|
|
463
|
-
*/
|
|
464
|
-
_getHeads() {
|
|
465
|
-
return Array.from(this.rig.peers.values()).map((peer) => {
|
|
466
|
-
const seq = this.timeframe.get(peer.key) ?? -1;
|
|
467
|
-
const message = peer.feedMessages[seq + 1];
|
|
468
|
-
return message && {
|
|
469
|
-
feedKey: peer.key,
|
|
470
|
-
seq: seq + 1,
|
|
471
|
-
data: message
|
|
472
|
-
};
|
|
473
|
-
}).filter(import_util2.isNotNullOrUndefined);
|
|
474
|
-
}
|
|
475
|
-
_processMessages(to) {
|
|
476
|
-
let run = true;
|
|
477
|
-
while (run) {
|
|
478
|
-
run = false;
|
|
479
|
-
const heads = this._getHeads();
|
|
480
|
-
for (const candidate of heads) {
|
|
481
|
-
const toSeq = to.get(candidate.feedKey) ?? -1;
|
|
482
|
-
if (toSeq < candidate.seq) {
|
|
483
|
-
continue;
|
|
484
|
-
}
|
|
485
|
-
const snapshotSeq = this.snapshot?.timeframe?.get(candidate.feedKey) ?? -1;
|
|
486
|
-
if (candidate.seq <= snapshotSeq) {
|
|
487
|
-
continue;
|
|
488
|
-
}
|
|
489
|
-
if (!import_timeframe2.Timeframe.dependencies(candidate.data.timeframe, this.timeframe).isEmpty()) {
|
|
490
|
-
continue;
|
|
491
|
-
}
|
|
492
|
-
run = true;
|
|
493
|
-
this.host.echoProcessor({
|
|
494
|
-
batch: candidate.data.payload.data.batch,
|
|
495
|
-
meta: {
|
|
496
|
-
feedKey: candidate.feedKey,
|
|
497
|
-
seq: candidate.seq,
|
|
498
|
-
memberKey: candidate.feedKey,
|
|
499
|
-
timeframe: candidate.data.timeframe
|
|
500
|
-
}
|
|
501
|
-
});
|
|
502
|
-
this.timeframe = import_timeframe2.Timeframe.merge(this.timeframe, new import_timeframe2.Timeframe([
|
|
503
|
-
[
|
|
504
|
-
candidate.feedKey,
|
|
505
|
-
candidate.seq
|
|
506
|
-
]
|
|
507
|
-
]));
|
|
508
|
-
}
|
|
509
|
-
}
|
|
510
|
-
}
|
|
511
|
-
getModel(id) {
|
|
512
|
-
const item = this.items.getItem(id);
|
|
513
|
-
if (!item) {
|
|
514
|
-
return;
|
|
515
|
-
}
|
|
516
|
-
(0, import_invariant.invariant)(item.modelMeta, void 0, {
|
|
517
|
-
F: __dxlog_file2,
|
|
518
|
-
L: 267,
|
|
519
|
-
S: this,
|
|
520
|
-
A: [
|
|
521
|
-
"item.modelMeta",
|
|
522
|
-
""
|
|
523
|
-
]
|
|
524
|
-
});
|
|
525
|
-
const ModelConstructor = this.modelFactory.getModel(item.modelMeta.type)?.constructor;
|
|
526
|
-
(0, import_invariant.invariant)(ModelConstructor, void 0, {
|
|
527
|
-
F: __dxlog_file2,
|
|
528
|
-
L: 269,
|
|
529
|
-
S: this,
|
|
530
|
-
A: [
|
|
531
|
-
"ModelConstructor",
|
|
532
|
-
""
|
|
533
|
-
]
|
|
534
|
-
});
|
|
535
|
-
const model = new ModelConstructor(item.modelMeta, item.id, () => item.state, async (mutation) => {
|
|
536
|
-
(0, import_invariant.invariant)(item.modelMeta, void 0, {
|
|
537
|
-
F: __dxlog_file2,
|
|
538
|
-
L: 276,
|
|
539
|
-
S: this,
|
|
540
|
-
A: [
|
|
541
|
-
"item.modelMeta",
|
|
542
|
-
""
|
|
543
|
-
]
|
|
544
|
-
});
|
|
545
|
-
this.proxy.mutate((0, import_echo_db2.createModelMutation)(id, (0, import_echo_db2.encodeModelMutation)(item.modelMeta, mutation)));
|
|
546
|
-
return {
|
|
547
|
-
feedKey: import_keys3.PublicKey.from("00"),
|
|
548
|
-
seq: 0,
|
|
549
|
-
waitToBeProcessed: () => Promise.resolve()
|
|
550
|
-
};
|
|
551
|
-
});
|
|
552
|
-
model.initialize();
|
|
553
|
-
return model;
|
|
554
|
-
}
|
|
555
|
-
};
|
|
556
289
|
// Annotate the CommonJS export names for ESM import in node:
|
|
557
290
|
0 && (module.exports = {
|
|
558
|
-
DatabaseTestBuilder,
|
|
559
|
-
DatabaseTestPeer,
|
|
560
291
|
MemoryNetworkManagerProvider,
|
|
561
292
|
TestAgent,
|
|
562
293
|
TestAgentBuilder,
|
|
@@ -564,7 +295,6 @@ var DatabaseTestPeer = class {
|
|
|
564
295
|
WebsocketNetworkManagerProvider,
|
|
565
296
|
changeStorageVersionInMetadata,
|
|
566
297
|
createMemoryDatabase,
|
|
567
|
-
createRemoteDatabaseFromDataServiceHost,
|
|
568
298
|
testLocalDatabase
|
|
569
299
|
});
|
|
570
300
|
//# sourceMappingURL=index.cjs.map
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
|
-
"sources": ["../../../../src/testing/change-metadata.ts", "../../../../src/testing/test-agent-builder.ts", "../../../../src/testing/test-feed-builder.ts", "../../../../src/testing/util.ts"
|
|
4
|
-
"sourcesContent": ["//\n// Copyright 2023 DXOS.org\n//\n\nimport { log } from '@dxos/log';\nimport { schema } from '@dxos/protocols';\nimport type { Storage } from '@dxos/random-access-storage';\n\nimport { MetadataStore } from '../metadata';\n\nconst EchoMetadata = schema.getCodecForType('dxos.echo.metadata.EchoMetadata');\n\n/**\n * This function will change the storage version in the metadata.\n * This will break your storage and make it unusable.\n * Use this only for testing purposes.\n */\nexport const changeStorageVersionInMetadata = async (storage: Storage, version: number) => {\n log.info('Changing storage version in metadata. USE ONLY FOR TESTING.');\n const metadata = new MetadataStore(storage.createDirectory('metadata'));\n await metadata.load();\n const echoMetadata = metadata.metadata;\n echoMetadata.version = version;\n const file = metadata._directory.getOrCreateFile('EchoMetadata');\n await metadata._writeFile(file, EchoMetadata, echoMetadata);\n await metadata._directory.flush();\n};\n", "//\n// Copyright 2022 DXOS.org\n//\n\nimport { Context } from '@dxos/context';\nimport { CredentialGenerator } from '@dxos/credentials';\nimport { DocumentModel } from '@dxos/document-model';\nimport { type FeedStore } from '@dxos/feed-store';\nimport { type Keyring } from '@dxos/keyring';\nimport { PublicKey } from '@dxos/keys';\nimport { MemorySignalManager, MemorySignalManagerContext, WebsocketSignalManager } from '@dxos/messaging';\nimport { ModelFactory } from '@dxos/model-factory';\nimport { createSimplePeerTransportFactory, MemoryTransportFactory, NetworkManager } from '@dxos/network-manager';\nimport type { FeedMessage } from '@dxos/protocols/proto/dxos/echo/feed';\nimport { type SpaceMetadata } from '@dxos/protocols/proto/dxos/echo/metadata';\nimport { AdmittedFeed } from '@dxos/protocols/proto/dxos/halo/credentials';\nimport { createStorage, type Storage, StorageType } from '@dxos/random-access-storage';\nimport { Gossip, Presence } from '@dxos/teleport-extension-gossip';\nimport { BlobStore } from '@dxos/teleport-extension-object-sync';\nimport { ComplexMap } from '@dxos/util';\n\nimport { TestFeedBuilder } from './test-feed-builder';\nimport { SnapshotStore } from '../db-host';\nimport { MetadataStore } from '../metadata';\nimport { MOCK_AUTH_PROVIDER, MOCK_AUTH_VERIFIER, type Space, SpaceManager, SpaceProtocol } from '../space';\n\nexport type NetworkManagerProvider = () => NetworkManager;\n\nexport const MemoryNetworkManagerProvider =\n (signalContext: MemorySignalManagerContext): NetworkManagerProvider =>\n () =>\n new NetworkManager({\n signalManager: new MemorySignalManager(signalContext),\n transportFactory: MemoryTransportFactory,\n });\n\nexport const WebsocketNetworkManagerProvider =\n (signalUrl: string): NetworkManagerProvider =>\n () =>\n new NetworkManager({\n signalManager: new WebsocketSignalManager([{ server: signalUrl }]),\n transportFactory: createSimplePeerTransportFactory(),\n });\n\nexport type TestAgentBuilderOptions = {\n storage?: Storage;\n networkManagerProvider?: NetworkManagerProvider;\n};\n\n/**\n * Factory for test agents.\n */\nexport class TestAgentBuilder {\n private readonly _agents = new ComplexMap<PublicKey, TestAgent>(PublicKey.hash);\n private readonly _storage: Storage;\n private readonly _networkManagerProvider: NetworkManagerProvider;\n\n constructor({ storage, networkManagerProvider }: TestAgentBuilderOptions = {}) {\n this._storage = storage ?? createStorage({ type: StorageType.RAM });\n this._networkManagerProvider =\n networkManagerProvider ?? MemoryNetworkManagerProvider(new MemorySignalManagerContext());\n }\n\n async close() {\n return Promise.all(this.agents.map((agent) => agent.close()));\n }\n\n get agents() {\n return Array.from(this._agents.values());\n }\n\n getAgent(deviceKey: PublicKey) {\n return this._agents.get(deviceKey);\n }\n\n async createPeer(): Promise<TestAgent> {\n // prettier-ignore\n const feedBuilder = new TestFeedBuilder()\n .setStorage(this._storage, `agent-${this._agents.size}`);\n\n const identityKey = await feedBuilder.keyring.createKey();\n const deviceKey = await feedBuilder.keyring.createKey();\n\n const agent = new TestAgent(this._networkManagerProvider, feedBuilder, identityKey, deviceKey);\n this._agents.set(deviceKey, agent);\n return agent;\n }\n}\n\n/**\n * Test agent that enables the creation and replication of multiple spaces.\n */\nexport class TestAgent {\n private readonly _spaces = new ComplexMap<PublicKey, Space>(PublicKey.hash);\n\n public readonly storage: Storage;\n public readonly keyring: Keyring;\n public readonly feedStore: FeedStore<FeedMessage>;\n\n private _metadataStore?: MetadataStore;\n get metadataStore() {\n return (this._metadataStore ??= new MetadataStore(this.storage.createDirectory('metadata')));\n }\n\n private _snapshotStore?: SnapshotStore;\n get snapshotStore() {\n return (this._snapshotStore ??= new SnapshotStore(this.storage.createDirectory('snapshots')));\n }\n\n private _blobStore?: BlobStore;\n get blobStore() {\n return (this._blobStore ??= new BlobStore(this.storage.createDirectory('blobs')));\n }\n\n public modelFactory = new ModelFactory().registerModel(DocumentModel);\n\n constructor(\n private readonly _networkManagerProvider: NetworkManagerProvider,\n private readonly _feedBuilder: TestFeedBuilder,\n public readonly identityKey: PublicKey,\n public readonly deviceKey: PublicKey,\n ) {\n this.storage = this._feedBuilder.storage;\n this.keyring = this._feedBuilder.keyring;\n this.feedStore = this._feedBuilder.createFeedStore();\n }\n\n async close() {\n return Promise.all([...this.spaces.map((space) => space.close())]);\n }\n\n get spaces() {\n return Array.from(this._spaces.values());\n }\n\n getSpace(spaceKey: PublicKey) {\n return this._spaces.get(spaceKey);\n }\n\n private _spaceManager?: SpaceManager;\n get spaceManager() {\n return (this._spaceManager ??= new SpaceManager({\n feedStore: this.feedStore,\n networkManager: this._networkManagerProvider(),\n modelFactory: this.modelFactory,\n metadataStore: this.metadataStore,\n snapshotStore: this.snapshotStore,\n blobStore: this.blobStore,\n }));\n }\n\n async createSpace(\n identityKey: PublicKey = this.identityKey,\n spaceKey?: PublicKey,\n genesisKey?: PublicKey,\n dataKey?: PublicKey,\n saveMetadata = false,\n ): Promise<Space> {\n if (!spaceKey) {\n saveMetadata = true;\n spaceKey = await this.keyring.createKey();\n }\n if (!genesisKey) {\n genesisKey = await this.keyring.createKey();\n }\n\n const controlFeed = await this.feedStore.openFeed(genesisKey, { writable: true });\n const dataFeed = await this.feedStore.openFeed(dataKey ?? (await this.keyring.createKey()), {\n writable: true,\n sparse: true,\n });\n\n const metadata: SpaceMetadata = {\n key: spaceKey,\n genesisFeedKey: genesisKey,\n controlFeedKey: controlFeed.key,\n dataFeedKey: dataFeed.key,\n };\n if (saveMetadata) {\n await this.metadataStore.addSpace(metadata);\n }\n\n await this.spaceManager.open();\n const space = await this.spaceManager.constructSpace({\n metadata,\n swarmIdentity: {\n peerKey: this.deviceKey,\n credentialProvider: MOCK_AUTH_PROVIDER,\n credentialAuthenticator: MOCK_AUTH_VERIFIER,\n },\n memberKey: identityKey,\n onAuthorizedConnection: (session) => {\n session.addExtension(\n 'dxos.mesh.teleport.gossip',\n this.createGossip().createExtension({ remotePeerId: session.remotePeerId }),\n );\n },\n });\n await space.setControlFeed(controlFeed);\n await space.setDataFeed(dataFeed);\n\n await space.open(new Context());\n\n this._spaces.set(spaceKey, space);\n return space;\n }\n\n createSpaceProtocol(topic: PublicKey, gossip?: Gossip) {\n return new SpaceProtocol({\n topic,\n swarmIdentity: {\n peerKey: this.deviceKey,\n credentialProvider: MOCK_AUTH_PROVIDER,\n credentialAuthenticator: MOCK_AUTH_VERIFIER,\n },\n networkManager: this._networkManagerProvider(),\n blobStore: this.blobStore,\n onSessionAuth: (session) => {\n session.addExtension(\n 'dxos.mesh.teleport.gossip',\n (gossip ?? this.createGossip()).createExtension({ remotePeerId: session.remotePeerId }),\n );\n },\n });\n }\n\n createGossip() {\n return new Gossip({\n localPeerId: this.deviceKey,\n });\n }\n\n createPresence(gossip?: Gossip) {\n return new Presence({\n announceInterval: 30,\n offlineTimeout: 200,\n identityKey: this.identityKey,\n gossip: gossip ?? this.createGossip(),\n });\n }\n\n async spaceGenesis(space: Space) {\n const generator = new CredentialGenerator(this.keyring, this.identityKey, this.deviceKey);\n const credentials = [\n ...(await generator.createSpaceGenesis(space.key, space.controlFeedKey!)),\n await generator.createFeedAdmission(space.key, space.dataFeedKey!, AdmittedFeed.Designation.DATA),\n await generator.createEpochCredential(space.key),\n ];\n\n for (const credential of credentials) {\n await space.controlPipeline.writer.write({\n credential: { credential },\n });\n }\n }\n}\n", "//\n// Copyright 2022 DXOS.org\n//\n\nimport { TestBuilder } from '@dxos/feed-store/testing';\nimport type { FeedMessage } from '@dxos/protocols/proto/dxos/echo/feed';\n\nimport { valueEncoding } from '../common';\n\n/**\n * Builder with default encoder and generator.\n */\nexport class TestFeedBuilder extends TestBuilder<FeedMessage> {\n constructor() {\n super({\n valueEncoding,\n });\n }\n}\n", "//\n// Copyright 2021 DXOS.org\n//\n\nimport { asyncTimeout } from '@dxos/async';\nimport { DocumentModel } from '@dxos/document-model';\nimport { DatabaseProxy, ItemManager } from '@dxos/echo-db';\nimport { MockFeedWriter } from '@dxos/feed-store/testing';\nimport { PublicKey } from '@dxos/keys';\nimport { ModelFactory } from '@dxos/model-factory';\nimport { type DataMessage } from '@dxos/protocols/proto/dxos/echo/feed';\nimport { StorageType, createStorage } from '@dxos/random-access-storage';\nimport { Timeframe } from '@dxos/timeframe';\n\nimport { AutomergeHost } from '../automerge';\nimport { DatabaseHost, type DataServiceHost, DataServiceImpl, DataServiceSubscriptions } from '../db-host';\nimport { type DataPipeline } from '../space';\n\nexport const createMemoryDatabase = async (modelFactory: ModelFactory) => {\n const feed = new MockFeedWriter<DataMessage>();\n const backend = new DatabaseHost(feed, async () => {\n // No-op.\n });\n\n feed.written.on(([data, meta]) =>\n backend.echoProcessor({\n batch: data.batch,\n meta: {\n ...meta,\n memberKey: PublicKey.random(),\n timeframe: new Timeframe([[meta.feedKey, meta.seq]]),\n },\n }),\n );\n\n const itemManager = new ItemManager(modelFactory);\n await backend.open(itemManager, new ModelFactory().registerModel(DocumentModel));\n return {\n backend,\n itemManager,\n };\n};\n\nexport const createRemoteDatabaseFromDataServiceHost = async (\n modelFactory: ModelFactory,\n dataServiceHost: DataServiceHost,\n) => {\n const dataServiceSubscriptions = new DataServiceSubscriptions();\n const automergeHost = new AutomergeHost({\n directory: createStorage({ type: StorageType.RAM }).createDirectory(),\n });\n const dataService = new DataServiceImpl(dataServiceSubscriptions, automergeHost);\n\n const spaceKey = PublicKey.random();\n await dataServiceSubscriptions.registerSpace(spaceKey, dataServiceHost);\n\n const itemManager = new ItemManager(modelFactory);\n const backend = new DatabaseProxy({ service: dataService, itemManager, spaceKey });\n await backend.open(new ModelFactory().registerModel(DocumentModel));\n return {\n itemManager,\n backend,\n };\n};\n\nexport const testLocalDatabase = async (create: DataPipeline, check: DataPipeline = create) => {\n const objectId = PublicKey.random().toHex();\n await create.databaseHost!.getWriteStream()?.write({\n batch: {\n objects: [\n {\n objectId,\n genesis: {\n modelType: DocumentModel.meta.type,\n },\n },\n ],\n },\n });\n\n await asyncTimeout(\n check.databaseHost!._itemDemuxer.mutation.waitForCondition(() => check.itemManager.entities.has(objectId)),\n 2000,\n );\n};\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport { Event, Trigger } from '@dxos/async';\nimport { DocumentModel } from '@dxos/document-model';\nimport { DatabaseProxy, ItemManager, createModelMutation, encodeModelMutation } from '@dxos/echo-db';\nimport { type WriteOptions, type WriteReceipt } from '@dxos/feed-store';\nimport { invariant } from '@dxos/invariant';\nimport { PublicKey } from '@dxos/keys';\nimport { ModelFactory } from '@dxos/model-factory';\nimport { type FeedMessageBlock, schema } from '@dxos/protocols';\nimport { type FeedMessage } from '@dxos/protocols/proto/dxos/echo/feed';\nimport { type EchoSnapshot, type SpaceSnapshot } from '@dxos/protocols/proto/dxos/echo/snapshot';\nimport { type Epoch } from '@dxos/protocols/proto/dxos/halo/credentials';\nimport { TextModel } from '@dxos/text-model';\nimport { Timeframe } from '@dxos/timeframe';\nimport { ComplexMap, isNotNullOrUndefined } from '@dxos/util';\n\nimport { DatabaseHost } from '../db-host';\n\nconst SPACE_KEY = PublicKey.random();\n\nexport class DatabaseTestBuilder {\n public readonly peers = new ComplexMap<PublicKey, DatabaseTestPeer>(PublicKey.hash);\n\n async createPeer(spaceKey = SPACE_KEY): Promise<DatabaseTestPeer> {\n const peer = new DatabaseTestPeer(this, spaceKey);\n this.peers.set(peer.key, peer);\n await peer.open();\n return peer;\n }\n}\n\ntype WriteRequest = {\n receipt: WriteReceipt;\n options: WriteOptions;\n trigger: Trigger;\n};\n\n// TODO(dmaretskyi): Still used in echo-schema test builder.\n\nexport class DatabaseTestPeer {\n public readonly modelFactory = new ModelFactory().registerModel(DocumentModel).registerModel(TextModel);\n\n public items!: ItemManager;\n public proxy!: DatabaseProxy;\n\n public host!: DatabaseHost;\n public hostItems!: ItemManager;\n\n //\n // Test state.\n //\n\n public readonly key = PublicKey.random();\n\n public feedMessages: FeedMessage[] = [];\n\n public readonly snapshots = new Map<string, SpaceSnapshot>();\n private currentEpoch?: Epoch;\n\n /**\n * Sequence number of the last mutation confirmed to be written to the feed store.\n */\n public confirmed = -1;\n\n /**\n * Current position of the peer's pipeline.\n */\n public timeframe = new Timeframe();\n\n public snapshot: SpaceSnapshot | undefined;\n\n private readonly _onConfirm = new Event();\n\n private readonly _writes = new Set<WriteRequest>();\n\n constructor(\n public readonly rig: DatabaseTestBuilder,\n public readonly spaceKey: PublicKey,\n ) {}\n\n async open() {\n this.hostItems = new ItemManager(this.modelFactory);\n this.host = new DatabaseHost(\n {\n write: async (message, { afterWrite }: WriteOptions) => {\n const seq =\n this.feedMessages.push({\n timeframe: this.timeframe,\n payload: {\n data: message,\n },\n }) - 1;\n\n const request: WriteRequest = {\n receipt: {\n seq,\n feedKey: this.key,\n },\n options: { afterWrite },\n trigger: new Trigger(),\n };\n this._writes.add(request);\n await request.trigger.wait();\n return request.receipt;\n },\n },\n async () => {\n // No-op.\n },\n );\n\n await this.host.open(this.hostItems, this.modelFactory);\n if (this.snapshot) {\n this.host._itemDemuxer.restoreFromSnapshot(this.snapshot.database);\n }\n\n this.items = new ItemManager(this.modelFactory);\n this.proxy = new DatabaseProxy({\n service: this.host.createDataServiceHost({ deferEvents: false }),\n itemManager: this.items,\n spaceKey: this.spaceKey,\n });\n await this.proxy.open(this.modelFactory);\n }\n\n /**\n * Confirm mutations written to the local feed.\n * @param seq Sequence number of the mutation to confirm. If not specified, all mutations will be confirmed.\n */\n async confirm(seq?: number) {\n this.confirmed = seq ?? this.feedMessages.length - 1;\n this._onConfirm.emit();\n\n for (const request of [...this._writes]) {\n if (this.confirmed >= request.receipt.seq) {\n this._writes.delete(request);\n await request.options.afterWrite?.(request.receipt);\n request.trigger.wake();\n }\n }\n\n this._processMessages(Timeframe.merge(this.timeframe, new Timeframe([[this.key, this.confirmed]])));\n }\n\n /**\n * Replicate the database to the specified timeframe.\n * @param to Timeframe to replicate to. If not specified, the database will be replicated to the latest timeframe (based on all other peers).\n */\n replicate(to?: Timeframe) {\n const toTimeframe = Timeframe.merge(\n to ?? new Timeframe(Array.from(this.rig.peers.values()).map((peer) => [peer.key, peer.confirmed])),\n this.timeframe,\n );\n toTimeframe.set(this.key, this.confirmed);\n\n this._processMessages(toTimeframe);\n }\n\n /**\n * Reload data from the feed. Wipes unconfirmed mutations.\n */\n async reload() {\n await this.open();\n const timeframe = this.timeframe;\n this.timeframe = this.snapshot?.timeframe ?? new Timeframe();\n this._processMessages(timeframe);\n }\n\n /**\n * Create snapshot and use it for the next reload.\n */\n makeSnapshot(): SpaceSnapshot {\n this.snapshot = {\n spaceKey: SPACE_KEY.asUint8Array(),\n database: this.host.createSnapshot(),\n timeframe: this.timeframe,\n };\n return this.snapshot;\n }\n\n createEpoch(mockSnapshot?: EchoSnapshot) {\n const snapshot = this.makeSnapshot();\n // Substitute snapshot with the mock one for test purposes (e.g. to test with empty snapshot).\n mockSnapshot && (snapshot.database = mockSnapshot);\n const snapshotCid = PublicKey.from(\n schema.getCodecForType('dxos.echo.snapshot.SpaceSnapshot').encode(snapshot),\n ).toHex();\n this.snapshots.set(snapshotCid, snapshot);\n\n const epoch: Epoch = {\n previousId: PublicKey.random(),\n timeframe: this.timeframe,\n number: this.currentEpoch ? this.currentEpoch.number + 1 : 0,\n snapshotCid,\n };\n\n this.currentEpoch = epoch;\n\n this.host._itemDemuxer.restoreFromSnapshot(snapshot.database);\n }\n\n /**\n * Gets all candidate messages according to the current timeframe.\n * Does not take into account the current snapshot, timeframe dependencies, or the confirmed, or replicated state.\n */\n private _getHeads(): FeedMessageBlock[] {\n return Array.from(this.rig.peers.values())\n .map((peer): FeedMessageBlock => {\n const seq = this.timeframe.get(peer.key) ?? -1;\n const message = peer.feedMessages[seq + 1];\n return (\n message && {\n feedKey: peer.key,\n seq: seq + 1,\n data: message,\n }\n );\n })\n .filter(isNotNullOrUndefined);\n }\n\n private _processMessages(to: Timeframe) {\n let run = true;\n while (run) {\n run = false;\n\n const heads = this._getHeads();\n for (const candidate of heads) {\n const toSeq = to.get(candidate.feedKey) ?? -1;\n if (toSeq < candidate.seq) {\n continue;\n }\n\n const snapshotSeq = this.snapshot?.timeframe?.get(candidate.feedKey) ?? -1;\n if (candidate.seq <= snapshotSeq) {\n continue;\n }\n\n if (!Timeframe.dependencies(candidate.data.timeframe, this.timeframe).isEmpty()) {\n continue;\n }\n\n run = true;\n this.host.echoProcessor({\n batch: candidate.data.payload.data!.batch,\n meta: {\n feedKey: candidate.feedKey,\n seq: candidate.seq,\n memberKey: candidate.feedKey,\n timeframe: candidate.data.timeframe,\n },\n });\n this.timeframe = Timeframe.merge(this.timeframe, new Timeframe([[candidate.feedKey, candidate.seq]]));\n }\n }\n }\n\n getModel(id: string): DocumentModel | TextModel | undefined {\n const item = this.items.getItem(id);\n if (!item) {\n return;\n }\n\n invariant(item.modelMeta);\n const ModelConstructor = this.modelFactory.getModel(item.modelMeta.type)?.constructor;\n invariant(ModelConstructor);\n\n const model = new ModelConstructor(\n item.modelMeta,\n item.id,\n () => item.state,\n async (mutation) => {\n invariant(item.modelMeta);\n this.proxy.mutate(createModelMutation(id, encodeModelMutation(item.modelMeta, mutation)));\n return {\n feedKey: PublicKey.from('00'),\n seq: 0,\n waitToBeProcessed: () => Promise.resolve(),\n };\n },\n );\n model.initialize();\n\n return model;\n }\n}\n"],
|
|
5
|
-
"mappings": "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",
|
|
6
|
-
"names": ["import_credentials", "import_document_model", "import_testing", "import_keys", "import_model_factory", "
|
|
3
|
+
"sources": ["../../../../src/testing/change-metadata.ts", "../../../../src/testing/test-agent-builder.ts", "../../../../src/testing/test-feed-builder.ts", "../../../../src/testing/util.ts"],
|
|
4
|
+
"sourcesContent": ["//\n// Copyright 2023 DXOS.org\n//\n\nimport { log } from '@dxos/log';\nimport { schema } from '@dxos/protocols';\nimport type { Storage } from '@dxos/random-access-storage';\n\nimport { MetadataStore } from '../metadata';\n\nconst EchoMetadata = schema.getCodecForType('dxos.echo.metadata.EchoMetadata');\n\n/**\n * This function will change the storage version in the metadata.\n * This will break your storage and make it unusable.\n * Use this only for testing purposes.\n */\nexport const changeStorageVersionInMetadata = async (storage: Storage, version: number) => {\n log.info('Changing storage version in metadata. USE ONLY FOR TESTING.');\n const metadata = new MetadataStore(storage.createDirectory('metadata'));\n await metadata.load();\n const echoMetadata = metadata.metadata;\n echoMetadata.version = version;\n const file = metadata._directory.getOrCreateFile('EchoMetadata');\n await metadata._writeFile(file, EchoMetadata, echoMetadata);\n await metadata._directory.flush();\n};\n", "//\n// Copyright 2022 DXOS.org\n//\n\nimport { Context } from '@dxos/context';\nimport { CredentialGenerator } from '@dxos/credentials';\nimport { DocumentModel } from '@dxos/document-model';\nimport { type FeedStore } from '@dxos/feed-store';\nimport { type Keyring } from '@dxos/keyring';\nimport { PublicKey } from '@dxos/keys';\nimport { MemorySignalManager, MemorySignalManagerContext, WebsocketSignalManager } from '@dxos/messaging';\nimport { ModelFactory } from '@dxos/model-factory';\nimport { createSimplePeerTransportFactory, MemoryTransportFactory, NetworkManager } from '@dxos/network-manager';\nimport type { FeedMessage } from '@dxos/protocols/proto/dxos/echo/feed';\nimport { type SpaceMetadata } from '@dxos/protocols/proto/dxos/echo/metadata';\nimport { AdmittedFeed } from '@dxos/protocols/proto/dxos/halo/credentials';\nimport { createStorage, type Storage, StorageType } from '@dxos/random-access-storage';\nimport { Gossip, Presence } from '@dxos/teleport-extension-gossip';\nimport { BlobStore } from '@dxos/teleport-extension-object-sync';\nimport { ComplexMap } from '@dxos/util';\n\nimport { TestFeedBuilder } from './test-feed-builder';\nimport { SnapshotStore } from '../db-host';\nimport { MetadataStore } from '../metadata';\nimport { MOCK_AUTH_PROVIDER, MOCK_AUTH_VERIFIER, type Space, SpaceManager, SpaceProtocol } from '../space';\n\nexport type NetworkManagerProvider = () => NetworkManager;\n\nexport const MemoryNetworkManagerProvider =\n (signalContext: MemorySignalManagerContext): NetworkManagerProvider =>\n () =>\n new NetworkManager({\n signalManager: new MemorySignalManager(signalContext),\n transportFactory: MemoryTransportFactory,\n });\n\nexport const WebsocketNetworkManagerProvider =\n (signalUrl: string): NetworkManagerProvider =>\n () =>\n new NetworkManager({\n signalManager: new WebsocketSignalManager([{ server: signalUrl }]),\n transportFactory: createSimplePeerTransportFactory(),\n });\n\nexport type TestAgentBuilderOptions = {\n storage?: Storage;\n networkManagerProvider?: NetworkManagerProvider;\n};\n\n/**\n * Factory for test agents.\n */\nexport class TestAgentBuilder {\n private readonly _agents = new ComplexMap<PublicKey, TestAgent>(PublicKey.hash);\n private readonly _storage: Storage;\n private readonly _networkManagerProvider: NetworkManagerProvider;\n\n constructor({ storage, networkManagerProvider }: TestAgentBuilderOptions = {}) {\n this._storage = storage ?? createStorage({ type: StorageType.RAM });\n this._networkManagerProvider =\n networkManagerProvider ?? MemoryNetworkManagerProvider(new MemorySignalManagerContext());\n }\n\n async close() {\n return Promise.all(this.agents.map((agent) => agent.close()));\n }\n\n get agents() {\n return Array.from(this._agents.values());\n }\n\n getAgent(deviceKey: PublicKey) {\n return this._agents.get(deviceKey);\n }\n\n async createPeer(): Promise<TestAgent> {\n // prettier-ignore\n const feedBuilder = new TestFeedBuilder()\n .setStorage(this._storage, `agent-${this._agents.size}`);\n\n const identityKey = await feedBuilder.keyring.createKey();\n const deviceKey = await feedBuilder.keyring.createKey();\n\n const agent = new TestAgent(this._networkManagerProvider, feedBuilder, identityKey, deviceKey);\n this._agents.set(deviceKey, agent);\n return agent;\n }\n}\n\n/**\n * Test agent that enables the creation and replication of multiple spaces.\n */\nexport class TestAgent {\n private readonly _spaces = new ComplexMap<PublicKey, Space>(PublicKey.hash);\n\n public readonly storage: Storage;\n public readonly keyring: Keyring;\n public readonly feedStore: FeedStore<FeedMessage>;\n\n private _metadataStore?: MetadataStore;\n get metadataStore() {\n return (this._metadataStore ??= new MetadataStore(this.storage.createDirectory('metadata')));\n }\n\n private _snapshotStore?: SnapshotStore;\n get snapshotStore() {\n return (this._snapshotStore ??= new SnapshotStore(this.storage.createDirectory('snapshots')));\n }\n\n private _blobStore?: BlobStore;\n get blobStore() {\n return (this._blobStore ??= new BlobStore(this.storage.createDirectory('blobs')));\n }\n\n public modelFactory = new ModelFactory().registerModel(DocumentModel);\n\n constructor(\n private readonly _networkManagerProvider: NetworkManagerProvider,\n private readonly _feedBuilder: TestFeedBuilder,\n public readonly identityKey: PublicKey,\n public readonly deviceKey: PublicKey,\n ) {\n this.storage = this._feedBuilder.storage;\n this.keyring = this._feedBuilder.keyring;\n this.feedStore = this._feedBuilder.createFeedStore();\n }\n\n async close() {\n return Promise.all([...this.spaces.map((space) => space.close())]);\n }\n\n get spaces() {\n return Array.from(this._spaces.values());\n }\n\n getSpace(spaceKey: PublicKey) {\n return this._spaces.get(spaceKey);\n }\n\n private _spaceManager?: SpaceManager;\n get spaceManager() {\n return (this._spaceManager ??= new SpaceManager({\n feedStore: this.feedStore,\n networkManager: this._networkManagerProvider(),\n modelFactory: this.modelFactory,\n metadataStore: this.metadataStore,\n snapshotStore: this.snapshotStore,\n blobStore: this.blobStore,\n }));\n }\n\n async createSpace(\n identityKey: PublicKey = this.identityKey,\n spaceKey?: PublicKey,\n genesisKey?: PublicKey,\n dataKey?: PublicKey,\n saveMetadata = false,\n ): Promise<Space> {\n if (!spaceKey) {\n saveMetadata = true;\n spaceKey = await this.keyring.createKey();\n }\n if (!genesisKey) {\n genesisKey = await this.keyring.createKey();\n }\n\n const controlFeed = await this.feedStore.openFeed(genesisKey, { writable: true });\n const dataFeed = await this.feedStore.openFeed(dataKey ?? (await this.keyring.createKey()), {\n writable: true,\n sparse: true,\n });\n\n const metadata: SpaceMetadata = {\n key: spaceKey,\n genesisFeedKey: genesisKey,\n controlFeedKey: controlFeed.key,\n dataFeedKey: dataFeed.key,\n };\n if (saveMetadata) {\n await this.metadataStore.addSpace(metadata);\n }\n\n await this.spaceManager.open();\n const space = await this.spaceManager.constructSpace({\n metadata,\n swarmIdentity: {\n peerKey: this.deviceKey,\n credentialProvider: MOCK_AUTH_PROVIDER,\n credentialAuthenticator: MOCK_AUTH_VERIFIER,\n },\n memberKey: identityKey,\n onAuthorizedConnection: (session) => {\n session.addExtension(\n 'dxos.mesh.teleport.gossip',\n this.createGossip().createExtension({ remotePeerId: session.remotePeerId }),\n );\n },\n });\n await space.setControlFeed(controlFeed);\n await space.setDataFeed(dataFeed);\n\n await space.open(new Context());\n\n this._spaces.set(spaceKey, space);\n return space;\n }\n\n createSpaceProtocol(topic: PublicKey, gossip?: Gossip) {\n return new SpaceProtocol({\n topic,\n swarmIdentity: {\n peerKey: this.deviceKey,\n credentialProvider: MOCK_AUTH_PROVIDER,\n credentialAuthenticator: MOCK_AUTH_VERIFIER,\n },\n networkManager: this._networkManagerProvider(),\n blobStore: this.blobStore,\n onSessionAuth: (session) => {\n session.addExtension(\n 'dxos.mesh.teleport.gossip',\n (gossip ?? this.createGossip()).createExtension({ remotePeerId: session.remotePeerId }),\n );\n },\n });\n }\n\n createGossip() {\n return new Gossip({\n localPeerId: this.deviceKey,\n });\n }\n\n createPresence(gossip?: Gossip) {\n return new Presence({\n announceInterval: 30,\n offlineTimeout: 200,\n identityKey: this.identityKey,\n gossip: gossip ?? this.createGossip(),\n });\n }\n\n async spaceGenesis(space: Space) {\n const generator = new CredentialGenerator(this.keyring, this.identityKey, this.deviceKey);\n const credentials = [\n ...(await generator.createSpaceGenesis(space.key, space.controlFeedKey!)),\n await generator.createFeedAdmission(space.key, space.dataFeedKey!, AdmittedFeed.Designation.DATA),\n await generator.createEpochCredential(space.key),\n ];\n\n for (const credential of credentials) {\n await space.controlPipeline.writer.write({\n credential: { credential },\n });\n }\n }\n}\n", "//\n// Copyright 2022 DXOS.org\n//\n\nimport { TestBuilder } from '@dxos/feed-store/testing';\nimport type { FeedMessage } from '@dxos/protocols/proto/dxos/echo/feed';\n\nimport { valueEncoding } from '../common';\n\n/**\n * Builder with default encoder and generator.\n */\nexport class TestFeedBuilder extends TestBuilder<FeedMessage> {\n constructor() {\n super({\n valueEncoding,\n });\n }\n}\n", "//\n// Copyright 2021 DXOS.org\n//\n\nimport { asyncTimeout } from '@dxos/async';\nimport { DocumentModel } from '@dxos/document-model';\nimport { ItemManager } from '@dxos/echo-db';\nimport { MockFeedWriter } from '@dxos/feed-store/testing';\nimport { PublicKey } from '@dxos/keys';\nimport { ModelFactory } from '@dxos/model-factory';\nimport { type DataMessage } from '@dxos/protocols/proto/dxos/echo/feed';\nimport { Timeframe } from '@dxos/timeframe';\n\nimport { DatabaseHost } from '../db-host';\nimport { type DataPipeline } from '../space';\n\nexport const createMemoryDatabase = async (modelFactory: ModelFactory) => {\n const feed = new MockFeedWriter<DataMessage>();\n const backend = new DatabaseHost(feed, async () => {\n // No-op.\n });\n\n feed.written.on(([data, meta]) =>\n backend.echoProcessor({\n batch: data.batch,\n meta: {\n ...meta,\n memberKey: PublicKey.random(),\n timeframe: new Timeframe([[meta.feedKey, meta.seq]]),\n },\n }),\n );\n\n const itemManager = new ItemManager(modelFactory);\n await backend.open(itemManager, new ModelFactory().registerModel(DocumentModel));\n return {\n backend,\n itemManager,\n };\n};\n\nexport const testLocalDatabase = async (create: DataPipeline, check: DataPipeline = create) => {\n const objectId = PublicKey.random().toHex();\n await create.databaseHost!.getWriteStream()?.write({\n batch: {\n objects: [\n {\n objectId,\n genesis: {\n modelType: DocumentModel.meta.type,\n },\n },\n ],\n },\n });\n\n await asyncTimeout(\n check.databaseHost!._itemDemuxer.mutation.waitForCondition(() => check.itemManager.entities.has(objectId)),\n 2000,\n );\n};\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": ["import_credentials", "import_document_model", "import_testing", "import_keys", "import_model_factory", "EchoMetadata", "schema", "getCodecForType", "changeStorageVersionInMetadata", "storage", "version", "log", "info", "metadata", "MetadataStore", "createDirectory", "load", "echoMetadata", "file", "_directory", "getOrCreateFile", "_writeFile", "flush", "TestFeedBuilder", "TestBuilder", "constructor", "valueEncoding", "MemoryNetworkManagerProvider", "signalContext", "NetworkManager", "signalManager", "MemorySignalManager", "transportFactory", "MemoryTransportFactory", "WebsocketNetworkManagerProvider", "signalUrl", "WebsocketSignalManager", "server", "createSimplePeerTransportFactory", "TestAgentBuilder", "networkManagerProvider", "_agents", "ComplexMap", "PublicKey", "hash", "_storage", "createStorage", "type", "StorageType", "RAM", "_networkManagerProvider", "MemorySignalManagerContext", "close", "Promise", "all", "agents", "map", "agent", "Array", "from", "values", "getAgent", "deviceKey", "get", "createPeer", "feedBuilder", "setStorage", "size", "identityKey", "keyring", "createKey", "TestAgent", "set", "metadataStore", "_metadataStore", "snapshotStore", "_snapshotStore", "SnapshotStore", "blobStore", "_blobStore", "BlobStore", "_feedBuilder", "_spaces", "modelFactory", "ModelFactory", "registerModel", "DocumentModel", "feedStore", "createFeedStore", "spaces", "space", "getSpace", "spaceKey", "spaceManager", "_spaceManager", "SpaceManager", "networkManager", "createSpace", "genesisKey", "dataKey", "saveMetadata", "controlFeed", "openFeed", "writable", "dataFeed", "sparse", "key", "genesisFeedKey", "controlFeedKey", "dataFeedKey", "addSpace", "open", "constructSpace", "swarmIdentity", "peerKey", "credentialProvider", "MOCK_AUTH_PROVIDER", "credentialAuthenticator", "MOCK_AUTH_VERIFIER", "memberKey", "onAuthorizedConnection", "session", "addExtension", "createGossip", "createExtension", "remotePeerId", "setControlFeed", "setDataFeed", "Context", "createSpaceProtocol", "topic", "gossip", "SpaceProtocol", "onSessionAuth", "Gossip", "localPeerId", "createPresence", "Presence", "announceInterval", "offlineTimeout", "spaceGenesis", "generator", "CredentialGenerator", "credentials", "createSpaceGenesis", "createFeedAdmission", "AdmittedFeed", "Designation", "DATA", "createEpochCredential", "credential", "controlPipeline", "writer", "write", "createMemoryDatabase", "feed", "MockFeedWriter", "backend", "DatabaseHost", "written", "on", "data", "meta", "echoProcessor", "batch", "random", "timeframe", "Timeframe", "feedKey", "seq", "itemManager", "ItemManager", "testLocalDatabase", "create", "check", "objectId", "toHex", "databaseHost", "getWriteStream", "objects", "genesis", "modelType", "asyncTimeout", "_itemDemuxer", "mutation", "waitForCondition", "entities", "has"]
|
|
7
7
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"control-pipeline.d.ts","sourceRoot":"","sources":["../../../../src/space/control-pipeline.ts"],"names":[],"mappings":"AAMA,OAAO,EAAqB,KAAK,UAAU,EAAE,KAAK,UAAU,EAAE,KAAK,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AACvG,OAAO,EAAE,KAAK,WAAW,EAAE,MAAM,kBAAkB,CAAC;AACpD,OAAO,EAAE,SAAS,EAAE,MAAM,YAAY,CAAC;AAGvC,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,sCAAsC,CAAC;AAExE,OAAO,EAAgB,KAAK,UAAU,EAAE,MAAM,6CAA6C,CAAC;AAG5F,OAAO,EAAE,KAAK,aAAa,EAAE,QAAQ,EAAU,MAAM,YAAY,CAAC;AAElE,OAAO,EAAE,KAAK,aAAa,EAAE,MAAM,aAAa,CAAC;AACjD,OAAO,EAAY,KAAK,gBAAgB,EAAE,MAAM,aAAa,CAAC;AAE9D,MAAM,MAAM,qBAAqB,GAAG;IAClC,QAAQ,EAAE,SAAS,CAAC;IACpB,WAAW,EAAE,WAAW,CAAC,WAAW,CAAC,CAAC;IACtC,YAAY,EAAE,CAAC,OAAO,EAAE,SAAS,KAAK,OAAO,CAAC,WAAW,CAAC,WAAW,CAAC,CAAC,CAAC;IACxE,aAAa,EAAE,aAAa,CAAC;CAC9B,CAAC;AAQF;;GAEG;AACH,qBAEa,eAAe;IAC1B,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAiB;IACtC,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAW;IACrC,OAAO,CAAC,QAAQ,CAAC,kBAAkB,CAAoB;IAEvD,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAY;IACtC,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAgB;IAC1C,OAAO,CAAC,gBAAgB,CAAC,CAAY;IACrC,OAAO,CAAC,sBAAsB,CAAsB;IAEpD,SAAgB,cAAc,oCAA2C;IACzE,SAAgB,gBAAgB,EAAE,QAAQ,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC,CAAC;IACtE,SAAgB,qBAAqB,EAAE,QAAQ,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC,CAAC;IAG3E,OAAO,CAAC,MAAM,CAA0B;IAGxC,OAAO,CAAC,UAAU,CAA2B;IAE7C,OAAO,CAAC,aAAa,CAGlB;gBAES,EAAE,QAAQ,EAAE,WAAW,EAAE,YAAY,EAAE,aAAa,EAAE,EAAE,qBAAqB;
|
|
1
|
+
{"version":3,"file":"control-pipeline.d.ts","sourceRoot":"","sources":["../../../../src/space/control-pipeline.ts"],"names":[],"mappings":"AAMA,OAAO,EAAqB,KAAK,UAAU,EAAE,KAAK,UAAU,EAAE,KAAK,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AACvG,OAAO,EAAE,KAAK,WAAW,EAAE,MAAM,kBAAkB,CAAC;AACpD,OAAO,EAAE,SAAS,EAAE,MAAM,YAAY,CAAC;AAGvC,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,sCAAsC,CAAC;AAExE,OAAO,EAAgB,KAAK,UAAU,EAAE,MAAM,6CAA6C,CAAC;AAG5F,OAAO,EAAE,KAAK,aAAa,EAAE,QAAQ,EAAU,MAAM,YAAY,CAAC;AAElE,OAAO,EAAE,KAAK,aAAa,EAAE,MAAM,aAAa,CAAC;AACjD,OAAO,EAAY,KAAK,gBAAgB,EAAE,MAAM,aAAa,CAAC;AAE9D,MAAM,MAAM,qBAAqB,GAAG;IAClC,QAAQ,EAAE,SAAS,CAAC;IACpB,WAAW,EAAE,WAAW,CAAC,WAAW,CAAC,CAAC;IACtC,YAAY,EAAE,CAAC,OAAO,EAAE,SAAS,KAAK,OAAO,CAAC,WAAW,CAAC,WAAW,CAAC,CAAC,CAAC;IACxE,aAAa,EAAE,aAAa,CAAC;CAC9B,CAAC;AAQF;;GAEG;AACH,qBAEa,eAAe;IAC1B,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAiB;IACtC,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAW;IACrC,OAAO,CAAC,QAAQ,CAAC,kBAAkB,CAAoB;IAEvD,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAY;IACtC,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAgB;IAC1C,OAAO,CAAC,gBAAgB,CAAC,CAAY;IACrC,OAAO,CAAC,sBAAsB,CAAsB;IAEpD,SAAgB,cAAc,oCAA2C;IACzE,SAAgB,gBAAgB,EAAE,QAAQ,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC,CAAC;IACtE,SAAgB,qBAAqB,EAAE,QAAQ,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC,CAAC;IAG3E,OAAO,CAAC,MAAM,CAA0B;IAGxC,OAAO,CAAC,UAAU,CAA2B;IAE7C,OAAO,CAAC,aAAa,CAGlB;gBAES,EAAE,QAAQ,EAAE,WAAW,EAAE,YAAY,EAAE,aAAa,EAAE,EAAE,qBAAqB;IAgCzF,IAAI,UAAU,IAAI,UAAU,CAE3B;IAED,IAAI,QAAQ,IAAI,gBAAgB,CAE/B;IAEK,YAAY,CAAC,IAAI,EAAE,WAAW,CAAC,WAAW,CAAC;IAM3C,KAAK;YAgBG,gBAAgB;YAehB,aAAa;YAgBb,gBAAgB;YAgBhB,eAAe;YAoBf,wBAAwB;IAUhC,IAAI;YAQI,oBAAoB;CASnC"}
|
|
@@ -68,7 +68,6 @@ export declare class DataPipeline implements CredentialProcessor {
|
|
|
68
68
|
private _consumePipeline;
|
|
69
69
|
private _createSnapshot;
|
|
70
70
|
private _saveTargetTimeframe;
|
|
71
|
-
private _saveCache;
|
|
72
71
|
private _noteTargetStateIfNeeded;
|
|
73
72
|
private _processEpochInSeparateTask;
|
|
74
73
|
private _processEpoch;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"data-pipeline.d.ts","sourceRoot":"","sources":["../../../../src/space/data-pipeline.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,KAAK,EAAiD,MAAM,aAAa,CAAC;AAEnF,OAAO,EACL,KAAK,mBAAmB,EACxB,KAAK,QAAQ,EACb,KAAK,kBAAkB,EAExB,MAAM,mBAAmB,CAAC;AAC3B,OAAO,
|
|
1
|
+
{"version":3,"file":"data-pipeline.d.ts","sourceRoot":"","sources":["../../../../src/space/data-pipeline.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/testing/index.ts"],"names":[],"mappings":"AAIA,cAAc,mBAAmB,CAAC;AAClC,cAAc,sBAAsB,CAAC;AACrC,cAAc,qBAAqB,CAAC;AACpC,cAAc,QAAQ,CAAC
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/testing/index.ts"],"names":[],"mappings":"AAIA,cAAc,mBAAmB,CAAC;AAClC,cAAc,sBAAsB,CAAC;AACrC,cAAc,qBAAqB,CAAC;AACpC,cAAc,QAAQ,CAAC"}
|
|
@@ -1,14 +1,10 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { ItemManager } from '@dxos/echo-db';
|
|
2
2
|
import { ModelFactory } from '@dxos/model-factory';
|
|
3
|
-
import { DatabaseHost
|
|
3
|
+
import { DatabaseHost } from '../db-host';
|
|
4
4
|
import { type DataPipeline } from '../space';
|
|
5
5
|
export declare const createMemoryDatabase: (modelFactory: ModelFactory) => Promise<{
|
|
6
6
|
backend: DatabaseHost;
|
|
7
7
|
itemManager: ItemManager;
|
|
8
8
|
}>;
|
|
9
|
-
export declare const createRemoteDatabaseFromDataServiceHost: (modelFactory: ModelFactory, dataServiceHost: DataServiceHost) => Promise<{
|
|
10
|
-
itemManager: ItemManager;
|
|
11
|
-
backend: DatabaseProxy;
|
|
12
|
-
}>;
|
|
13
9
|
export declare const testLocalDatabase: (create: DataPipeline, check?: DataPipeline) => Promise<void>;
|
|
14
10
|
//# sourceMappingURL=util.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"util.d.ts","sourceRoot":"","sources":["../../../../src/testing/util.ts"],"names":[],"mappings":"AAMA,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"util.d.ts","sourceRoot":"","sources":["../../../../src/testing/util.ts"],"names":[],"mappings":"AAMA,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAG5C,OAAO,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAC;AAInD,OAAO,EAAE,YAAY,EAAE,MAAM,YAAY,CAAC;AAC1C,OAAO,EAAE,KAAK,YAAY,EAAE,MAAM,UAAU,CAAC;AAE7C,eAAO,MAAM,oBAAoB,iBAAwB,YAAY;;;EAuBpE,CAAC;AAEF,eAAO,MAAM,iBAAiB,WAAkB,YAAY,UAAS,YAAY,kBAmBhF,CAAC"}
|