cojson 0.10.8 → 0.11.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/.turbo/turbo-build.log +1 -1
- package/CHANGELOG.md +20 -0
- package/dist/CoValuesStore.d.ts +12 -0
- package/dist/CoValuesStore.d.ts.map +1 -0
- package/dist/PeerKnownStates.d.ts +38 -0
- package/dist/PeerKnownStates.d.ts.map +1 -0
- package/dist/PeerState.d.ts +46 -0
- package/dist/PeerState.d.ts.map +1 -0
- package/dist/PriorityBasedMessageQueue.d.ts +18 -0
- package/dist/PriorityBasedMessageQueue.d.ts.map +1 -0
- package/dist/SyncStateManager.d.ts +20 -0
- package/dist/SyncStateManager.d.ts.map +1 -0
- package/dist/base64url.d.ts +3 -0
- package/dist/base64url.d.ts.map +1 -0
- package/dist/base64url.test.d.ts +2 -0
- package/dist/base64url.test.d.ts.map +1 -0
- package/dist/coValue.d.ts +52 -0
- package/dist/coValue.d.ts.map +1 -0
- package/dist/coValueCore.d.ts +143 -0
- package/dist/coValueCore.d.ts.map +1 -0
- package/dist/coValueCore.js +3 -9
- package/dist/coValueCore.js.map +1 -1
- package/dist/coValueState.d.ts +58 -0
- package/dist/coValueState.d.ts.map +1 -0
- package/dist/coValues/account.d.ts +69 -0
- package/dist/coValues/account.d.ts.map +1 -0
- package/dist/coValues/account.js +9 -10
- package/dist/coValues/account.js.map +1 -1
- package/dist/coValues/coList.d.ts +163 -0
- package/dist/coValues/coList.d.ts.map +1 -0
- package/dist/coValues/coMap.d.ts +142 -0
- package/dist/coValues/coMap.d.ts.map +1 -0
- package/dist/coValues/coPlainText.d.ts +33 -0
- package/dist/coValues/coPlainText.d.ts.map +1 -0
- package/dist/coValues/coStream.d.ts +109 -0
- package/dist/coValues/coStream.d.ts.map +1 -0
- package/dist/coValues/group.d.ts +143 -0
- package/dist/coValues/group.d.ts.map +1 -0
- package/dist/coValues/group.js +52 -6
- package/dist/coValues/group.js.map +1 -1
- package/dist/coreToCoValue.d.ts +15 -0
- package/dist/coreToCoValue.d.ts.map +1 -0
- package/dist/crypto/PureJSCrypto.d.ts +50 -0
- package/dist/crypto/PureJSCrypto.d.ts.map +1 -0
- package/dist/crypto/WasmCrypto.d.ts +49 -0
- package/dist/crypto/WasmCrypto.d.ts.map +1 -0
- package/dist/crypto/crypto.d.ts +142 -0
- package/dist/crypto/crypto.d.ts.map +1 -0
- package/dist/exports.d.ts +84 -0
- package/dist/exports.d.ts.map +1 -0
- package/dist/ids.d.ts +23 -0
- package/dist/ids.d.ts.map +1 -0
- package/dist/index.d.ts +2 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/jsonStringify.d.ts +7 -0
- package/dist/jsonStringify.d.ts.map +1 -0
- package/dist/jsonValue.d.ts +45 -0
- package/dist/jsonValue.d.ts.map +1 -0
- package/dist/localNode.d.ts +111 -0
- package/dist/localNode.d.ts.map +1 -0
- package/dist/localNode.js +3 -5
- package/dist/localNode.js.map +1 -1
- package/dist/logger.d.ts +33 -0
- package/dist/logger.d.ts.map +1 -0
- package/dist/media.d.ts +8 -0
- package/dist/media.d.ts.map +1 -0
- package/dist/permissions.d.ts +24 -0
- package/dist/permissions.d.ts.map +1 -0
- package/dist/permissions.js +5 -9
- package/dist/permissions.js.map +1 -1
- package/dist/priority.d.ts +19 -0
- package/dist/priority.d.ts.map +1 -0
- package/dist/storage/FileSystem.d.ts +37 -0
- package/dist/storage/FileSystem.d.ts.map +1 -0
- package/dist/storage/chunksAndKnownStates.d.ts +7 -0
- package/dist/storage/chunksAndKnownStates.d.ts.map +1 -0
- package/dist/storage/index.d.ts +52 -0
- package/dist/storage/index.d.ts.map +1 -0
- package/dist/streamUtils.d.ts +13 -0
- package/dist/streamUtils.d.ts.map +1 -0
- package/dist/sync.d.ts +97 -0
- package/dist/sync.d.ts.map +1 -0
- package/dist/tests/PeerKnownStates.test.d.ts +2 -0
- package/dist/tests/PeerKnownStates.test.d.ts.map +1 -0
- package/dist/tests/PeerKnownStates.test.js +82 -0
- package/dist/tests/PeerKnownStates.test.js.map +1 -0
- package/dist/tests/PeerState.test.d.ts +2 -0
- package/dist/tests/PeerState.test.d.ts.map +1 -0
- package/dist/tests/PeerState.test.js +188 -0
- package/dist/tests/PeerState.test.js.map +1 -0
- package/dist/tests/PriorityBasedMessageQueue.test.d.ts +2 -0
- package/dist/tests/PriorityBasedMessageQueue.test.d.ts.map +1 -0
- package/dist/tests/PriorityBasedMessageQueue.test.js +120 -0
- package/dist/tests/PriorityBasedMessageQueue.test.js.map +1 -0
- package/dist/tests/SyncStateManager.test.d.ts +2 -0
- package/dist/tests/SyncStateManager.test.d.ts.map +1 -0
- package/dist/tests/SyncStateManager.test.js +127 -0
- package/dist/tests/SyncStateManager.test.js.map +1 -0
- package/dist/tests/account.test.d.ts +2 -0
- package/dist/tests/account.test.d.ts.map +1 -0
- package/dist/tests/account.test.js +66 -0
- package/dist/tests/account.test.js.map +1 -0
- package/dist/tests/coList.test.d.ts +2 -0
- package/dist/tests/coList.test.d.ts.map +1 -0
- package/dist/tests/coList.test.js +120 -0
- package/dist/tests/coList.test.js.map +1 -0
- package/dist/tests/coMap.test.d.ts +2 -0
- package/dist/tests/coMap.test.d.ts.map +1 -0
- package/dist/tests/coMap.test.js +164 -0
- package/dist/tests/coMap.test.js.map +1 -0
- package/dist/tests/coPlainText.test.d.ts +2 -0
- package/dist/tests/coPlainText.test.d.ts.map +1 -0
- package/dist/tests/coPlainText.test.js +99 -0
- package/dist/tests/coPlainText.test.js.map +1 -0
- package/dist/tests/coStream.test.d.ts +2 -0
- package/dist/tests/coStream.test.d.ts.map +1 -0
- package/dist/tests/coStream.test.js +206 -0
- package/dist/tests/coStream.test.js.map +1 -0
- package/dist/tests/coValueCore.test.d.ts +2 -0
- package/dist/tests/coValueCore.test.d.ts.map +1 -0
- package/dist/tests/coValueCore.test.js +164 -0
- package/dist/tests/coValueCore.test.js.map +1 -0
- package/dist/tests/coValueState.test.d.ts +2 -0
- package/dist/tests/coValueState.test.d.ts.map +1 -0
- package/dist/tests/coValueState.test.js +364 -0
- package/dist/tests/coValueState.test.js.map +1 -0
- package/dist/tests/crypto.test.d.ts +2 -0
- package/dist/tests/crypto.test.d.ts.map +1 -0
- package/dist/tests/crypto.test.js +144 -0
- package/dist/tests/crypto.test.js.map +1 -0
- package/dist/tests/cryptoImpl.test.d.ts +2 -0
- package/dist/tests/cryptoImpl.test.d.ts.map +1 -0
- package/dist/tests/cryptoImpl.test.js +144 -0
- package/dist/tests/cryptoImpl.test.js.map +1 -0
- package/dist/tests/group.test.d.ts +2 -0
- package/dist/tests/group.test.d.ts.map +1 -0
- package/dist/tests/group.test.js +576 -0
- package/dist/tests/group.test.js.map +1 -0
- package/dist/tests/logger.test.d.ts +2 -0
- package/dist/tests/logger.test.d.ts.map +1 -0
- package/dist/tests/logger.test.js +118 -0
- package/dist/tests/logger.test.js.map +1 -0
- package/dist/tests/permissions.test.d.ts +2 -0
- package/dist/tests/permissions.test.d.ts.map +1 -0
- package/dist/tests/permissions.test.js +2051 -0
- package/dist/tests/permissions.test.js.map +1 -0
- package/dist/tests/priority.test.d.ts +2 -0
- package/dist/tests/priority.test.d.ts.map +1 -0
- package/dist/tests/priority.test.js +61 -0
- package/dist/tests/priority.test.js.map +1 -0
- package/dist/tests/sync.test.d.ts +2 -0
- package/dist/tests/sync.test.d.ts.map +1 -0
- package/dist/tests/sync.test.js +1548 -0
- package/dist/tests/sync.test.js.map +1 -0
- package/dist/tests/testUtils.d.ts +142 -0
- package/dist/tests/testUtils.d.ts.map +1 -0
- package/dist/tests/testUtils.js +315 -0
- package/dist/tests/testUtils.js.map +1 -0
- package/dist/typeUtils/accountOrAgentIDfromSessionID.d.ts +4 -0
- package/dist/typeUtils/accountOrAgentIDfromSessionID.d.ts.map +1 -0
- package/dist/typeUtils/expectGroup.d.ts +4 -0
- package/dist/typeUtils/expectGroup.d.ts.map +1 -0
- package/dist/typeUtils/isAccountID.d.ts +4 -0
- package/dist/typeUtils/isAccountID.d.ts.map +1 -0
- package/dist/typeUtils/isCoValue.d.ts +4 -0
- package/dist/typeUtils/isCoValue.d.ts.map +1 -0
- package/dist/utils.d.ts +5 -0
- package/dist/utils.d.ts.map +1 -0
- package/package.json +6 -6
- package/src/coValueCore.ts +3 -9
- package/src/coValues/account.ts +15 -15
- package/src/coValues/group.ts +85 -12
- package/src/jsonValue.ts +9 -5
- package/src/localNode.ts +3 -5
- package/src/permissions.ts +5 -15
- package/src/tests/coValueCore.test.ts +2 -2
- package/src/tests/group.test.ts +187 -0
- package/src/tests/permissions.test.ts +330 -57
- package/src/tests/testUtils.ts +4 -1
- package/tsconfig.json +4 -2
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"priority.d.ts","sourceRoot":"","sources":["../src/priority.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,aAAa,EAAE,MAAM,kBAAkB,CAAC;AAEtD;;;;;;;;;GASG;AACH,eAAO,MAAM,iBAAiB;;;;CAIpB,CAAC;AAEX,MAAM,MAAM,eAAe,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;AAE5D,wBAAgB,qBAAqB,CACnC,MAAM,EAAE,aAAa,GAAG,SAAS,GAAG,OAAO,GAC1C,eAAe,CAkBjB"}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import { CryptoProvider } from "../crypto/crypto.js";
|
|
2
|
+
import { RawCoID } from "../ids.js";
|
|
3
|
+
import { CoValueChunk } from "./index.js";
|
|
4
|
+
export type BlockFilename = `L${number}-${string}-${string}-H${number}.jsonl`;
|
|
5
|
+
export type BlockHeader = {
|
|
6
|
+
id: RawCoID;
|
|
7
|
+
start: number;
|
|
8
|
+
length: number;
|
|
9
|
+
}[];
|
|
10
|
+
export type WalEntry = {
|
|
11
|
+
id: RawCoID;
|
|
12
|
+
} & CoValueChunk;
|
|
13
|
+
export type WalFilename = `wal-${number}.jsonl`;
|
|
14
|
+
export interface FileSystem<WriteHandle, ReadHandle> {
|
|
15
|
+
crypto: CryptoProvider;
|
|
16
|
+
createFile(filename: string): Promise<WriteHandle>;
|
|
17
|
+
append(handle: WriteHandle, data: Uint8Array): Promise<void>;
|
|
18
|
+
close(handle: ReadHandle | WriteHandle): Promise<void>;
|
|
19
|
+
closeAndRename(handle: WriteHandle, filename: BlockFilename): Promise<void>;
|
|
20
|
+
openToRead(filename: string): Promise<{
|
|
21
|
+
handle: ReadHandle;
|
|
22
|
+
size: number;
|
|
23
|
+
}>;
|
|
24
|
+
read(handle: ReadHandle, offset: number, length: number): Promise<Uint8Array>;
|
|
25
|
+
listFiles(): Promise<string[]>;
|
|
26
|
+
removeFile(filename: BlockFilename | WalFilename): Promise<void>;
|
|
27
|
+
}
|
|
28
|
+
export declare const textEncoder: TextEncoder;
|
|
29
|
+
export declare const textDecoder: TextDecoder;
|
|
30
|
+
export declare function readChunk<RH, FS extends FileSystem<unknown, RH>>(handle: RH, header: {
|
|
31
|
+
start: number;
|
|
32
|
+
length: number;
|
|
33
|
+
}, fs: FS): Promise<CoValueChunk>;
|
|
34
|
+
export declare function readHeader<RH, FS extends FileSystem<unknown, RH>>(filename: string, handle: RH, size: number, fs: FS): Promise<BlockHeader>;
|
|
35
|
+
export declare function writeBlock<WH, RH, FS extends FileSystem<WH, RH>>(chunks: Map<RawCoID, CoValueChunk>, level: number, blockNumber: number, fs: FS): Promise<BlockFilename>;
|
|
36
|
+
export declare function writeToWal<WH, RH, FS extends FileSystem<WH, RH>>(handle: WH, fs: FS, id: RawCoID, chunk: CoValueChunk): Promise<void>;
|
|
37
|
+
//# sourceMappingURL=FileSystem.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"FileSystem.d.ts","sourceRoot":"","sources":["../../src/storage/FileSystem.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAiB,MAAM,qBAAqB,CAAC;AACpE,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,OAAO,EAAE,YAAY,EAAE,MAAM,YAAY,CAAC;AAE1C,MAAM,MAAM,aAAa,GAAG,IAAI,MAAM,IAAI,MAAM,IAAI,MAAM,KAAK,MAAM,QAAQ,CAAC;AAE9E,MAAM,MAAM,WAAW,GAAG;IAAE,EAAE,EAAE,OAAO,CAAC;IAAC,KAAK,EAAE,MAAM,CAAC;IAAC,MAAM,EAAE,MAAM,CAAA;CAAE,EAAE,CAAC;AAE3E,MAAM,MAAM,QAAQ,GAAG;IAAE,EAAE,EAAE,OAAO,CAAA;CAAE,GAAG,YAAY,CAAC;AAEtD,MAAM,MAAM,WAAW,GAAG,OAAO,MAAM,QAAQ,CAAC;AAEhD,MAAM,WAAW,UAAU,CAAC,WAAW,EAAE,UAAU;IACjD,MAAM,EAAE,cAAc,CAAC;IACvB,UAAU,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,WAAW,CAAC,CAAC;IACnD,MAAM,CAAC,MAAM,EAAE,WAAW,EAAE,IAAI,EAAE,UAAU,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAC7D,KAAK,CAAC,MAAM,EAAE,UAAU,GAAG,WAAW,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IACvD,cAAc,CAAC,MAAM,EAAE,WAAW,EAAE,QAAQ,EAAE,aAAa,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAC5E,UAAU,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC;QAAE,MAAM,EAAE,UAAU,CAAC;QAAC,IAAI,EAAE,MAAM,CAAA;KAAE,CAAC,CAAC;IAC5E,IAAI,CAAC,MAAM,EAAE,UAAU,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,UAAU,CAAC,CAAC;IAC9E,SAAS,IAAI,OAAO,CAAC,MAAM,EAAE,CAAC,CAAC;IAC/B,UAAU,CAAC,QAAQ,EAAE,aAAa,GAAG,WAAW,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;CAClE;AAED,eAAO,MAAM,WAAW,aAAoB,CAAC;AAC7C,eAAO,MAAM,WAAW,aAAoB,CAAC;AAE7C,wBAAsB,SAAS,CAAC,EAAE,EAAE,EAAE,SAAS,UAAU,CAAC,OAAO,EAAE,EAAE,CAAC,EACpE,MAAM,EAAE,EAAE,EACV,MAAM,EAAE;IAAE,KAAK,EAAE,MAAM,CAAC;IAAC,MAAM,EAAE,MAAM,CAAA;CAAE,EACzC,EAAE,EAAE,EAAE,GACL,OAAO,CAAC,YAAY,CAAC,CAKvB;AAED,wBAAsB,UAAU,CAAC,EAAE,EAAE,EAAE,SAAS,UAAU,CAAC,OAAO,EAAE,EAAE,CAAC,EACrE,QAAQ,EAAE,MAAM,EAChB,MAAM,EAAE,EAAE,EACV,IAAI,EAAE,MAAM,EACZ,EAAE,EAAE,EAAE,GACL,OAAO,CAAC,WAAW,CAAC,CAOtB;AAED,wBAAsB,UAAU,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,SAAS,UAAU,CAAC,EAAE,EAAE,EAAE,CAAC,EACpE,MAAM,EAAE,GAAG,CAAC,OAAO,EAAE,YAAY,CAAC,EAClC,KAAK,EAAE,MAAM,EACb,WAAW,EAAE,MAAM,EACnB,EAAE,EAAE,EAAE,GACL,OAAO,CAAC,aAAa,CAAC,CAyCxB;AAED,wBAAsB,UAAU,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,SAAS,UAAU,CAAC,EAAE,EAAE,EAAE,CAAC,EACpE,MAAM,EAAE,EAAE,EACV,EAAE,EAAE,EAAE,EACN,EAAE,EAAE,OAAO,EACX,KAAK,EAAE,YAAY,iBAQpB"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { RawCoID } from "../ids.js";
|
|
2
|
+
import { CoValueKnownState, NewContentMessage } from "../sync.js";
|
|
3
|
+
import { CoValueChunk } from "./index.js";
|
|
4
|
+
export declare function contentSinceChunk(id: RawCoID, chunk: CoValueChunk, known?: CoValueKnownState): NewContentMessage[];
|
|
5
|
+
export declare function chunkToKnownState(id: RawCoID, chunk: CoValueChunk): CoValueKnownState;
|
|
6
|
+
export declare function mergeChunks(chunkA: CoValueChunk, chunkB: CoValueChunk): "nonContigous" | CoValueChunk;
|
|
7
|
+
//# sourceMappingURL=chunksAndKnownStates.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"chunksAndKnownStates.d.ts","sourceRoot":"","sources":["../../src/storage/chunksAndKnownStates.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,OAAO,EAAa,MAAM,WAAW,CAAC;AAE/C,OAAO,EAAE,iBAAiB,EAAE,iBAAiB,EAAE,MAAM,YAAY,CAAC;AAClE,OAAO,EAAE,YAAY,EAAE,MAAM,YAAY,CAAC;AAE1C,wBAAgB,iBAAiB,CAC/B,EAAE,EAAE,OAAO,EACX,KAAK,EAAE,YAAY,EACnB,KAAK,CAAC,EAAE,iBAAiB,GACxB,iBAAiB,EAAE,CA8CrB;AAED,wBAAgB,iBAAiB,CAAC,EAAE,EAAE,OAAO,EAAE,KAAK,EAAE,YAAY,qBAgBjE;AAED,wBAAgB,WAAW,CACzB,MAAM,EAAE,YAAY,EACpB,MAAM,EAAE,YAAY,GACnB,cAAc,GAAG,YAAY,CAyD/B"}
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
import { CoValueHeader, Transaction } from "../coValueCore.js";
|
|
2
|
+
import { Signature } from "../crypto/crypto.js";
|
|
3
|
+
import { RawCoID } from "../ids.js";
|
|
4
|
+
import { CoValueKnownState, IncomingSyncStream, NewContentMessage, OutgoingSyncQueue, Peer } from "../sync.js";
|
|
5
|
+
import { BlockFilename, FileSystem } from "./FileSystem.js";
|
|
6
|
+
export type { BlockFilename, WalFilename } from "./FileSystem.js";
|
|
7
|
+
export type CoValueChunk = {
|
|
8
|
+
header?: CoValueHeader;
|
|
9
|
+
sessionEntries: {
|
|
10
|
+
[sessionID: string]: {
|
|
11
|
+
after: number;
|
|
12
|
+
lastSignature: Signature;
|
|
13
|
+
transactions: Transaction[];
|
|
14
|
+
}[];
|
|
15
|
+
};
|
|
16
|
+
};
|
|
17
|
+
export declare class LSMStorage<WH, RH, FS extends FileSystem<WH, RH>> {
|
|
18
|
+
fs: FS;
|
|
19
|
+
fromLocalNode: IncomingSyncStream;
|
|
20
|
+
toLocalNode: OutgoingSyncQueue;
|
|
21
|
+
currentWal: WH | undefined;
|
|
22
|
+
coValues: {
|
|
23
|
+
[id: RawCoID]: CoValueChunk | undefined;
|
|
24
|
+
};
|
|
25
|
+
fileCache: string[] | undefined;
|
|
26
|
+
headerCache: Map<`L${number}-${string}-${string}-H${number}.jsonl`, {
|
|
27
|
+
[id: `co_z${string}`]: {
|
|
28
|
+
start: number;
|
|
29
|
+
length: number;
|
|
30
|
+
};
|
|
31
|
+
}>;
|
|
32
|
+
blockFileHandles: Map<`L${number}-${string}-${string}-H${number}.jsonl`, Promise<{
|
|
33
|
+
handle: RH;
|
|
34
|
+
size: number;
|
|
35
|
+
}>>;
|
|
36
|
+
constructor(fs: FS, fromLocalNode: IncomingSyncStream, toLocalNode: OutgoingSyncQueue);
|
|
37
|
+
sendNewContent(id: RawCoID, known: CoValueKnownState | undefined, asDependencyOf: RawCoID | undefined): Promise<void>;
|
|
38
|
+
withWAL(handler: (wal: WH) => Promise<void>): Promise<void>;
|
|
39
|
+
handleNewContent(newContent: NewContentMessage): Promise<void>;
|
|
40
|
+
getBlockHandle(blockFile: BlockFilename, fs: FS): Promise<{
|
|
41
|
+
handle: RH;
|
|
42
|
+
size: number;
|
|
43
|
+
}>;
|
|
44
|
+
loadCoValue(id: RawCoID, fs: FS): Promise<CoValueChunk | undefined>;
|
|
45
|
+
compact(): Promise<void>;
|
|
46
|
+
static asPeer<WH, RH, FS extends FileSystem<WH, RH>>({ fs, trace, localNodeName, }: {
|
|
47
|
+
fs: FS;
|
|
48
|
+
trace?: boolean;
|
|
49
|
+
localNodeName?: string;
|
|
50
|
+
}): Peer;
|
|
51
|
+
}
|
|
52
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/storage/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,aAAa,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAC/D,OAAO,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AAChD,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAGpC,OAAO,EACL,iBAAiB,EACjB,kBAAkB,EAClB,iBAAiB,EACjB,iBAAiB,EACjB,IAAI,EACL,MAAM,YAAY,CAAC;AACpB,OAAO,EACL,aAAa,EACb,UAAU,EAQX,MAAM,iBAAiB,CAAC;AAMzB,YAAY,EAAE,aAAa,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAC;AAIlE,MAAM,MAAM,YAAY,GAAG;IACzB,MAAM,CAAC,EAAE,aAAa,CAAC;IACvB,cAAc,EAAE;QACd,CAAC,SAAS,EAAE,MAAM,GAAG;YACnB,KAAK,EAAE,MAAM,CAAC;YACd,aAAa,EAAE,SAAS,CAAC;YACzB,YAAY,EAAE,WAAW,EAAE,CAAC;SAC7B,EAAE,CAAC;KACL,CAAC;CACH,CAAC;AAEF,qBAAa,UAAU,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,SAAS,UAAU,CAAC,EAAE,EAAE,EAAE,CAAC;IAgBlD,EAAE,EAAE,EAAE;IACN,aAAa,EAAE,kBAAkB;IACjC,WAAW,EAAE,iBAAiB;IAjBvC,UAAU,EAAE,EAAE,GAAG,SAAS,CAAC;IAC3B,QAAQ,EAAE;QACR,CAAC,EAAE,EAAE,OAAO,GAAG,YAAY,GAAG,SAAS,CAAC;KACzC,CAAC;IACF,SAAS,EAAE,MAAM,EAAE,GAAG,SAAS,CAAC;IAChC,WAAW;;mBAEiB,MAAM;oBAAU,MAAM;;OAC9C;IACJ,gBAAgB;gBAEI,EAAE;cAAQ,MAAM;QAChC;gBAGK,EAAE,EAAE,EAAE,EACN,aAAa,EAAE,kBAAkB,EACjC,WAAW,EAAE,iBAAiB;IAoDjC,cAAc,CAClB,EAAE,EAAE,OAAO,EACX,KAAK,EAAE,iBAAiB,GAAG,SAAS,EACpC,cAAc,EAAE,OAAO,GAAG,SAAS;IAqF/B,OAAO,CAAC,OAAO,EAAE,CAAC,GAAG,EAAE,EAAE,KAAK,OAAO,CAAC,IAAI,CAAC;IAS3C,gBAAgB,CAAC,UAAU,EAAE,iBAAiB;IA6D9C,cAAc,CAClB,SAAS,EAAE,aAAa,EACxB,EAAE,EAAE,EAAE,GACL,OAAO,CAAC;QAAE,MAAM,EAAE,EAAE,CAAC;QAAC,IAAI,EAAE,MAAM,CAAA;KAAE,CAAC;IAQlC,WAAW,CAAC,EAAE,EAAE,OAAO,EAAE,EAAE,EAAE,EAAE,GAAG,OAAO,CAAC,YAAY,GAAG,SAAS,CAAC;IAuDnE,OAAO;IA4Kb,MAAM,CAAC,MAAM,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,SAAS,UAAU,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,EACnD,EAAE,EACF,KAAK,EACL,aAAuB,GACxB,EAAE;QACD,EAAE,EAAE,EAAE,CAAC;QACP,KAAK,CAAC,EAAE,OAAO,CAAC;QAChB,aAAa,CAAC,EAAE,MAAM,CAAC;KACxB,GAAG,IAAI;CAiBT"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { Channel } from "queueueue";
|
|
2
|
+
import { Peer, PeerID, SyncMessage } from "./sync.js";
|
|
3
|
+
export { Channel } from "queueueue";
|
|
4
|
+
export declare function connectedPeers(peer1id: PeerID, peer2id: PeerID, { trace, peer1role, peer2role, crashOnClose, }?: {
|
|
5
|
+
trace?: boolean;
|
|
6
|
+
peer1role?: Peer["role"];
|
|
7
|
+
peer2role?: Peer["role"];
|
|
8
|
+
crashOnClose?: boolean;
|
|
9
|
+
}): [Peer, Peer];
|
|
10
|
+
export declare function newQueuePair(options?: {
|
|
11
|
+
traceAs?: string;
|
|
12
|
+
}): [AsyncIterable<SyncMessage>, Channel<SyncMessage>];
|
|
13
|
+
//# sourceMappingURL=streamUtils.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"streamUtils.d.ts","sourceRoot":"","sources":["../src/streamUtils.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,OAAO,EAAE,IAAI,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,WAAW,CAAC;AACtD,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAEpC,wBAAgB,cAAc,CAC5B,OAAO,EAAE,MAAM,EACf,OAAO,EAAE,MAAM,EACf,EACE,KAAa,EACb,SAAkB,EAClB,SAAkB,EAClB,YAAoB,GACrB,GAAE;IACD,KAAK,CAAC,EAAE,OAAO,CAAC;IAChB,SAAS,CAAC,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC;IACzB,SAAS,CAAC,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC;IACzB,YAAY,CAAC,EAAE,OAAO,CAAC;CACnB,GACL,CAAC,IAAI,EAAE,IAAI,CAAC,CAyBd;AAED,wBAAgB,YAAY,CAC1B,OAAO,GAAE;IAAE,OAAO,CAAC,EAAE,MAAM,CAAA;CAAO,GACjC,CAAC,aAAa,CAAC,WAAW,CAAC,EAAE,OAAO,CAAC,WAAW,CAAC,CAAC,CA0BpD"}
|
package/dist/sync.d.ts
ADDED
|
@@ -0,0 +1,97 @@
|
|
|
1
|
+
import { PeerState } from "./PeerState.js";
|
|
2
|
+
import { SyncStateManager } from "./SyncStateManager.js";
|
|
3
|
+
import { CoValueHeader, Transaction } from "./coValueCore.js";
|
|
4
|
+
import { CoValueCore } from "./coValueCore.js";
|
|
5
|
+
import { Signature } from "./crypto/crypto.js";
|
|
6
|
+
import { RawCoID, SessionID } from "./ids.js";
|
|
7
|
+
import { LocalNode } from "./localNode.js";
|
|
8
|
+
import { CoValuePriority } from "./priority.js";
|
|
9
|
+
export type CoValueKnownState = {
|
|
10
|
+
id: RawCoID;
|
|
11
|
+
header: boolean;
|
|
12
|
+
sessions: {
|
|
13
|
+
[sessionID: SessionID]: number;
|
|
14
|
+
};
|
|
15
|
+
};
|
|
16
|
+
export declare function emptyKnownState(id: RawCoID): CoValueKnownState;
|
|
17
|
+
export type SyncMessage = LoadMessage | KnownStateMessage | NewContentMessage | DoneMessage;
|
|
18
|
+
export type LoadMessage = {
|
|
19
|
+
action: "load";
|
|
20
|
+
} & CoValueKnownState;
|
|
21
|
+
export type KnownStateMessage = {
|
|
22
|
+
action: "known";
|
|
23
|
+
asDependencyOf?: RawCoID;
|
|
24
|
+
isCorrection?: boolean;
|
|
25
|
+
} & CoValueKnownState;
|
|
26
|
+
export type NewContentMessage = {
|
|
27
|
+
action: "content";
|
|
28
|
+
id: RawCoID;
|
|
29
|
+
header?: CoValueHeader;
|
|
30
|
+
priority: CoValuePriority;
|
|
31
|
+
new: {
|
|
32
|
+
[sessionID: SessionID]: SessionNewContent;
|
|
33
|
+
};
|
|
34
|
+
};
|
|
35
|
+
export type SessionNewContent = {
|
|
36
|
+
after: number;
|
|
37
|
+
newTransactions: Transaction[];
|
|
38
|
+
lastSignature: Signature;
|
|
39
|
+
};
|
|
40
|
+
export type DoneMessage = {
|
|
41
|
+
action: "done";
|
|
42
|
+
id: RawCoID;
|
|
43
|
+
};
|
|
44
|
+
export type PeerID = string;
|
|
45
|
+
export type DisconnectedError = "Disconnected";
|
|
46
|
+
export type PingTimeoutError = "PingTimeout";
|
|
47
|
+
export type IncomingSyncStream = AsyncIterable<SyncMessage | DisconnectedError | PingTimeoutError>;
|
|
48
|
+
export type OutgoingSyncQueue = {
|
|
49
|
+
push: (msg: SyncMessage) => Promise<unknown>;
|
|
50
|
+
close: () => void;
|
|
51
|
+
};
|
|
52
|
+
export interface Peer {
|
|
53
|
+
id: PeerID;
|
|
54
|
+
incoming: IncomingSyncStream;
|
|
55
|
+
outgoing: OutgoingSyncQueue;
|
|
56
|
+
role: "peer" | "server" | "client" | "storage";
|
|
57
|
+
priority?: number;
|
|
58
|
+
crashOnClose: boolean;
|
|
59
|
+
deletePeerStateOnClose?: boolean;
|
|
60
|
+
}
|
|
61
|
+
export declare function combinedKnownStates(stateA: CoValueKnownState, stateB: CoValueKnownState): CoValueKnownState;
|
|
62
|
+
export declare class SyncManager {
|
|
63
|
+
peers: {
|
|
64
|
+
[key: PeerID]: PeerState;
|
|
65
|
+
};
|
|
66
|
+
local: LocalNode;
|
|
67
|
+
requestedSyncs: {
|
|
68
|
+
[id: RawCoID]: {
|
|
69
|
+
done: Promise<void>;
|
|
70
|
+
nRequestsThisTick: number;
|
|
71
|
+
} | undefined;
|
|
72
|
+
};
|
|
73
|
+
peersCounter: import("@opentelemetry/api").UpDownCounter<import("@opentelemetry/api").Attributes>;
|
|
74
|
+
constructor(local: LocalNode);
|
|
75
|
+
syncState: SyncStateManager;
|
|
76
|
+
peersInPriorityOrder(): PeerState[];
|
|
77
|
+
getPeers(): PeerState[];
|
|
78
|
+
getServerAndStoragePeers(excludePeerId?: PeerID): PeerState[];
|
|
79
|
+
handleSyncMessage(msg: SyncMessage, peer: PeerState): Promise<void>;
|
|
80
|
+
subscribeToIncludingDependencies(id: RawCoID, peer: PeerState): Promise<void>;
|
|
81
|
+
tellUntoldKnownStateIncludingDependencies(id: RawCoID, peer: PeerState, asDependencyOf?: RawCoID): Promise<void>;
|
|
82
|
+
sendNewContentIncludingDependencies(id: RawCoID, peer: PeerState): Promise<void>;
|
|
83
|
+
addPeer(peer: Peer): void;
|
|
84
|
+
trySendToPeer(peer: PeerState, msg: SyncMessage): Promise<void>;
|
|
85
|
+
handleLoad(msg: LoadMessage, peer: PeerState): Promise<void>;
|
|
86
|
+
handleKnownState(msg: KnownStateMessage, peer: PeerState): Promise<void>;
|
|
87
|
+
handleNewContent(msg: NewContentMessage, peer: PeerState): Promise<void>;
|
|
88
|
+
handleCorrection(msg: KnownStateMessage, peer: PeerState): Promise<void>;
|
|
89
|
+
handleUnsubscribe(_msg: DoneMessage): void;
|
|
90
|
+
syncCoValue(coValue: CoValueCore): Promise<void>;
|
|
91
|
+
actuallySyncCoValue(coValue: CoValueCore): Promise<void>;
|
|
92
|
+
waitForSyncWithPeer(peerId: PeerID, id: RawCoID, timeout: number): Promise<unknown>;
|
|
93
|
+
waitForSync(id: RawCoID, timeout?: number): Promise<unknown[]>;
|
|
94
|
+
waitForAllCoValuesSync(timeout?: number): Promise<unknown[][]>;
|
|
95
|
+
gracefulShutdown(): void;
|
|
96
|
+
}
|
|
97
|
+
//# sourceMappingURL=sync.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sync.d.ts","sourceRoot":"","sources":["../src/sync.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PeerKnownStates.test.d.ts","sourceRoot":"","sources":["../../src/tests/PeerKnownStates.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,82 @@
|
|
|
1
|
+
import { describe, expect, test, vi } from "vitest";
|
|
2
|
+
import { PeerKnownStates } from "../PeerKnownStates.js";
|
|
3
|
+
import { emptyKnownState } from "../sync.js";
|
|
4
|
+
describe("PeerKnownStates", () => {
|
|
5
|
+
test("should set and get a known state", () => {
|
|
6
|
+
const peerKnownStates = new PeerKnownStates();
|
|
7
|
+
const id = "test-id";
|
|
8
|
+
const knownState = emptyKnownState(id);
|
|
9
|
+
peerKnownStates.dispatch({ type: "SET", id, value: knownState });
|
|
10
|
+
expect(peerKnownStates.get(id)).toEqual(knownState);
|
|
11
|
+
expect(peerKnownStates.has(id)).toBe(true);
|
|
12
|
+
});
|
|
13
|
+
test("should update header", () => {
|
|
14
|
+
const peerKnownStates = new PeerKnownStates();
|
|
15
|
+
const id = "test-id";
|
|
16
|
+
peerKnownStates.dispatch({ type: "UPDATE_HEADER", id, header: true });
|
|
17
|
+
const result = peerKnownStates.get(id);
|
|
18
|
+
expect(result?.header).toBe(true);
|
|
19
|
+
});
|
|
20
|
+
test("should update session counter", () => {
|
|
21
|
+
const peerKnownStates = new PeerKnownStates();
|
|
22
|
+
const id = "test-id";
|
|
23
|
+
const sessionId = "session-1";
|
|
24
|
+
peerKnownStates.dispatch({
|
|
25
|
+
type: "UPDATE_SESSION_COUNTER",
|
|
26
|
+
id,
|
|
27
|
+
sessionId,
|
|
28
|
+
value: 5,
|
|
29
|
+
});
|
|
30
|
+
const result = peerKnownStates.get(id);
|
|
31
|
+
expect(result?.sessions[sessionId]).toBe(5);
|
|
32
|
+
});
|
|
33
|
+
test("should combine with existing state", () => {
|
|
34
|
+
const peerKnownStates = new PeerKnownStates();
|
|
35
|
+
const id = "test-id";
|
|
36
|
+
const session1 = "session-1";
|
|
37
|
+
const session2 = "session-2";
|
|
38
|
+
const initialState = {
|
|
39
|
+
...emptyKnownState(id),
|
|
40
|
+
sessions: { [session1]: 5 },
|
|
41
|
+
};
|
|
42
|
+
const combineState = {
|
|
43
|
+
...emptyKnownState(id),
|
|
44
|
+
sessions: { [session2]: 10 },
|
|
45
|
+
};
|
|
46
|
+
peerKnownStates.dispatch({ type: "SET", id, value: initialState });
|
|
47
|
+
peerKnownStates.dispatch({ type: "COMBINE_WITH", id, value: combineState });
|
|
48
|
+
const result = peerKnownStates.get(id);
|
|
49
|
+
expect(result?.sessions).toEqual({ [session1]: 5, [session2]: 10 });
|
|
50
|
+
});
|
|
51
|
+
test("should set as empty", () => {
|
|
52
|
+
const peerKnownStates = new PeerKnownStates();
|
|
53
|
+
const id = "test-id";
|
|
54
|
+
const sessionId = "session-1";
|
|
55
|
+
const initialState = {
|
|
56
|
+
...emptyKnownState(id),
|
|
57
|
+
sessions: { [sessionId]: 5 },
|
|
58
|
+
};
|
|
59
|
+
peerKnownStates.dispatch({ type: "SET", id, value: initialState });
|
|
60
|
+
peerKnownStates.dispatch({ type: "SET_AS_EMPTY", id });
|
|
61
|
+
const result = peerKnownStates.get(id);
|
|
62
|
+
expect(result).toEqual(emptyKnownState(id));
|
|
63
|
+
});
|
|
64
|
+
test("should trigger listeners on dispatch", () => {
|
|
65
|
+
const peerKnownStates = new PeerKnownStates();
|
|
66
|
+
const id = "test-id";
|
|
67
|
+
const listener = vi.fn();
|
|
68
|
+
peerKnownStates.subscribe(listener);
|
|
69
|
+
peerKnownStates.dispatch({ type: "SET_AS_EMPTY", id });
|
|
70
|
+
expect(listener).toHaveBeenCalledWith(id, emptyKnownState(id));
|
|
71
|
+
});
|
|
72
|
+
test("should unsubscribe listener", () => {
|
|
73
|
+
const peerKnownStates = new PeerKnownStates();
|
|
74
|
+
const id = "test-id";
|
|
75
|
+
const listener = vi.fn();
|
|
76
|
+
const unsubscribe = peerKnownStates.subscribe(listener);
|
|
77
|
+
unsubscribe();
|
|
78
|
+
peerKnownStates.dispatch({ type: "SET_AS_EMPTY", id });
|
|
79
|
+
expect(listener).not.toHaveBeenCalled();
|
|
80
|
+
});
|
|
81
|
+
});
|
|
82
|
+
//# sourceMappingURL=PeerKnownStates.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PeerKnownStates.test.js","sourceRoot":"","sources":["../../src/tests/PeerKnownStates.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PeerState.test.d.ts","sourceRoot":"","sources":["../../src/tests/PeerState.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,188 @@
|
|
|
1
|
+
import { describe, expect, test, vi } from "vitest";
|
|
2
|
+
import { PeerState } from "../PeerState.js";
|
|
3
|
+
import { CO_VALUE_PRIORITY } from "../priority.js";
|
|
4
|
+
function setup() {
|
|
5
|
+
const mockPeer = {
|
|
6
|
+
id: "test-peer",
|
|
7
|
+
role: "peer",
|
|
8
|
+
priority: 1,
|
|
9
|
+
crashOnClose: false,
|
|
10
|
+
incoming: (async function* () { })(),
|
|
11
|
+
outgoing: {
|
|
12
|
+
push: vi.fn().mockResolvedValue(undefined),
|
|
13
|
+
close: vi.fn(),
|
|
14
|
+
},
|
|
15
|
+
};
|
|
16
|
+
const peerState = new PeerState(mockPeer, undefined);
|
|
17
|
+
return { mockPeer, peerState };
|
|
18
|
+
}
|
|
19
|
+
describe("PeerState", () => {
|
|
20
|
+
test("should push outgoing message to peer", async () => {
|
|
21
|
+
const { mockPeer, peerState } = setup();
|
|
22
|
+
const message = {
|
|
23
|
+
action: "load",
|
|
24
|
+
id: "co_ztest-id",
|
|
25
|
+
header: false,
|
|
26
|
+
sessions: {},
|
|
27
|
+
};
|
|
28
|
+
await peerState.pushOutgoingMessage(message);
|
|
29
|
+
expect(mockPeer.outgoing.push).toHaveBeenCalledWith(message);
|
|
30
|
+
});
|
|
31
|
+
test("should return peer's incoming when not closed", () => {
|
|
32
|
+
const { mockPeer, peerState } = setup();
|
|
33
|
+
expect(peerState.incoming).toBe(mockPeer.incoming);
|
|
34
|
+
});
|
|
35
|
+
test("should return Disconnected when closed", async () => {
|
|
36
|
+
const { peerState } = setup();
|
|
37
|
+
peerState.gracefulShutdown();
|
|
38
|
+
const incomingIterator = peerState.incoming[Symbol.asyncIterator]();
|
|
39
|
+
const { value, done } = await incomingIterator.next();
|
|
40
|
+
expect(value).toBe("Disconnected");
|
|
41
|
+
expect(done).toBe(false);
|
|
42
|
+
});
|
|
43
|
+
test("should perform graceful shutdown", () => {
|
|
44
|
+
const { mockPeer, peerState } = setup();
|
|
45
|
+
peerState.gracefulShutdown();
|
|
46
|
+
expect(mockPeer.outgoing.close).toHaveBeenCalled();
|
|
47
|
+
expect(peerState.closed).toBe(true);
|
|
48
|
+
});
|
|
49
|
+
test("should empty the queue when closing", async () => {
|
|
50
|
+
const { mockPeer, peerState } = setup();
|
|
51
|
+
mockPeer.outgoing.push = vi.fn().mockImplementation((message) => {
|
|
52
|
+
return new Promise((resolve) => {
|
|
53
|
+
setTimeout(resolve, 100);
|
|
54
|
+
});
|
|
55
|
+
});
|
|
56
|
+
const message1 = peerState.pushOutgoingMessage({
|
|
57
|
+
action: "content",
|
|
58
|
+
id: "co_z1",
|
|
59
|
+
new: {},
|
|
60
|
+
priority: CO_VALUE_PRIORITY.HIGH,
|
|
61
|
+
});
|
|
62
|
+
const message2 = peerState.pushOutgoingMessage({
|
|
63
|
+
action: "content",
|
|
64
|
+
id: "co_z1",
|
|
65
|
+
new: {},
|
|
66
|
+
priority: CO_VALUE_PRIORITY.HIGH,
|
|
67
|
+
});
|
|
68
|
+
peerState.gracefulShutdown();
|
|
69
|
+
await Promise.allSettled([message1, message2]);
|
|
70
|
+
await expect(message1).resolves.toBe(undefined);
|
|
71
|
+
await expect(message2).resolves.toBe(undefined);
|
|
72
|
+
});
|
|
73
|
+
test("should schedule outgoing messages based on their priority", async () => {
|
|
74
|
+
const { peerState } = setup();
|
|
75
|
+
const loadMessage = {
|
|
76
|
+
action: "load",
|
|
77
|
+
id: "co_zhigh",
|
|
78
|
+
header: false,
|
|
79
|
+
sessions: {},
|
|
80
|
+
};
|
|
81
|
+
const contentMessageHigh = {
|
|
82
|
+
action: "content",
|
|
83
|
+
id: "co_zhigh",
|
|
84
|
+
new: {},
|
|
85
|
+
priority: CO_VALUE_PRIORITY.HIGH,
|
|
86
|
+
};
|
|
87
|
+
const contentMessageMid = {
|
|
88
|
+
action: "content",
|
|
89
|
+
id: "co_zmid",
|
|
90
|
+
new: {},
|
|
91
|
+
priority: CO_VALUE_PRIORITY.MEDIUM,
|
|
92
|
+
};
|
|
93
|
+
const contentMessageLow = {
|
|
94
|
+
action: "content",
|
|
95
|
+
id: "co_zlow",
|
|
96
|
+
new: {},
|
|
97
|
+
priority: CO_VALUE_PRIORITY.LOW,
|
|
98
|
+
};
|
|
99
|
+
const promises = [
|
|
100
|
+
peerState.pushOutgoingMessage(contentMessageLow),
|
|
101
|
+
peerState.pushOutgoingMessage(contentMessageMid),
|
|
102
|
+
peerState.pushOutgoingMessage(contentMessageHigh),
|
|
103
|
+
peerState.pushOutgoingMessage(loadMessage),
|
|
104
|
+
];
|
|
105
|
+
await Promise.all(promises);
|
|
106
|
+
// The first message is pushed directly, the other three are queued because are waiting
|
|
107
|
+
// for the first push to be completed.
|
|
108
|
+
expect(peerState["peer"].outgoing.push).toHaveBeenNthCalledWith(1, contentMessageLow);
|
|
109
|
+
// Load message are managed as high priority messages and having the same priority as the content message
|
|
110
|
+
// they follow the push order.
|
|
111
|
+
expect(peerState["peer"].outgoing.push).toHaveBeenNthCalledWith(2, contentMessageHigh);
|
|
112
|
+
expect(peerState["peer"].outgoing.push).toHaveBeenNthCalledWith(3, loadMessage);
|
|
113
|
+
expect(peerState["peer"].outgoing.push).toHaveBeenNthCalledWith(4, contentMessageMid);
|
|
114
|
+
});
|
|
115
|
+
test("should clone the knownStates into optimisticKnownStates and knownStates when passed as argument", () => {
|
|
116
|
+
const { peerState, mockPeer } = setup();
|
|
117
|
+
const action = {
|
|
118
|
+
type: "SET",
|
|
119
|
+
id: "co_z1",
|
|
120
|
+
value: {
|
|
121
|
+
id: "co_z1",
|
|
122
|
+
header: false,
|
|
123
|
+
sessions: {},
|
|
124
|
+
},
|
|
125
|
+
};
|
|
126
|
+
peerState.dispatchToKnownStates(action);
|
|
127
|
+
const newPeerState = new PeerState(mockPeer, peerState.knownStates);
|
|
128
|
+
expect(newPeerState.knownStates).toEqual(peerState.knownStates);
|
|
129
|
+
expect(newPeerState.optimisticKnownStates).toEqual(peerState.knownStates);
|
|
130
|
+
});
|
|
131
|
+
test("should dispatch to both states", () => {
|
|
132
|
+
const { peerState } = setup();
|
|
133
|
+
const knownStatesSpy = vi.spyOn(peerState.knownStates, "dispatch");
|
|
134
|
+
const optimisticKnownStatesSpy = vi.spyOn(peerState.optimisticKnownStates, "dispatch");
|
|
135
|
+
const action = {
|
|
136
|
+
type: "SET",
|
|
137
|
+
id: "co_z1",
|
|
138
|
+
value: {
|
|
139
|
+
id: "co_z1",
|
|
140
|
+
header: false,
|
|
141
|
+
sessions: {},
|
|
142
|
+
},
|
|
143
|
+
};
|
|
144
|
+
peerState.dispatchToKnownStates(action);
|
|
145
|
+
expect(knownStatesSpy).toHaveBeenCalledWith(action);
|
|
146
|
+
expect(optimisticKnownStatesSpy).toHaveBeenCalledWith(action);
|
|
147
|
+
});
|
|
148
|
+
test("should use same reference for knownStates and optimisticKnownStates for storage peers", () => {
|
|
149
|
+
const mockStoragePeer = {
|
|
150
|
+
id: "test-storage-peer",
|
|
151
|
+
role: "storage",
|
|
152
|
+
priority: 1,
|
|
153
|
+
crashOnClose: false,
|
|
154
|
+
incoming: (async function* () { })(),
|
|
155
|
+
outgoing: {
|
|
156
|
+
push: vi.fn().mockResolvedValue(undefined),
|
|
157
|
+
close: vi.fn(),
|
|
158
|
+
},
|
|
159
|
+
};
|
|
160
|
+
const peerState = new PeerState(mockStoragePeer, undefined);
|
|
161
|
+
// Verify they are the same reference
|
|
162
|
+
expect(peerState.knownStates).toBe(peerState.optimisticKnownStates);
|
|
163
|
+
// Verify that dispatching only updates one state
|
|
164
|
+
const knownStatesSpy = vi.spyOn(peerState.knownStates, "dispatch");
|
|
165
|
+
const optimisticKnownStatesSpy = vi.spyOn(peerState.optimisticKnownStates, "dispatch");
|
|
166
|
+
const action = {
|
|
167
|
+
type: "SET",
|
|
168
|
+
id: "co_z1",
|
|
169
|
+
value: {
|
|
170
|
+
id: "co_z1",
|
|
171
|
+
header: false,
|
|
172
|
+
sessions: {},
|
|
173
|
+
},
|
|
174
|
+
};
|
|
175
|
+
peerState.dispatchToKnownStates(action);
|
|
176
|
+
// Only one dispatch should happen since they're the same reference
|
|
177
|
+
expect(knownStatesSpy).toHaveBeenCalledTimes(1);
|
|
178
|
+
expect(knownStatesSpy).toHaveBeenCalledWith(action);
|
|
179
|
+
expect(optimisticKnownStatesSpy).toHaveBeenCalledTimes(1);
|
|
180
|
+
expect(optimisticKnownStatesSpy).toHaveBeenCalledWith(action);
|
|
181
|
+
});
|
|
182
|
+
test("should use separate references for knownStates and optimisticKnownStates for non-storage peers", () => {
|
|
183
|
+
const { peerState } = setup(); // Uses a regular peer
|
|
184
|
+
// Verify they are different references
|
|
185
|
+
expect(peerState.knownStates).not.toBe(peerState.optimisticKnownStates);
|
|
186
|
+
});
|
|
187
|
+
});
|
|
188
|
+
//# sourceMappingURL=PeerState.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PeerState.test.js","sourceRoot":"","sources":["../../src/tests/PeerState.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PriorityBasedMessageQueue.test.d.ts","sourceRoot":"","sources":["../../src/tests/PriorityBasedMessageQueue.test.ts"],"names":[],"mappings":""}
|