cojson 0.10.8 → 0.10.15

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.
Files changed (59) hide show
  1. package/.turbo/turbo-build.log +1 -1
  2. package/CHANGELOG.md +6 -0
  3. package/dist/coValueCore.js +3 -9
  4. package/dist/coValueCore.js.map +1 -1
  5. package/dist/coValues/account.js +9 -10
  6. package/dist/coValues/account.js.map +1 -1
  7. package/dist/coValues/group.js +1 -3
  8. package/dist/coValues/group.js.map +1 -1
  9. package/dist/localNode.js +3 -5
  10. package/dist/localNode.js.map +1 -1
  11. package/dist/permissions.js +2 -5
  12. package/dist/permissions.js.map +1 -1
  13. package/dist/tests/PeerKnownStates.test.js +82 -0
  14. package/dist/tests/PeerKnownStates.test.js.map +1 -0
  15. package/dist/tests/PeerState.test.js +188 -0
  16. package/dist/tests/PeerState.test.js.map +1 -0
  17. package/dist/tests/PriorityBasedMessageQueue.test.js +120 -0
  18. package/dist/tests/PriorityBasedMessageQueue.test.js.map +1 -0
  19. package/dist/tests/SyncStateManager.test.js +127 -0
  20. package/dist/tests/SyncStateManager.test.js.map +1 -0
  21. package/dist/tests/account.test.js +66 -0
  22. package/dist/tests/account.test.js.map +1 -0
  23. package/dist/tests/coList.test.js +120 -0
  24. package/dist/tests/coList.test.js.map +1 -0
  25. package/dist/tests/coMap.test.js +164 -0
  26. package/dist/tests/coMap.test.js.map +1 -0
  27. package/dist/tests/coPlainText.test.js +99 -0
  28. package/dist/tests/coPlainText.test.js.map +1 -0
  29. package/dist/tests/coStream.test.js +206 -0
  30. package/dist/tests/coStream.test.js.map +1 -0
  31. package/dist/tests/coValueCore.test.js +164 -0
  32. package/dist/tests/coValueCore.test.js.map +1 -0
  33. package/dist/tests/coValueState.test.js +364 -0
  34. package/dist/tests/coValueState.test.js.map +1 -0
  35. package/dist/tests/crypto.test.js +144 -0
  36. package/dist/tests/crypto.test.js.map +1 -0
  37. package/dist/tests/cryptoImpl.test.js +144 -0
  38. package/dist/tests/cryptoImpl.test.js.map +1 -0
  39. package/dist/tests/group.test.js +446 -0
  40. package/dist/tests/group.test.js.map +1 -0
  41. package/dist/tests/logger.test.js +118 -0
  42. package/dist/tests/logger.test.js.map +1 -0
  43. package/dist/tests/permissions.test.js +1858 -0
  44. package/dist/tests/permissions.test.js.map +1 -0
  45. package/dist/tests/priority.test.js +61 -0
  46. package/dist/tests/priority.test.js.map +1 -0
  47. package/dist/tests/sync.test.js +1548 -0
  48. package/dist/tests/sync.test.js.map +1 -0
  49. package/dist/tests/testUtils.js +312 -0
  50. package/dist/tests/testUtils.js.map +1 -0
  51. package/package.json +1 -1
  52. package/src/coValueCore.ts +3 -9
  53. package/src/coValues/account.ts +15 -15
  54. package/src/coValues/group.ts +1 -3
  55. package/src/localNode.ts +3 -5
  56. package/src/permissions.ts +2 -11
  57. package/src/tests/coValueCore.test.ts +2 -2
  58. package/src/tests/permissions.test.ts +45 -57
  59. package/tsconfig.json +1 -1
@@ -0,0 +1,446 @@
1
+ import { describe, expect, test } from "vitest";
2
+ import { CoValueState } from "../coValueState.js";
3
+ import { RawCoList } from "../coValues/coList.js";
4
+ import { RawCoMap } from "../coValues/coMap.js";
5
+ import { RawCoStream } from "../coValues/coStream.js";
6
+ import { RawBinaryCoStream } from "../coValues/coStream.js";
7
+ import { WasmCrypto } from "../crypto/WasmCrypto.js";
8
+ import { LocalNode } from "../localNode.js";
9
+ import { createThreeConnectedNodes, createTwoConnectedNodes, loadCoValueOrFail, randomAnonymousAccountAndSessionID, } from "./testUtils.js";
10
+ const Crypto = await WasmCrypto.create();
11
+ test("Can create a RawCoMap in a group", () => {
12
+ const node = new LocalNode(...randomAnonymousAccountAndSessionID(), Crypto);
13
+ const group = node.createGroup();
14
+ const map = group.createMap();
15
+ expect(map.core.getCurrentContent().type).toEqual("comap");
16
+ expect(map instanceof RawCoMap).toEqual(true);
17
+ });
18
+ test("Can create a CoList in a group", () => {
19
+ const node = new LocalNode(...randomAnonymousAccountAndSessionID(), Crypto);
20
+ const group = node.createGroup();
21
+ const list = group.createList();
22
+ expect(list.core.getCurrentContent().type).toEqual("colist");
23
+ expect(list instanceof RawCoList).toEqual(true);
24
+ });
25
+ test("Can create a CoStream in a group", () => {
26
+ const node = new LocalNode(...randomAnonymousAccountAndSessionID(), Crypto);
27
+ const group = node.createGroup();
28
+ const stream = group.createStream();
29
+ expect(stream.core.getCurrentContent().type).toEqual("costream");
30
+ expect(stream instanceof RawCoStream).toEqual(true);
31
+ });
32
+ test("Can create a FileStream in a group", () => {
33
+ const node = new LocalNode(...randomAnonymousAccountAndSessionID(), Crypto);
34
+ const group = node.createGroup();
35
+ const stream = group.createBinaryStream();
36
+ expect(stream.core.getCurrentContent().type).toEqual("costream");
37
+ expect(stream.headerMeta.type).toEqual("binary");
38
+ expect(stream instanceof RawBinaryCoStream).toEqual(true);
39
+ });
40
+ test("Remove a member from a group where the admin role is inherited", async () => {
41
+ const { node1, node2, node3 } = await createThreeConnectedNodes("server", "server", "server");
42
+ const group = node1.node.createGroup();
43
+ group.addMember(await loadCoValueOrFail(node1.node, node2.accountID), "admin");
44
+ group.addMember(await loadCoValueOrFail(node1.node, node3.accountID), "reader");
45
+ await group.core.waitForSync();
46
+ const groupOnNode2 = await loadCoValueOrFail(node2.node, group.id);
47
+ // The account of node2 create a child group and extend the initial group
48
+ // This way the node1 account should become "admin" of the child group
49
+ // by inheriting the admin role from the initial group
50
+ const childGroup = node2.node.createGroup();
51
+ childGroup.extend(groupOnNode2);
52
+ const map = childGroup.createMap();
53
+ map.set("test", "Available to everyone");
54
+ const mapOnNode3 = await loadCoValueOrFail(node3.node, map.id);
55
+ // Check that the sync between node2 and node3 worked
56
+ expect(mapOnNode3.get("test")).toEqual("Available to everyone");
57
+ // The node1 account removes the reader from the group
58
+ // The reader should be automatically kicked out of the child group
59
+ await group.removeMember(node3.node.account);
60
+ await group.core.waitForSync();
61
+ // Update the map to check that node3 can't read updates anymore
62
+ map.set("test", "Hidden to node3");
63
+ await map.core.waitForSync();
64
+ // Check that the value has not been updated on node3
65
+ expect(mapOnNode3.get("test")).toEqual("Available to everyone");
66
+ const mapOnNode1 = await loadCoValueOrFail(node1.node, map.id);
67
+ expect(mapOnNode1.get("test")).toEqual("Hidden to node3");
68
+ });
69
+ test("An admin should be able to rotate the readKey on child groups and keep access to new coValues", async () => {
70
+ const { node1, node2, node3 } = await createThreeConnectedNodes("server", "server", "server");
71
+ const group = node1.node.createGroup();
72
+ group.addMember(await loadCoValueOrFail(node1.node, node2.accountID), "admin");
73
+ group.addMember(await loadCoValueOrFail(node1.node, node3.accountID), "reader");
74
+ await group.core.waitForSync();
75
+ const groupOnNode2 = await loadCoValueOrFail(node2.node, group.id);
76
+ // The account of node2 create a child group and extend the initial group
77
+ // This way the node1 account should become "admin" of the child group
78
+ // by inheriting the admin role from the initial group
79
+ const childGroup = node2.node.createGroup();
80
+ childGroup.extend(groupOnNode2);
81
+ await childGroup.core.waitForSync();
82
+ // The node1 account removes the reader from the group
83
+ // In this case we want to ensure that node1 is still able to read new coValues
84
+ // Even if some childs are not available when the readKey is rotated
85
+ await group.removeMember(node3.node.account);
86
+ await group.core.waitForSync();
87
+ const map = childGroup.createMap();
88
+ map.set("test", "Available to node1");
89
+ const mapOnNode1 = await loadCoValueOrFail(node1.node, map.id);
90
+ expect(mapOnNode1.get("test")).toEqual("Available to node1");
91
+ });
92
+ test("An admin should be able to rotate the readKey on child groups even if it was unavailable when kicking out a member from a parent group", async () => {
93
+ const { node1, node2, node3 } = await createThreeConnectedNodes("server", "server", "server");
94
+ const group = node1.node.createGroup();
95
+ group.addMember(await loadCoValueOrFail(node1.node, node2.accountID), "admin");
96
+ group.addMember(await loadCoValueOrFail(node1.node, node3.accountID), "reader");
97
+ await group.core.waitForSync();
98
+ const groupOnNode2 = await loadCoValueOrFail(node2.node, group.id);
99
+ // The account of node2 create a child group and extend the initial group
100
+ // This way the node1 account should become "admin" of the child group
101
+ // by inheriting the admin role from the initial group
102
+ const childGroup = node2.node.createGroup();
103
+ childGroup.extend(groupOnNode2);
104
+ // The node1 account removes the reader from the group
105
+ // In this case we want to ensure that node1 is still able to read new coValues
106
+ // Even if some childs are not available when the readKey is rotated
107
+ await group.removeMember(node3.node.account);
108
+ await group.core.waitForSync();
109
+ const map = childGroup.createMap();
110
+ map.set("test", "Available to node1");
111
+ const mapOnNode1 = await loadCoValueOrFail(node1.node, map.id);
112
+ expect(mapOnNode1.get("test")).toEqual("Available to node1");
113
+ });
114
+ test("An admin should be able to rotate the readKey on child groups even if it was unavailable when kicking out a member from a parent group (grandChild)", async () => {
115
+ const { node1, node2, node3 } = await createThreeConnectedNodes("server", "server", "server");
116
+ const group = node1.node.createGroup();
117
+ group.addMember(await loadCoValueOrFail(node1.node, node2.accountID), "admin");
118
+ group.addMember(await loadCoValueOrFail(node1.node, node3.accountID), "reader");
119
+ await group.core.waitForSync();
120
+ const groupOnNode2 = await loadCoValueOrFail(node2.node, group.id);
121
+ // The account of node2 create a child group and extend the initial group
122
+ // This way the node1 account should become "admin" of the child group
123
+ // by inheriting the admin role from the initial group
124
+ const childGroup = node2.node.createGroup();
125
+ childGroup.extend(groupOnNode2);
126
+ const grandChildGroup = node2.node.createGroup();
127
+ grandChildGroup.extend(childGroup);
128
+ // The node1 account removes the reader from the group
129
+ // In this case we want to ensure that node1 is still able to read new coValues
130
+ // Even if some childs are not available when the readKey is rotated
131
+ await group.removeMember(node3.node.account);
132
+ await group.core.waitForSync();
133
+ const map = childGroup.createMap();
134
+ map.set("test", "Available to node1");
135
+ const mapOnNode1 = await loadCoValueOrFail(node1.node, map.id);
136
+ expect(mapOnNode1.get("test")).toEqual("Available to node1");
137
+ });
138
+ test("A user add after a key rotation should have access to the old transactions", async () => {
139
+ const { node1, node2, node3 } = await createThreeConnectedNodes("server", "server", "server");
140
+ const group = node1.node.createGroup();
141
+ group.addMember(await loadCoValueOrFail(node1.node, node2.accountID), "writer");
142
+ await group.core.waitForSync();
143
+ const groupOnNode2 = await loadCoValueOrFail(node2.node, group.id);
144
+ const map = groupOnNode2.createMap();
145
+ map.set("test", "Written from node2");
146
+ await map.core.waitForSync();
147
+ await group.removeMember(node3.node.account);
148
+ group.addMember(await loadCoValueOrFail(node1.node, node3.accountID), "reader");
149
+ await group.core.waitForSync();
150
+ const mapOnNode3 = await loadCoValueOrFail(node3.node, map.id);
151
+ expect(mapOnNode3.get("test")).toEqual("Written from node2");
152
+ });
153
+ test("Invites should have access to the new keys", async () => {
154
+ const { node1, node2, node3 } = await createThreeConnectedNodes("server", "server", "server");
155
+ const group = node1.node.createGroup();
156
+ group.addMember(await loadCoValueOrFail(node1.node, node3.accountID), "reader");
157
+ const invite = group.createInvite("admin");
158
+ await group.removeMember(node3.node.account);
159
+ const map = group.createMap();
160
+ map.set("test", "Written from node1");
161
+ await map.core.waitForSync();
162
+ await node2.node.acceptInvite(group.id, invite);
163
+ const mapOnNode2 = await loadCoValueOrFail(node2.node, map.id);
164
+ expect(mapOnNode2.get("test")).toEqual("Written from node1");
165
+ });
166
+ describe("writeOnly", () => {
167
+ test("Admins can invite writeOnly members", async () => {
168
+ const { node1, node2 } = await createTwoConnectedNodes("server", "server");
169
+ const group = node1.node.createGroup();
170
+ const invite = group.createInvite("writeOnly");
171
+ await node2.node.acceptInvite(group.id, invite);
172
+ const groupOnNode2 = await loadCoValueOrFail(node2.node, group.id);
173
+ expect(groupOnNode2.myRole()).toEqual("writeOnly");
174
+ });
175
+ test("writeOnly roles are not inherited", async () => {
176
+ const { node1, node2 } = await createTwoConnectedNodes("server", "server");
177
+ const group = node1.node.createGroup();
178
+ group.addMember(await loadCoValueOrFail(node1.node, node2.accountID), "writeOnly");
179
+ const childGroup = node1.node.createGroup();
180
+ childGroup.extend(group);
181
+ expect(childGroup.roleOf(node2.accountID)).toEqual(undefined);
182
+ });
183
+ test("writeOnly roles are not overridded by reader roles", async () => {
184
+ const { node1, node2 } = await createTwoConnectedNodes("server", "server");
185
+ const group = node1.node.createGroup();
186
+ group.addMember(await loadCoValueOrFail(node1.node, node2.accountID), "reader");
187
+ const childGroup = node1.node.createGroup();
188
+ childGroup.extend(group);
189
+ childGroup.addMember(await loadCoValueOrFail(node1.node, node2.accountID), "writeOnly");
190
+ expect(childGroup.roleOf(node2.accountID)).toEqual("writeOnly");
191
+ });
192
+ test("writeOnly roles are overridded by writer roles", async () => {
193
+ const { node1, node2 } = await createTwoConnectedNodes("server", "server");
194
+ const group = node1.node.createGroup();
195
+ group.addMember(await loadCoValueOrFail(node1.node, node2.accountID), "writer");
196
+ const childGroup = node1.node.createGroup();
197
+ childGroup.extend(group);
198
+ childGroup.addMember(await loadCoValueOrFail(node1.node, node2.accountID), "writeOnly");
199
+ expect(childGroup.roleOf(node2.accountID)).toEqual("writer");
200
+ });
201
+ test("Edits by writeOnly members are visible to other members", async () => {
202
+ const { node1, node2, node3 } = await createThreeConnectedNodes("server", "server", "server");
203
+ const group = node1.node.createGroup();
204
+ group.addMember(await loadCoValueOrFail(node1.node, node2.accountID), "writeOnly");
205
+ group.addMember(await loadCoValueOrFail(node1.node, node3.accountID), "reader");
206
+ await group.core.waitForSync();
207
+ const groupOnNode2 = await loadCoValueOrFail(node2.node, group.id);
208
+ const map = groupOnNode2.createMap();
209
+ map.set("test", "Written from a writeOnly member");
210
+ expect(map.get("test")).toEqual("Written from a writeOnly member");
211
+ await map.core.waitForSync();
212
+ const mapOnNode1 = await loadCoValueOrFail(node1.node, map.id);
213
+ expect(mapOnNode1.get("test")).toEqual("Written from a writeOnly member");
214
+ const mapOnNode3 = await loadCoValueOrFail(node3.node, map.id);
215
+ expect(mapOnNode3.get("test")).toEqual("Written from a writeOnly member");
216
+ });
217
+ test("Edits by other members are not visible to writeOnly members", async () => {
218
+ const { node1, node2 } = await createTwoConnectedNodes("server", "server");
219
+ const group = node1.node.createGroup();
220
+ group.addMember(await loadCoValueOrFail(node1.node, node2.accountID), "writeOnly");
221
+ const map = group.createMap();
222
+ map.set("test", "Written from the admin");
223
+ await map.core.waitForSync();
224
+ const mapOnNode2 = await loadCoValueOrFail(node2.node, map.id);
225
+ expect(mapOnNode2.get("test")).toEqual(undefined);
226
+ });
227
+ test("Write only member keys are rotated when a member is kicked out", async () => {
228
+ const { node1, node2, node3 } = await createThreeConnectedNodes("server", "server", "server");
229
+ const group = node1.node.createGroup();
230
+ group.addMember(await loadCoValueOrFail(node1.node, node2.accountID), "writeOnly");
231
+ group.addMember(await loadCoValueOrFail(node1.node, node3.accountID), "reader");
232
+ await group.core.waitForSync();
233
+ const groupOnNode2 = await loadCoValueOrFail(node2.node, group.id);
234
+ const map = groupOnNode2.createMap();
235
+ map.set("test", "Written from a writeOnly member");
236
+ await map.core.waitForSync();
237
+ await group.removeMember(node3.node.account);
238
+ await group.core.waitForSync();
239
+ map.set("test", "Updated after key rotation");
240
+ await map.core.waitForSync();
241
+ const mapOnNode1 = await loadCoValueOrFail(node1.node, map.id);
242
+ expect(mapOnNode1.get("test")).toEqual("Updated after key rotation");
243
+ const mapOnNode3 = await loadCoValueOrFail(node3.node, map.id);
244
+ expect(mapOnNode3.get("test")).toEqual("Written from a writeOnly member");
245
+ });
246
+ test("upgrade to writer roles should work correctly", async () => {
247
+ const { node1, node2 } = await createTwoConnectedNodes("server", "server");
248
+ const group = node1.node.createGroup();
249
+ group.addMember(await loadCoValueOrFail(node1.node, node2.accountID), "writeOnly");
250
+ await group.core.waitForSync();
251
+ const groupOnNode2 = await loadCoValueOrFail(node2.node, group.id);
252
+ const map = groupOnNode2.createMap();
253
+ map.set("test", "Written from the writeOnly member");
254
+ await map.core.waitForSync();
255
+ group.addMember(await loadCoValueOrFail(node1.node, node2.accountID), "writer");
256
+ group.core.waitForSync();
257
+ node2.node.coValuesStore.coValues.delete(map.id);
258
+ expect(node2.node.coValuesStore.get(map.id)).toEqual(CoValueState.Unknown(map.id));
259
+ const mapOnNode2 = await loadCoValueOrFail(node2.node, map.id);
260
+ // The writer role should be able to see the edits from the admin
261
+ expect(mapOnNode2.get("test")).toEqual("Written from the writeOnly member");
262
+ });
263
+ });
264
+ describe("extend", () => {
265
+ test("inherited writer roles should work correctly", async () => {
266
+ const { node1, node2 } = await createTwoConnectedNodes("server", "server");
267
+ const group = node1.node.createGroup();
268
+ group.addMember(await loadCoValueOrFail(node1.node, node2.accountID), "writer");
269
+ const childGroup = node1.node.createGroup();
270
+ childGroup.extend(group);
271
+ childGroup.addMember(await loadCoValueOrFail(node1.node, node2.accountID), "writeOnly");
272
+ const map = childGroup.createMap();
273
+ map.set("test", "Written from the admin");
274
+ await map.core.waitForSync();
275
+ const mapOnNode2 = await loadCoValueOrFail(node2.node, map.id);
276
+ // The writer role should be able to see the edits from the admin
277
+ expect(mapOnNode2.get("test")).toEqual("Written from the admin");
278
+ });
279
+ test("a user should be able to extend a group when his role on the parent group is writer", async () => {
280
+ const { node1, node2 } = await createTwoConnectedNodes("server", "server");
281
+ const group = node1.node.createGroup();
282
+ group.addMember(await loadCoValueOrFail(node1.node, node2.accountID), "writer");
283
+ await group.core.waitForSync();
284
+ const groupOnNode2 = await loadCoValueOrFail(node2.node, group.id);
285
+ const childGroup = node2.node.createGroup();
286
+ childGroup.extend(groupOnNode2);
287
+ const map = childGroup.createMap();
288
+ map.set("test", "Written from node2");
289
+ await map.core.waitForSync();
290
+ await childGroup.core.waitForSync();
291
+ const mapOnNode2 = await loadCoValueOrFail(node2.node, map.id);
292
+ expect(mapOnNode2.get("test")).toEqual("Written from node2");
293
+ });
294
+ test("a user should be able to extend a group when his role on the parent group is reader", async () => {
295
+ const { node1, node2 } = await createTwoConnectedNodes("server", "server");
296
+ const group = node1.node.createGroup();
297
+ group.addMember(await loadCoValueOrFail(node1.node, node2.accountID), "reader");
298
+ await group.core.waitForSync();
299
+ const groupOnNode2 = await loadCoValueOrFail(node2.node, group.id);
300
+ const childGroup = node2.node.createGroup();
301
+ childGroup.extend(groupOnNode2);
302
+ const map = childGroup.createMap();
303
+ map.set("test", "Written from node2");
304
+ await map.core.waitForSync();
305
+ await childGroup.core.waitForSync();
306
+ const mapOnNode2 = await loadCoValueOrFail(node2.node, map.id);
307
+ expect(mapOnNode2.get("test")).toEqual("Written from node2");
308
+ });
309
+ test("a user should be able to extend a group when his role on the parent group is writeOnly", async () => {
310
+ const { node1, node2 } = await createTwoConnectedNodes("server", "server");
311
+ const group = node1.node.createGroup();
312
+ group.addMember(await loadCoValueOrFail(node1.node, node2.accountID), "writeOnly");
313
+ await group.core.waitForSync();
314
+ const groupOnNode2 = await loadCoValueOrFail(node2.node, group.id);
315
+ const childGroup = node2.node.createGroup();
316
+ childGroup.extend(groupOnNode2);
317
+ const map = childGroup.createMap();
318
+ map.set("test", "Written from node2");
319
+ await map.core.waitForSync();
320
+ await childGroup.core.waitForSync();
321
+ const mapOnNode2 = await loadCoValueOrFail(node2.node, map.id);
322
+ expect(mapOnNode2.get("test")).toEqual("Written from node2");
323
+ });
324
+ test("self-extend a group should not break anything", async () => {
325
+ const { node1 } = await createTwoConnectedNodes("server", "server");
326
+ const group = node1.node.createGroup();
327
+ group.extend(group);
328
+ const map = group.createMap();
329
+ map.set("test", "Hello!");
330
+ expect(map.get("test")).toEqual("Hello!");
331
+ });
332
+ test("should not break when introducing extend cycles", async () => {
333
+ const { node1 } = await createTwoConnectedNodes("server", "server");
334
+ const group = node1.node.createGroup();
335
+ const group2 = node1.node.createGroup();
336
+ const group3 = node1.node.createGroup();
337
+ group.extend(group2);
338
+ group2.extend(group3);
339
+ group3.extend(group);
340
+ const map = group.createMap();
341
+ map.set("test", "Hello!");
342
+ expect(map.get("test")).toEqual("Hello!");
343
+ });
344
+ test("a writerInvite role should not be inherited", async () => {
345
+ const { node1, node2 } = await createTwoConnectedNodes("server", "server");
346
+ const group = node1.node.createGroup();
347
+ group.addMember(await loadCoValueOrFail(node1.node, node2.accountID), "writerInvite");
348
+ const childGroup = node1.node.createGroup();
349
+ childGroup.extend(group);
350
+ expect(childGroup.roleOf(node2.accountID)).toEqual(undefined);
351
+ });
352
+ });
353
+ describe("extend with role mapping", () => {
354
+ test("mapping to writer should add the ability to write", async () => {
355
+ const { node1, node2 } = await createTwoConnectedNodes("server", "server");
356
+ const group = node1.node.createGroup();
357
+ group.addMember(await loadCoValueOrFail(node1.node, node2.accountID), "reader");
358
+ const childGroup = node1.node.createGroup();
359
+ childGroup.extend(group, "writer");
360
+ expect(childGroup.roleOf(node2.accountID)).toEqual("writer");
361
+ const map = childGroup.createMap();
362
+ map.set("test", "Written from the admin");
363
+ await map.core.waitForSync();
364
+ const mapOnNode2 = await loadCoValueOrFail(node2.node, map.id);
365
+ expect(mapOnNode2.get("test")).toEqual("Written from the admin");
366
+ mapOnNode2.set("test", "Written from the inherited role");
367
+ expect(mapOnNode2.get("test")).toEqual("Written from the inherited role");
368
+ await mapOnNode2.core.waitForSync();
369
+ expect(map.get("test")).toEqual("Written from the inherited role");
370
+ });
371
+ test("mapping to reader should remove the ability to write", async () => {
372
+ const { node1, node2 } = await createTwoConnectedNodes("server", "server");
373
+ const group = node1.node.createGroup();
374
+ group.addMember(await loadCoValueOrFail(node1.node, node2.accountID), "writer");
375
+ const childGroup = node1.node.createGroup();
376
+ childGroup.extend(group, "reader");
377
+ expect(childGroup.roleOf(node2.accountID)).toEqual("reader");
378
+ const map = childGroup.createMap();
379
+ map.set("test", "Written from the admin");
380
+ await map.core.waitForSync();
381
+ const mapOnNode2 = await loadCoValueOrFail(node2.node, map.id);
382
+ expect(mapOnNode2.get("test")).toEqual("Written from the admin");
383
+ mapOnNode2.set("test", "Should not be visible");
384
+ await mapOnNode2.core.waitForSync();
385
+ expect(map.get("test")).toEqual("Written from the admin");
386
+ expect(mapOnNode2.get("test")).toEqual("Written from the admin");
387
+ });
388
+ test("mapping to admin should add the ability to add members", async () => {
389
+ const { node1, node2, node3 } = await createThreeConnectedNodes("server", "server", "server");
390
+ const group = node1.node.createGroup();
391
+ group.addMember(await loadCoValueOrFail(node1.node, node2.accountID), "reader");
392
+ const childGroup = node1.node.createGroup();
393
+ childGroup.extend(group, "admin");
394
+ expect(childGroup.roleOf(node2.accountID)).toEqual("admin");
395
+ await childGroup.core.waitForSync();
396
+ const childGroupOnNode2 = await loadCoValueOrFail(node2.node, childGroup.id);
397
+ childGroupOnNode2.addMember(await loadCoValueOrFail(node2.node, node3.accountID), "reader");
398
+ expect(childGroupOnNode2.roleOf(node3.accountID)).toEqual("reader");
399
+ });
400
+ test("mapping to reader should remove the ability to add members", async () => {
401
+ const { node1, node2, node3 } = await createThreeConnectedNodes("server", "server", "server");
402
+ const group = node1.node.createGroup();
403
+ group.addMember(await loadCoValueOrFail(node1.node, node2.accountID), "admin");
404
+ const childGroup = node1.node.createGroup();
405
+ childGroup.extend(group, "reader");
406
+ expect(childGroup.roleOf(node2.accountID)).toEqual("reader");
407
+ await childGroup.core.waitForSync();
408
+ const childGroupOnNode2 = await loadCoValueOrFail(node2.node, childGroup.id);
409
+ const accountToAdd = await loadCoValueOrFail(node2.node, node3.accountID);
410
+ expect(() => {
411
+ childGroupOnNode2.addMember(accountToAdd, "reader");
412
+ }).toThrow();
413
+ expect(childGroupOnNode2.roleOf(node3.accountID)).toEqual(undefined);
414
+ });
415
+ test("non-inheritable roles should not give access to the child group when role mapping is used", async () => {
416
+ const { node1, node2 } = await createTwoConnectedNodes("server", "server");
417
+ const group = node1.node.createGroup();
418
+ group.addMember(await loadCoValueOrFail(node1.node, node2.accountID), "writeOnly");
419
+ const childGroup = node1.node.createGroup();
420
+ childGroup.extend(group, "reader");
421
+ expect(childGroup.roleOf(node2.accountID)).toEqual(undefined);
422
+ const map = childGroup.createMap();
423
+ map.set("test", "Written from the admin");
424
+ await map.core.waitForSync();
425
+ const mapOnNode2 = await loadCoValueOrFail(node2.node, map.id);
426
+ expect(mapOnNode2.get("test")).toEqual(undefined);
427
+ });
428
+ test("invite roles should not give write access to the child group when role mapping is used", async () => {
429
+ const { node1, node2 } = await createTwoConnectedNodes("server", "server");
430
+ const group = node1.node.createGroup();
431
+ group.addMember(await loadCoValueOrFail(node1.node, node2.accountID), "writerInvite");
432
+ const childGroup = node1.node.createGroup();
433
+ childGroup.extend(group, "writer");
434
+ expect(childGroup.roleOf(node2.accountID)).toEqual(undefined);
435
+ const map = childGroup.createMap();
436
+ map.set("test", "Written from the admin");
437
+ await map.core.waitForSync();
438
+ const mapOnNode2 = await loadCoValueOrFail(node2.node, map.id);
439
+ expect(mapOnNode2.get("test")).toEqual("Written from the admin"); // The invite roles have access to the readKey hence can read the values on inherited groups
440
+ mapOnNode2.set("test", "Should not be visible");
441
+ await mapOnNode2.core.waitForSync();
442
+ expect(map.get("test")).toEqual("Written from the admin");
443
+ expect(mapOnNode2.get("test")).toEqual("Written from the admin");
444
+ });
445
+ });
446
+ //# sourceMappingURL=group.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"group.test.js","sourceRoot":"","sources":["../../src/tests/group.test.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,118 @@
1
+ import { describe, expect, test, vi } from "vitest";
2
+ import { LogLevel, Logger } from "../logger";
3
+ describe("Logger", () => {
4
+ describe("Log Level Filtering", () => {
5
+ test("should respect log level hierarchy", () => {
6
+ const mockLogSystem = {
7
+ debug: vi.fn(),
8
+ info: vi.fn(),
9
+ warn: vi.fn(),
10
+ error: vi.fn(),
11
+ };
12
+ const logger = new Logger(LogLevel.WARN, mockLogSystem);
13
+ logger.debug("Debug message");
14
+ logger.info("Info message");
15
+ logger.warn("Warning message");
16
+ logger.error("Error message");
17
+ expect(mockLogSystem.debug).not.toHaveBeenCalled();
18
+ expect(mockLogSystem.info).not.toHaveBeenCalled();
19
+ expect(mockLogSystem.warn).toHaveBeenCalledWith("Warning message", undefined);
20
+ expect(mockLogSystem.error).toHaveBeenCalledWith("Error message", undefined);
21
+ });
22
+ test("should pass additional arguments to log system", () => {
23
+ const mockLogSystem = {
24
+ debug: vi.fn(),
25
+ info: vi.fn(),
26
+ warn: vi.fn(),
27
+ error: vi.fn(),
28
+ };
29
+ const logger = new Logger(LogLevel.DEBUG, mockLogSystem);
30
+ logger.debug("Debug message", { foo: "bar" });
31
+ expect(mockLogSystem.debug).toHaveBeenCalledWith("Debug message", {
32
+ foo: "bar",
33
+ });
34
+ });
35
+ });
36
+ describe("Log System Configuration", () => {
37
+ test("should allow changing log level at runtime", () => {
38
+ const mockLogSystem = {
39
+ debug: vi.fn(),
40
+ info: vi.fn(),
41
+ warn: vi.fn(),
42
+ error: vi.fn(),
43
+ };
44
+ const logger = new Logger(LogLevel.ERROR, mockLogSystem);
45
+ logger.warn("Warning 1"); // Should not log
46
+ expect(mockLogSystem.warn).not.toHaveBeenCalled();
47
+ logger.setLevel(LogLevel.WARN);
48
+ logger.warn("Warning 2"); // Should log
49
+ expect(mockLogSystem.warn).toHaveBeenCalledWith("Warning 2", undefined);
50
+ });
51
+ test("should allow changing log system at runtime", () => {
52
+ const mockLogSystem1 = {
53
+ debug: vi.fn(),
54
+ info: vi.fn(),
55
+ warn: vi.fn(),
56
+ error: vi.fn(),
57
+ };
58
+ const mockLogSystem2 = {
59
+ debug: vi.fn(),
60
+ info: vi.fn(),
61
+ warn: vi.fn(),
62
+ error: vi.fn(),
63
+ };
64
+ const logger = new Logger(LogLevel.INFO, mockLogSystem1);
65
+ logger.info("Message 1");
66
+ expect(mockLogSystem1.info).toHaveBeenCalledWith("Message 1", undefined);
67
+ expect(mockLogSystem2.info).not.toHaveBeenCalled();
68
+ logger.setLogSystem(mockLogSystem2);
69
+ logger.info("Message 2");
70
+ expect(mockLogSystem2.info).toHaveBeenCalledWith("Message 2", undefined);
71
+ expect(mockLogSystem1.info).toHaveBeenCalledTimes(1);
72
+ });
73
+ });
74
+ describe("Default Console Log System", () => {
75
+ test("should use console methods by default", () => {
76
+ const consoleSpy = {
77
+ debug: vi.spyOn(console, "debug").mockImplementation(() => { }),
78
+ info: vi.spyOn(console, "info").mockImplementation(() => { }),
79
+ warn: vi.spyOn(console, "warn").mockImplementation(() => { }),
80
+ error: vi.spyOn(console, "error").mockImplementation(() => { }),
81
+ };
82
+ const logger = new Logger();
83
+ logger.setLevel(LogLevel.DEBUG);
84
+ const testMessage = "Test message";
85
+ const testArgs = { data: "test" };
86
+ logger.debug(testMessage, testArgs);
87
+ logger.info(testMessage, testArgs);
88
+ logger.warn(testMessage, testArgs);
89
+ logger.error(testMessage, testArgs);
90
+ expect(consoleSpy.debug).toHaveBeenCalledWith(testMessage, testArgs);
91
+ expect(consoleSpy.info).toHaveBeenCalledWith(testMessage, testArgs);
92
+ expect(consoleSpy.warn).toHaveBeenCalledWith(testMessage, testArgs);
93
+ expect(consoleSpy.error).toHaveBeenCalledWith(testMessage, testArgs);
94
+ // Cleanup
95
+ Object.values(consoleSpy).forEach((spy) => spy.mockRestore());
96
+ });
97
+ });
98
+ describe("Log Level NONE", () => {
99
+ test("should not log anything when level is NONE", () => {
100
+ const mockLogSystem = {
101
+ debug: vi.fn(),
102
+ info: vi.fn(),
103
+ warn: vi.fn(),
104
+ error: vi.fn(),
105
+ };
106
+ const logger = new Logger(LogLevel.NONE, mockLogSystem);
107
+ logger.debug("Debug message");
108
+ logger.info("Info message");
109
+ logger.warn("Warning message");
110
+ logger.error("Error message");
111
+ expect(mockLogSystem.debug).not.toHaveBeenCalled();
112
+ expect(mockLogSystem.info).not.toHaveBeenCalled();
113
+ expect(mockLogSystem.warn).not.toHaveBeenCalled();
114
+ expect(mockLogSystem.error).not.toHaveBeenCalled();
115
+ });
116
+ });
117
+ });
118
+ //# sourceMappingURL=logger.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"logger.test.js","sourceRoot":"","sources":["../../src/tests/logger.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,IAAI,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAC;AACpD,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,MAAM,WAAW,CAAC;AAE7C,QAAQ,CAAC,QAAQ,EAAE,GAAG,EAAE;IACtB,QAAQ,CAAC,qBAAqB,EAAE,GAAG,EAAE;QACnC,IAAI,CAAC,oCAAoC,EAAE,GAAG,EAAE;YAC9C,MAAM,aAAa,GAAG;gBACpB,KAAK,EAAE,EAAE,CAAC,EAAE,EAAE;gBACd,IAAI,EAAE,EAAE,CAAC,EAAE,EAAE;gBACb,IAAI,EAAE,EAAE,CAAC,EAAE,EAAE;gBACb,KAAK,EAAE,EAAE,CAAC,EAAE,EAAE;aACf,CAAC;YAEF,MAAM,MAAM,GAAG,IAAI,MAAM,CAAC,QAAQ,CAAC,IAAI,EAAE,aAAa,CAAC,CAAC;YAExD,MAAM,CAAC,KAAK,CAAC,eAAe,CAAC,CAAC;YAC9B,MAAM,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;YAC5B,MAAM,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC;YAC/B,MAAM,CAAC,KAAK,CAAC,eAAe,CAAC,CAAC;YAE9B,MAAM,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC,GAAG,CAAC,gBAAgB,EAAE,CAAC;YACnD,MAAM,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,gBAAgB,EAAE,CAAC;YAClD,MAAM,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC,oBAAoB,CAC7C,iBAAiB,EACjB,SAAS,CACV,CAAC;YACF,MAAM,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC,oBAAoB,CAC9C,eAAe,EACf,SAAS,CACV,CAAC;QACJ,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,gDAAgD,EAAE,GAAG,EAAE;YAC1D,MAAM,aAAa,GAAG;gBACpB,KAAK,EAAE,EAAE,CAAC,EAAE,EAAE;gBACd,IAAI,EAAE,EAAE,CAAC,EAAE,EAAE;gBACb,IAAI,EAAE,EAAE,CAAC,EAAE,EAAE;gBACb,KAAK,EAAE,EAAE,CAAC,EAAE,EAAE;aACf,CAAC;YAEF,MAAM,MAAM,GAAG,IAAI,MAAM,CAAC,QAAQ,CAAC,KAAK,EAAE,aAAa,CAAC,CAAC;YAEzD,MAAM,CAAC,KAAK,CAAC,eAAe,EAAE,EAAE,GAAG,EAAE,KAAK,EAAE,CAAC,CAAC;YAE9C,MAAM,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC,oBAAoB,CAAC,eAAe,EAAE;gBAChE,GAAG,EAAE,KAAK;aACX,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,QAAQ,CAAC,0BAA0B,EAAE,GAAG,EAAE;QACxC,IAAI,CAAC,4CAA4C,EAAE,GAAG,EAAE;YACtD,MAAM,aAAa,GAAG;gBACpB,KAAK,EAAE,EAAE,CAAC,EAAE,EAAE;gBACd,IAAI,EAAE,EAAE,CAAC,EAAE,EAAE;gBACb,IAAI,EAAE,EAAE,CAAC,EAAE,EAAE;gBACb,KAAK,EAAE,EAAE,CAAC,EAAE,EAAE;aACf,CAAC;YAEF,MAAM,MAAM,GAAG,IAAI,MAAM,CAAC,QAAQ,CAAC,KAAK,EAAE,aAAa,CAAC,CAAC;YAEzD,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,iBAAiB;YAC3C,MAAM,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,gBAAgB,EAAE,CAAC;YAElD,MAAM,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;YAC/B,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,aAAa;YACvC,MAAM,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC,oBAAoB,CAAC,WAAW,EAAE,SAAS,CAAC,CAAC;QAC1E,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,6CAA6C,EAAE,GAAG,EAAE;YACvD,MAAM,cAAc,GAAG;gBACrB,KAAK,EAAE,EAAE,CAAC,EAAE,EAAE;gBACd,IAAI,EAAE,EAAE,CAAC,EAAE,EAAE;gBACb,IAAI,EAAE,EAAE,CAAC,EAAE,EAAE;gBACb,KAAK,EAAE,EAAE,CAAC,EAAE,EAAE;aACf,CAAC;YAEF,MAAM,cAAc,GAAG;gBACrB,KAAK,EAAE,EAAE,CAAC,EAAE,EAAE;gBACd,IAAI,EAAE,EAAE,CAAC,EAAE,EAAE;gBACb,IAAI,EAAE,EAAE,CAAC,EAAE,EAAE;gBACb,KAAK,EAAE,EAAE,CAAC,EAAE,EAAE;aACf,CAAC;YAEF,MAAM,MAAM,GAAG,IAAI,MAAM,CAAC,QAAQ,CAAC,IAAI,EAAE,cAAc,CAAC,CAAC;YAEzD,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;YACzB,MAAM,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC,oBAAoB,CAAC,WAAW,EAAE,SAAS,CAAC,CAAC;YACzE,MAAM,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,gBAAgB,EAAE,CAAC;YAEnD,MAAM,CAAC,YAAY,CAAC,cAAc,CAAC,CAAC;YACpC,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;YACzB,MAAM,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC,oBAAoB,CAAC,WAAW,EAAE,SAAS,CAAC,CAAC;YACzE,MAAM,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC;QACvD,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,QAAQ,CAAC,4BAA4B,EAAE,GAAG,EAAE;QAC1C,IAAI,CAAC,uCAAuC,EAAE,GAAG,EAAE;YACjD,MAAM,UAAU,GAAG;gBACjB,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC,kBAAkB,CAAC,GAAG,EAAE,GAAE,CAAC,CAAC;gBAC9D,IAAI,EAAE,EAAE,CAAC,KAAK,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC,kBAAkB,CAAC,GAAG,EAAE,GAAE,CAAC,CAAC;gBAC5D,IAAI,EAAE,EAAE,CAAC,KAAK,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC,kBAAkB,CAAC,GAAG,EAAE,GAAE,CAAC,CAAC;gBAC5D,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC,kBAAkB,CAAC,GAAG,EAAE,GAAE,CAAC,CAAC;aAC/D,CAAC;YAEF,MAAM,MAAM,GAAG,IAAI,MAAM,EAAE,CAAC;YAC5B,MAAM,CAAC,QAAQ,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;YAChC,MAAM,WAAW,GAAG,cAAc,CAAC;YACnC,MAAM,QAAQ,GAAG,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;YAElC,MAAM,CAAC,KAAK,CAAC,WAAW,EAAE,QAAQ,CAAC,CAAC;YACpC,MAAM,CAAC,IAAI,CAAC,WAAW,EAAE,QAAQ,CAAC,CAAC;YACnC,MAAM,CAAC,IAAI,CAAC,WAAW,EAAE,QAAQ,CAAC,CAAC;YACnC,MAAM,CAAC,KAAK,CAAC,WAAW,EAAE,QAAQ,CAAC,CAAC;YAEpC,MAAM,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC,oBAAoB,CAAC,WAAW,EAAE,QAAQ,CAAC,CAAC;YACrE,MAAM,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,oBAAoB,CAAC,WAAW,EAAE,QAAQ,CAAC,CAAC;YACpE,MAAM,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,oBAAoB,CAAC,WAAW,EAAE,QAAQ,CAAC,CAAC;YACpE,MAAM,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC,oBAAoB,CAAC,WAAW,EAAE,QAAQ,CAAC,CAAC;YAErE,UAAU;YACV,MAAM,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC,OAAO,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,WAAW,EAAE,CAAC,CAAC;QAChE,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,QAAQ,CAAC,gBAAgB,EAAE,GAAG,EAAE;QAC9B,IAAI,CAAC,4CAA4C,EAAE,GAAG,EAAE;YACtD,MAAM,aAAa,GAAG;gBACpB,KAAK,EAAE,EAAE,CAAC,EAAE,EAAE;gBACd,IAAI,EAAE,EAAE,CAAC,EAAE,EAAE;gBACb,IAAI,EAAE,EAAE,CAAC,EAAE,EAAE;gBACb,KAAK,EAAE,EAAE,CAAC,EAAE,EAAE;aACf,CAAC;YAEF,MAAM,MAAM,GAAG,IAAI,MAAM,CAAC,QAAQ,CAAC,IAAI,EAAE,aAAa,CAAC,CAAC;YAExD,MAAM,CAAC,KAAK,CAAC,eAAe,CAAC,CAAC;YAC9B,MAAM,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;YAC5B,MAAM,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC;YAC/B,MAAM,CAAC,KAAK,CAAC,eAAe,CAAC,CAAC;YAE9B,MAAM,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC,GAAG,CAAC,gBAAgB,EAAE,CAAC;YACnD,MAAM,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,gBAAgB,EAAE,CAAC;YAClD,MAAM,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,gBAAgB,EAAE,CAAC;YAClD,MAAM,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC,GAAG,CAAC,gBAAgB,EAAE,CAAC;QACrD,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}