@peerbit/shared-log 9.0.0-3a75d6e → 9.0.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.
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=replicate.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"replicate.d.ts","sourceRoot":"","sources":["../../benchmark/replicate.ts"],"names":[],"mappings":""}
@@ -0,0 +1,105 @@
1
+ import { waitForResolved } from "@peerbit/time";
2
+ import { TestSession } from "@peerbit/test-utils";
3
+ import { Ed25519Keypair } from "@peerbit/crypto";
4
+ import { AbsoluteReplicas } from "../src/replication.js";
5
+ import { deserialize } from "@dao-xyz/borsh";
6
+ import { expect } from "chai";
7
+ import { EventStore } from "../test/utils/stores/event-store.js";
8
+ let session = await TestSession.connected(3, [
9
+ {
10
+ libp2p: {
11
+ peerId: await deserialize(new Uint8Array([
12
+ 0, 0, 235, 231, 83, 185, 72, 206, 24, 154, 182, 109, 204, 158, 45,
13
+ 46, 27, 15, 0, 173, 134, 194, 249, 74, 80, 151, 42, 219, 238, 163,
14
+ 44, 6, 244, 93, 0, 136, 33, 37, 186, 9, 233, 46, 16, 89, 240, 71,
15
+ 145, 18, 244, 158, 62, 37, 199, 0, 28, 223, 185, 206, 109, 168,
16
+ 112, 65, 202, 154, 27, 63, 15
17
+ ]), Ed25519Keypair).toPeerId()
18
+ }
19
+ },
20
+ {
21
+ libp2p: {
22
+ peerId: await deserialize(new Uint8Array([
23
+ 0, 0, 132, 56, 63, 72, 241, 115, 159, 73, 215, 187, 97, 34, 23,
24
+ 12, 215, 160, 74, 43, 159, 235, 35, 84, 2, 7, 71, 15, 5, 210, 231,
25
+ 155, 75, 37, 0, 15, 85, 72, 252, 153, 251, 89, 18, 236, 54, 84,
26
+ 137, 152, 227, 77, 127, 108, 252, 59, 138, 246, 221, 120, 187,
27
+ 239, 56, 174, 184, 34, 141, 45, 242
28
+ ]), Ed25519Keypair).toPeerId()
29
+ }
30
+ },
31
+ {
32
+ libp2p: {
33
+ peerId: await deserialize(new Uint8Array([
34
+ 0, 0, 193, 202, 95, 29, 8, 42, 238, 188, 32, 59, 103, 187, 192,
35
+ 93, 202, 183, 249, 50, 240, 175, 84, 87, 239, 94, 92, 9, 207, 165,
36
+ 88, 38, 234, 216, 0, 183, 243, 219, 11, 211, 12, 61, 235, 154, 68,
37
+ 205, 124, 143, 217, 234, 222, 254, 15, 18, 64, 197, 13, 62, 84,
38
+ 62, 133, 97, 57, 150, 187, 247, 215
39
+ ]), Ed25519Keypair).toPeerId()
40
+ }
41
+ }
42
+ ]);
43
+ let db1, db2, db3;
44
+ const init = async (min, max) => {
45
+ db1 = await session.peers[0].open(new EventStore(), {
46
+ args: {
47
+ replicas: {
48
+ min,
49
+ max
50
+ },
51
+ replicate: false
52
+ }
53
+ });
54
+ db2 = (await EventStore.open(db1.address, session.peers[1], {
55
+ args: {
56
+ replicas: {
57
+ min,
58
+ max
59
+ }
60
+ }
61
+ }));
62
+ db3 = (await EventStore.open(db1.address, session.peers[2], {
63
+ args: {
64
+ replicas: {
65
+ min,
66
+ max
67
+ }
68
+ }
69
+ }));
70
+ await db1.waitFor(session.peers[1].peerId);
71
+ await db2.waitFor(session.peers[0].peerId);
72
+ await db2.waitFor(session.peers[2].peerId);
73
+ await db3.waitFor(session.peers[0].peerId);
74
+ };
75
+ let minReplicas = 1;
76
+ let maxReplicas = 1;
77
+ await init(minReplicas, maxReplicas);
78
+ /* await delay(5000)
79
+ */
80
+ // await delay(5000)
81
+ const entryCount = 100;
82
+ for (let i = 0; i < entryCount; i++) {
83
+ await db1.add("hello", {
84
+ replicas: new AbsoluteReplicas(100), // will be overriden by 'maxReplicas' above
85
+ meta: { next: [] }
86
+ });
87
+ }
88
+ try {
89
+ await waitForResolved(() => {
90
+ expect(db1.log.log.length).equal(0); // because db1 is not replicating at all, but just pruning once it knows entries are replicated elsewhere
91
+ let total = db2.log.log.length + db3.log.log.length;
92
+ expect(total).greaterThanOrEqual(entryCount);
93
+ expect(total).lessThan(entryCount * 2);
94
+ expect(db2.log.log.length).greaterThan(entryCount * 0.2);
95
+ expect(db3.log.log.length).greaterThan(entryCount * 0.2);
96
+ });
97
+ }
98
+ catch (error) {
99
+ console.log("NOT DONE : ( ", db1.log.log.length);
100
+ }
101
+ finally {
102
+ console.log("??");
103
+ }
104
+ await session.stop();
105
+ //# sourceMappingURL=replicate.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"replicate.js","sourceRoot":"","sources":["../../benchmark/replicate.ts"],"names":[],"mappings":"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"}
package/package.json CHANGED
@@ -1,72 +1,72 @@
1
1
  {
2
- "name": "@peerbit/shared-log",
3
- "version": "9.0.0-3a75d6e",
4
- "description": "Shared log",
5
- "sideEffects": false,
6
- "type": "module",
7
- "types": "./dist/src/index.d.ts",
8
- "typesVersions": {
9
- "*": {
10
- "*": [
11
- "*",
12
- "dist/*",
13
- "dist/src/*",
14
- "dist/src/*/index"
15
- ],
16
- "src/*": [
17
- "*",
18
- "dist/*",
19
- "dist/src/*",
20
- "dist/src/*/index"
21
- ]
22
- }
23
- },
24
- "files": [
25
- "src",
26
- "dist",
27
- "!dist/e2e",
28
- "!dist/test",
29
- "!**/*.tsbuildinfo"
30
- ],
31
- "exports": {
32
- ".": {
33
- "types": "./dist/src/index.d.ts",
34
- "import": "./dist/src/index.js"
35
- }
36
- },
37
- "eslintConfig": {
38
- "extends": "peerbit",
39
- "parserOptions": {
40
- "project": true,
41
- "sourceType": "module"
42
- },
43
- "ignorePatterns": [
44
- "!.aegir.js",
45
- "test/ts-use",
46
- "*.d.ts"
47
- ]
48
- },
49
- "publishConfig": {
50
- "access": "public"
51
- },
52
- "scripts": {
53
- "clean": "aegir clean",
54
- "build": "aegir build --no-bundle",
55
- "test": "aegir test --target node",
56
- "lint": "aegir lint"
57
- },
58
- "author": "dao.xyz",
59
- "license": "MIT",
60
- "dependencies": {
61
- "@dao-xyz/borsh": "^5.2.3",
62
- "@peerbit/logger": "1.0.3-3a75d6e",
63
- "@peerbit/program": "5.0.0-3a75d6e",
64
- "@peerbit/log": "4.0.0-3a75d6e",
65
- "@peerbit/rpc": "5.0.0-3a75d6e",
66
- "@peerbit/time": "2.0.7-3a75d6e",
67
- "p-debounce": "^4.0.0"
68
- },
69
- "devDependencies": {
70
- "@peerbit/test-utils": "2.0.34-3a75d6e"
71
- }
2
+ "name": "@peerbit/shared-log",
3
+ "version": "9.0.0",
4
+ "description": "Shared log",
5
+ "sideEffects": false,
6
+ "type": "module",
7
+ "types": "./dist/src/index.d.ts",
8
+ "typesVersions": {
9
+ "*": {
10
+ "*": [
11
+ "*",
12
+ "dist/*",
13
+ "dist/src/*",
14
+ "dist/src/*/index"
15
+ ],
16
+ "src/*": [
17
+ "*",
18
+ "dist/*",
19
+ "dist/src/*",
20
+ "dist/src/*/index"
21
+ ]
22
+ }
23
+ },
24
+ "files": [
25
+ "src",
26
+ "dist",
27
+ "!dist/e2e",
28
+ "!dist/test",
29
+ "!**/*.tsbuildinfo"
30
+ ],
31
+ "exports": {
32
+ ".": {
33
+ "types": "./dist/src/index.d.ts",
34
+ "import": "./dist/src/index.js"
35
+ }
36
+ },
37
+ "eslintConfig": {
38
+ "extends": "peerbit",
39
+ "parserOptions": {
40
+ "project": true,
41
+ "sourceType": "module"
42
+ },
43
+ "ignorePatterns": [
44
+ "!.aegir.js",
45
+ "test/ts-use",
46
+ "*.d.ts"
47
+ ]
48
+ },
49
+ "publishConfig": {
50
+ "access": "public"
51
+ },
52
+ "scripts": {
53
+ "clean": "aegir clean",
54
+ "build": "aegir build --no-bundle",
55
+ "test": "aegir test --target node",
56
+ "lint": "aegir lint"
57
+ },
58
+ "author": "dao.xyz",
59
+ "license": "MIT",
60
+ "dependencies": {
61
+ "@dao-xyz/borsh": "^5.2.3",
62
+ "@peerbit/logger": "1.0.3",
63
+ "@peerbit/program": "5.0.0",
64
+ "@peerbit/log": "4.0.0",
65
+ "@peerbit/rpc": "5.0.0",
66
+ "@peerbit/time": "2.0.7",
67
+ "p-debounce": "^4.0.0"
68
+ },
69
+ "devDependencies": {
70
+ "@peerbit/test-utils": "^2.0.34"
71
+ }
72
72
  }