@ibgib/core-gib 0.1.54 → 0.1.57

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 (190) hide show
  1. package/CHANGELOG.md +11 -3
  2. package/README.md +12 -15
  3. package/dist/keystone/aggregate-details.respec.d.mts +2 -0
  4. package/dist/keystone/aggregate-details.respec.d.mts.map +1 -0
  5. package/dist/keystone/aggregate-details.respec.mjs +118 -0
  6. package/dist/keystone/aggregate-details.respec.mjs.map +1 -0
  7. package/dist/keystone/keystone-constants.d.mts +5 -0
  8. package/dist/keystone/keystone-constants.d.mts.map +1 -1
  9. package/dist/keystone/keystone-constants.mjs +6 -1
  10. package/dist/keystone/keystone-constants.mjs.map +1 -1
  11. package/dist/keystone/keystone-helpers.d.mts +7 -1
  12. package/dist/keystone/keystone-helpers.d.mts.map +1 -1
  13. package/dist/keystone/keystone-helpers.mjs +5 -2
  14. package/dist/keystone/keystone-helpers.mjs.map +1 -1
  15. package/dist/keystone/keystone-service-v1.d.mts +51 -0
  16. package/dist/keystone/keystone-service-v1.d.mts.map +1 -1
  17. package/dist/keystone/keystone-service-v1.mjs +176 -9
  18. package/dist/keystone/keystone-service-v1.mjs.map +1 -1
  19. package/dist/keystone/keystone-service-v1.respec.mjs +40 -98
  20. package/dist/keystone/keystone-service-v1.respec.mjs.map +1 -1
  21. package/dist/keystone/keystone-types.d.mts +5 -0
  22. package/dist/keystone/keystone-types.d.mts.map +1 -1
  23. package/dist/sync/graft-info/graft-info-helpers.respec.mjs +8 -8
  24. package/dist/sync/graft-info/graft-info-helpers.respec.mjs.map +1 -1
  25. package/dist/sync/sync-conflict-adv-multitimelines.respec.mjs +26 -30
  26. package/dist/sync/sync-conflict-adv-multitimelines.respec.mjs.map +1 -1
  27. package/dist/sync/sync-conflict-basic-divergence.respec.mjs +7 -8
  28. package/dist/sync/sync-conflict-basic-divergence.respec.mjs.map +1 -1
  29. package/dist/sync/sync-conflict-basic-multitimelines.respec.mjs +10 -11
  30. package/dist/sync/sync-conflict-basic-multitimelines.respec.mjs.map +1 -1
  31. package/dist/sync/sync-conflict-text-merge.respec.mjs +30 -33
  32. package/dist/sync/sync-conflict-text-merge.respec.mjs.map +1 -1
  33. package/dist/sync/sync-constants.d.mts +1 -56
  34. package/dist/sync/sync-constants.d.mts.map +1 -1
  35. package/dist/sync/sync-constants.mjs +2 -59
  36. package/dist/sync/sync-constants.mjs.map +1 -1
  37. package/dist/sync/sync-helpers.d.mts +0 -1
  38. package/dist/sync/sync-helpers.d.mts.map +1 -1
  39. package/dist/sync/sync-helpers.mjs +1 -6
  40. package/dist/sync/sync-helpers.mjs.map +1 -1
  41. package/dist/sync/sync-innerspace-constants.respec.mjs +5 -9
  42. package/dist/sync/sync-innerspace-constants.respec.mjs.map +1 -1
  43. package/dist/sync/sync-innerspace-deep-updates.respec.mjs +6 -7
  44. package/dist/sync/sync-innerspace-deep-updates.respec.mjs.map +1 -1
  45. package/dist/sync/sync-innerspace-dest-ahead-withid.respec.mjs +22 -22
  46. package/dist/sync/sync-innerspace-dest-ahead-withid.respec.mjs.map +1 -1
  47. package/dist/sync/sync-innerspace-dest-ahead.respec.mjs +8 -9
  48. package/dist/sync/sync-innerspace-dest-ahead.respec.mjs.map +1 -1
  49. package/dist/sync/sync-innerspace-multiple-timelines.respec.mjs +6 -7
  50. package/dist/sync/sync-innerspace-multiple-timelines.respec.mjs.map +1 -1
  51. package/dist/sync/sync-innerspace-partial-update.respec.mjs +7 -8
  52. package/dist/sync/sync-innerspace-partial-update.respec.mjs.map +1 -1
  53. package/dist/sync/sync-innerspace.respec.mjs +8 -11
  54. package/dist/sync/sync-innerspace.respec.mjs.map +1 -1
  55. package/dist/sync/sync-peer/sync-peer-http-receiver/sync-http-node-adapter.mjs +10 -5
  56. package/dist/sync/sync-peer/sync-peer-http-receiver/sync-http-node-adapter.mjs.map +1 -1
  57. package/dist/sync/sync-peer/sync-peer-http-receiver/sync-peer-http-receiver-types.d.mts +3 -1
  58. package/dist/sync/sync-peer/sync-peer-http-receiver/sync-peer-http-receiver-types.d.mts.map +1 -1
  59. package/dist/sync/sync-peer/sync-peer-http-receiver/sync-peer-http-receiver-v1.d.mts +4 -2
  60. package/dist/sync/sync-peer/sync-peer-http-receiver/sync-peer-http-receiver-v1.d.mts.map +1 -1
  61. package/dist/sync/sync-peer/sync-peer-http-receiver/sync-peer-http-receiver-v1.mjs +37 -6
  62. package/dist/sync/sync-peer/sync-peer-http-receiver/sync-peer-http-receiver-v1.mjs.map +1 -1
  63. package/dist/sync/sync-peer/sync-peer-http-sender/sync-peer-http-sender-types.d.mts +3 -1
  64. package/dist/sync/sync-peer/sync-peer-http-sender/sync-peer-http-sender-types.d.mts.map +1 -1
  65. package/dist/sync/sync-peer/sync-peer-http-sender/sync-peer-http-sender-v1.d.mts +4 -2
  66. package/dist/sync/sync-peer/sync-peer-http-sender/sync-peer-http-sender-v1.d.mts.map +1 -1
  67. package/dist/sync/sync-peer/sync-peer-http-sender/sync-peer-http-sender-v1.mjs +37 -0
  68. package/dist/sync/sync-peer/sync-peer-http-sender/sync-peer-http-sender-v1.mjs.map +1 -1
  69. package/dist/sync/sync-peer/sync-peer-innerspace/sync-peer-innerspace-types.d.mts +7 -1
  70. package/dist/sync/sync-peer/sync-peer-innerspace/sync-peer-innerspace-types.d.mts.map +1 -1
  71. package/dist/sync/sync-peer/sync-peer-innerspace/sync-peer-innerspace-v1.d.mts +10 -2
  72. package/dist/sync/sync-peer/sync-peer-innerspace/sync-peer-innerspace-v1.d.mts.map +1 -1
  73. package/dist/sync/sync-peer/sync-peer-innerspace/sync-peer-innerspace-v1.mjs +50 -38
  74. package/dist/sync/sync-peer/sync-peer-innerspace/sync-peer-innerspace-v1.mjs.map +1 -1
  75. package/dist/sync/sync-peer/sync-peer-types.d.mts +21 -5
  76. package/dist/sync/sync-peer/sync-peer-types.d.mts.map +1 -1
  77. package/dist/sync/sync-peer/sync-peer-v1.d.mts +30 -5
  78. package/dist/sync/sync-peer/sync-peer-v1.d.mts.map +1 -1
  79. package/dist/sync/sync-peer/sync-peer-v1.mjs +41 -25
  80. package/dist/sync/sync-peer/sync-peer-v1.mjs.map +1 -1
  81. package/dist/sync/sync-saga-context/sync-saga-context-helpers.d.mts +2 -11
  82. package/dist/sync/sync-saga-context/sync-saga-context-helpers.d.mts.map +1 -1
  83. package/dist/sync/sync-saga-context/sync-saga-context-helpers.mjs +7 -51
  84. package/dist/sync/sync-saga-context/sync-saga-context-helpers.mjs.map +1 -1
  85. package/dist/sync/sync-saga-context/sync-saga-context-types.d.mts +1 -47
  86. package/dist/sync/sync-saga-context/sync-saga-context-types.d.mts.map +1 -1
  87. package/dist/sync/sync-saga-coordinator.d.mts +6 -58
  88. package/dist/sync/sync-saga-coordinator.d.mts.map +1 -1
  89. package/dist/sync/sync-saga-coordinator.mjs +23 -425
  90. package/dist/sync/sync-saga-coordinator.mjs.map +1 -1
  91. package/dist/sync/sync-saga-message/sync-saga-message-types.d.mts +2 -2
  92. package/dist/sync/sync-saga-message/sync-saga-message-types.d.mts.map +1 -1
  93. package/dist/sync/sync-types.d.mts +2 -19
  94. package/dist/sync/sync-types.d.mts.map +1 -1
  95. package/dist/sync/sync-types.mjs.map +1 -1
  96. package/dist/test/mock-space.mjs +1 -1
  97. package/dist/test/mock-space.mjs.map +1 -1
  98. package/dist/test-helpers.d.mts +0 -6
  99. package/dist/test-helpers.d.mts.map +1 -1
  100. package/dist/test-helpers.mjs +2 -25
  101. package/dist/test-helpers.mjs.map +1 -1
  102. package/package.json +10 -34
  103. package/src/keystone/aggregate-details.respec.mts +137 -0
  104. package/src/keystone/docs/architecture.md +16 -0
  105. package/src/keystone/keystone-constants.mts +6 -1
  106. package/src/keystone/keystone-helpers.mts +9 -1
  107. package/src/keystone/keystone-service-v1.mts +216 -8
  108. package/src/keystone/keystone-service-v1.respec.mts +39 -103
  109. package/src/keystone/keystone-types.mts +6 -0
  110. package/src/sync/README.md +2 -87
  111. package/src/sync/docs/architecture.md +26 -5
  112. package/src/sync/docs/security.md +176 -0
  113. package/src/sync/graft-info/graft-info-helpers.respec.mts +7 -7
  114. package/src/sync/sync-conflict-adv-multitimelines.respec.mts +25 -29
  115. package/src/sync/sync-conflict-basic-divergence.respec.mts +6 -7
  116. package/src/sync/sync-conflict-basic-multitimelines.respec.mts +9 -10
  117. package/src/sync/sync-conflict-text-merge.respec.mts +29 -32
  118. package/src/sync/sync-constants.mts +2 -62
  119. package/src/sync/sync-helpers.mts +1 -8
  120. package/src/sync/sync-id-testlog.txt +421 -0
  121. package/src/sync/sync-innerspace-constants.respec.mts +4 -8
  122. package/src/sync/sync-innerspace-deep-updates.respec.mts +5 -6
  123. package/src/sync/sync-innerspace-dest-ahead-withid.respec.mts +23 -25
  124. package/src/sync/sync-innerspace-dest-ahead.respec.mts +7 -8
  125. package/src/sync/sync-innerspace-multiple-timelines.respec.mts +5 -6
  126. package/src/sync/sync-innerspace-partial-update.respec.mts +6 -7
  127. package/src/sync/sync-innerspace.respec.mts +7 -10
  128. package/src/sync/sync-peer/sync-peer-http-receiver/sync-http-node-adapter.mts +5 -5
  129. package/src/sync/sync-peer/sync-peer-http-receiver/sync-peer-http-receiver-types.mts +5 -1
  130. package/src/sync/sync-peer/sync-peer-http-receiver/sync-peer-http-receiver-v1.mts +30 -9
  131. package/src/sync/sync-peer/sync-peer-http-sender/sync-peer-http-sender-types.mts +3 -1
  132. package/src/sync/sync-peer/sync-peer-http-sender/sync-peer-http-sender-v1.mts +29 -2
  133. package/src/sync/sync-peer/sync-peer-innerspace/sync-peer-innerspace-types.mts +7 -1
  134. package/src/sync/sync-peer/sync-peer-innerspace/sync-peer-innerspace-v1.mts +51 -38
  135. package/src/sync/sync-peer/sync-peer-types.mts +23 -6
  136. package/src/sync/sync-peer/sync-peer-v1.mts +68 -28
  137. package/src/sync/sync-saga-context/sync-saga-context-helpers.mts +6 -66
  138. package/src/sync/sync-saga-context/sync-saga-context-types.mts +1 -48
  139. package/src/sync/sync-saga-coordinator.mts +12 -552
  140. package/src/sync/sync-saga-message/sync-saga-message-types.mts +2 -3
  141. package/src/sync/sync-types.mts +2 -22
  142. package/src/sync/unused-identity-backup.mts.md +311 -0
  143. package/src/test/mock-space.mts +1 -1
  144. package/src/test-helpers.mts +1 -26
  145. package/test_output.log +0 -0
  146. package/test_output_utf8.txt +398 -0
  147. package/.vscode/core-gib-snippets.code-snippets +0 -293
  148. package/.vscode/launch.json +0 -40
  149. package/.vscode/settings.json +0 -58
  150. package/.vscode/tasks.json +0 -37
  151. package/dist/sync/sync-peer/sync-peer-http.respec.d.mts +0 -2
  152. package/dist/sync/sync-peer/sync-peer-http.respec.d.mts.map +0 -1
  153. package/dist/sync/sync-peer/sync-peer-http.respec.mjs +0 -340
  154. package/dist/sync/sync-peer/sync-peer-http.respec.mjs.map +0 -1
  155. package/dist/witness/space/filesystem-space/node-filesystem-space/node-filesystem-space-helper.d.mts +0 -42
  156. package/dist/witness/space/filesystem-space/node-filesystem-space/node-filesystem-space-helper.d.mts.map +0 -1
  157. package/dist/witness/space/filesystem-space/node-filesystem-space/node-filesystem-space-helper.mjs +0 -312
  158. package/dist/witness/space/filesystem-space/node-filesystem-space/node-filesystem-space-helper.mjs.map +0 -1
  159. package/dist/witness/space/filesystem-space/node-filesystem-space/node-filesystem-space-types.d.mts +0 -84
  160. package/dist/witness/space/filesystem-space/node-filesystem-space/node-filesystem-space-types.d.mts.map +0 -1
  161. package/dist/witness/space/filesystem-space/node-filesystem-space/node-filesystem-space-types.mjs +0 -65
  162. package/dist/witness/space/filesystem-space/node-filesystem-space/node-filesystem-space-types.mjs.map +0 -1
  163. package/dist/witness/space/filesystem-space/node-filesystem-space/node-filesystem-space-v1.d.mts +0 -73
  164. package/dist/witness/space/filesystem-space/node-filesystem-space/node-filesystem-space-v1.d.mts.map +0 -1
  165. package/dist/witness/space/filesystem-space/node-filesystem-space/node-filesystem-space-v1.mjs +0 -667
  166. package/dist/witness/space/filesystem-space/node-filesystem-space/node-filesystem-space-v1.mjs.map +0 -1
  167. package/dist/witness/space/filesystem-space/node-filesystem-space/respec/testSpace_createAndInit.node-filesystem-space-v1.respec.d.mts +0 -2
  168. package/dist/witness/space/filesystem-space/node-filesystem-space/respec/testSpace_createAndInit.node-filesystem-space-v1.respec.d.mts.map +0 -1
  169. package/dist/witness/space/filesystem-space/node-filesystem-space/respec/testSpace_createAndInit.node-filesystem-space-v1.respec.mjs +0 -67
  170. package/dist/witness/space/filesystem-space/node-filesystem-space/respec/testSpace_createAndInit.node-filesystem-space-v1.respec.mjs.map +0 -1
  171. package/dist/witness/space/filesystem-space/node-filesystem-space/respec/testSpace_persistTransformResult.node-filesystem-space-v1.respec.d.mts +0 -2
  172. package/dist/witness/space/filesystem-space/node-filesystem-space/respec/testSpace_persistTransformResult.node-filesystem-space-v1.respec.d.mts.map +0 -1
  173. package/dist/witness/space/filesystem-space/node-filesystem-space/respec/testSpace_persistTransformResult.node-filesystem-space-v1.respec.mjs +0 -67
  174. package/dist/witness/space/filesystem-space/node-filesystem-space/respec/testSpace_persistTransformResult.node-filesystem-space-v1.respec.mjs.map +0 -1
  175. package/dist/witness/space/filesystem-space/node-filesystem-space/respec/testSpace_putGetDelete.node-filesystem-space-v1.respec.d.mts +0 -2
  176. package/dist/witness/space/filesystem-space/node-filesystem-space/respec/testSpace_putGetDelete.node-filesystem-space-v1.respec.d.mts.map +0 -1
  177. package/dist/witness/space/filesystem-space/node-filesystem-space/respec/testSpace_putGetDelete.node-filesystem-space-v1.respec.mjs +0 -68
  178. package/dist/witness/space/filesystem-space/node-filesystem-space/respec/testSpace_putGetDelete.node-filesystem-space-v1.respec.mjs.map +0 -1
  179. package/dist/witness/space/filesystem-space/node-filesystem-space/respec/testSpace_registerNewIbGib_GetLatest.node-filesystem-space-v1.respec.d.mts +0 -2
  180. package/dist/witness/space/filesystem-space/node-filesystem-space/respec/testSpace_registerNewIbGib_GetLatest.node-filesystem-space-v1.respec.d.mts.map +0 -1
  181. package/dist/witness/space/filesystem-space/node-filesystem-space/respec/testSpace_registerNewIbGib_GetLatest.node-filesystem-space-v1.respec.mjs +0 -69
  182. package/dist/witness/space/filesystem-space/node-filesystem-space/respec/testSpace_registerNewIbGib_GetLatest.node-filesystem-space-v1.respec.mjs.map +0 -1
  183. package/src/sync/sync-peer/sync-peer-http.respec.mts +0 -396
  184. package/src/witness/space/filesystem-space/node-filesystem-space/node-filesystem-space-helper.mts +0 -298
  185. package/src/witness/space/filesystem-space/node-filesystem-space/node-filesystem-space-types.mts +0 -150
  186. package/src/witness/space/filesystem-space/node-filesystem-space/node-filesystem-space-v1.mts +0 -666
  187. package/src/witness/space/filesystem-space/node-filesystem-space/respec/testSpace_createAndInit.node-filesystem-space-v1.respec.mts +0 -87
  188. package/src/witness/space/filesystem-space/node-filesystem-space/respec/testSpace_persistTransformResult.node-filesystem-space-v1.respec.mts +0 -88
  189. package/src/witness/space/filesystem-space/node-filesystem-space/respec/testSpace_putGetDelete.node-filesystem-space-v1.respec.mts +0 -88
  190. package/src/witness/space/filesystem-space/node-filesystem-space/respec/testSpace_registerNewIbGib_GetLatest.node-filesystem-space-v1.respec.mts +0 -90
@@ -8,7 +8,7 @@ await respecfully(sir, 'Graft Info Helpers', async () => {
8
8
 
9
9
  await respecfully(sir, 'mergeTextLCS', async () => {
10
10
 
11
- await ifWe(sir, 'mergeTextLCS should interleave unique lines (A then B)', async () => {
11
+ await ifWeMight(sir, 'mergeTextLCS should interleave unique lines (A then B)', async () => {
12
12
  const textA = "Line 1\nLine A\nLine 3";
13
13
  const textB = "Line 1\nLine B\nLine 3";
14
14
  const res = await mergeTextByLongestCommonSubsequence({ textA, textB });
@@ -16,7 +16,7 @@ await respecfully(sir, 'Graft Info Helpers', async () => {
16
16
  iReckon(sir, res).asTo('result').isGonnaBe(expected);
17
17
  });
18
18
 
19
- await ifWe(sir, 'mergeTextLCS should handle insertions', async () => {
19
+ await ifWeMight(sir, 'mergeTextLCS should handle insertions', async () => {
20
20
  const textA = "Line 1\nLine 3";
21
21
  const textB = "Line 1\nLine 2\nLine 3";
22
22
  const res = await mergeTextByLongestCommonSubsequence({ textA, textB });
@@ -24,7 +24,7 @@ await respecfully(sir, 'Graft Info Helpers', async () => {
24
24
  iReckon(sir, res).asTo('result').isGonnaBe(expected);
25
25
  });
26
26
 
27
- await ifWe(sir, 'mergeTextLCS should handle appends', async () => {
27
+ await ifWeMight(sir, 'mergeTextLCS should handle appends', async () => {
28
28
  const textA = "Line 1";
29
29
  const textB = "Line 1\nLine 2";
30
30
  const res = await mergeTextByLongestCommonSubsequence({ textA, textB });
@@ -32,7 +32,7 @@ await respecfully(sir, 'Graft Info Helpers', async () => {
32
32
  iReckon(sir, res).asTo('result').isGonnaBe(expected);
33
33
  });
34
34
 
35
- await ifWe(sir, 'mergeTextLCS should handle simultaneous list additions', async () => {
35
+ await ifWeMight(sir, 'mergeTextLCS should handle simultaneous list additions', async () => {
36
36
  const textA = "- Item 1\n- Item 2\n- Item A";
37
37
  const textB = "- Item 1\n- Item 2\n- Item B";
38
38
  const res = await mergeTextByLongestCommonSubsequence({ textA, textB });
@@ -42,7 +42,7 @@ await respecfully(sir, 'Graft Info Helpers', async () => {
42
42
  iReckon(sir, res).asTo('result').isGonnaBe(expected);
43
43
  });
44
44
 
45
- await ifWe(sir, 'mergeTextLCS should handle distinct modifications in code block', async () => {
45
+ await ifWeMight(sir, 'mergeTextLCS should handle distinct modifications in code block', async () => {
46
46
  const textA = `function foo() {
47
47
  console.log("start");
48
48
  doA();
@@ -64,7 +64,7 @@ await respecfully(sir, 'Graft Info Helpers', async () => {
64
64
  iReckon(sir, res).asTo('result').isGonnaBe(expected);
65
65
  });
66
66
 
67
- await ifWe(sir, 'mergeTextLCS should return same string if identical', async () => {
67
+ await ifWeMight(sir, 'mergeTextLCS should return same string if identical', async () => {
68
68
  const textA = "Hello";
69
69
  const res = await mergeTextByLongestCommonSubsequence({ textA, textB: textA });
70
70
  iReckon(sir, res).asTo('result').isGonnaBe(textA);
@@ -75,7 +75,7 @@ await respecfully(sir, 'Graft Info Helpers', async () => {
75
75
  await respecfully(sir, 'graftTimelines', async () => {
76
76
  // We need a more complex setup to test this properly (mock space, etc.)
77
77
  // For now, this placeholder ensures the test file runs.
78
- await ifWe(sir, 'graftTimelines placeholders', async () => {
78
+ await ifWeMight(sir, 'graftTimelines placeholders', async () => {
79
79
  iReckon(sir, true).isGonnaBeTrue();
80
80
  });
81
81
  });
@@ -15,7 +15,7 @@ import { getIbGibAddr } from '@ibgib/ts-gib/dist/helper.mjs';
15
15
  import { IbGibData_V1, IbGib_V1 } from '@ibgib/ts-gib/dist/V1/types.mjs';
16
16
 
17
17
  import { GLOBAL_LOG_A_LOT } from '../core-constants.mjs';
18
- import { TestTransformer, getTestKeystoneServiceHelper } from '../test-helpers.mjs';
18
+ import { TestTransformer, } from '../test-helpers.mjs';
19
19
  import { TestMut8Info, } from '../test-types.mjs';
20
20
  import { SyncSagaCoordinator } from './sync-saga-coordinator.mjs';
21
21
  import { getFromSpace } from '../witness/space/space-helper.mjs';
@@ -78,14 +78,14 @@ await respecfully(sir, `Multi-round/timeline permutations`, async () => {
78
78
  const testTransformer = new TestTransformer(metaspace, sourceSpace, destSpace);
79
79
 
80
80
  if (logalot) { console.log(`${lc} Setting up Coordinators...`); }
81
- const mockKeystone = await getTestKeystoneServiceHelper();
82
- const senderCoordinator = new SyncSagaCoordinator(mockKeystone);
83
- const receiverCoordinator = new SyncSagaCoordinator(mockKeystone);
81
+ const senderCoordinator = new SyncSagaCoordinator();
82
+ const receiverCoordinator = new SyncSagaCoordinator();
84
83
 
85
84
  async function newTestPeer(): Promise<SyncPeerInnerspace_V1> {
86
85
  const peer = new SyncPeerInnerspace_V1(clone(SYNC_PEER_INNERSPACE_DEFAULT_DATA_V1));
87
86
  await peer.initialized;
88
87
  await peer.initializeOpts({
88
+ localMetaspace: metaspace,
89
89
  localSpace: sourceSpace,
90
90
  receiverSpace: destSpace,
91
91
  receiverCoordinator: receiverCoordinator,
@@ -127,7 +127,7 @@ await respecfully(sir, `Multi-round/timeline permutations`, async () => {
127
127
  // #endregion r1 setup
128
128
 
129
129
  await respecfully(sir, `r1 verify pre`, async () => {
130
- await ifWe(sir, 'dest should NOT have alpha', async () => {
130
+ await ifWeMight(sir, 'dest should NOT have alpha', async () => {
131
131
  const resGet = await getFromSpace({
132
132
  space: destSpace,
133
133
  addr: alpha_tjpAddr,
@@ -144,14 +144,13 @@ await respecfully(sir, `Multi-round/timeline permutations`, async () => {
144
144
  metaspace,
145
145
  domainIbGibs: [r1_alpha_v1_source_common.ibGib],
146
146
  conflictStrategy: SyncConflictStrategy.optimisticWithLCS,
147
- useSessionIdentity: false,
148
147
  });
149
148
 
150
149
  await r1_syncSaga.done;
151
150
  if (logalot) { console.log(`${lc} r1_syncSaga Complete.`); }
152
151
 
153
152
  await respecfully(sir, `r1 verify post`, async () => {
154
- await ifWe(sir, 'dest should have alpha', async () => {
153
+ await ifWeMight(sir, 'dest should have alpha', async () => {
155
154
  // alpha's full dep graph should exist on dest
156
155
  const [alpha_dest] = await getIbGibsFromCache_fallbackToSpaces({
157
156
  addrs: [r1_alpha_v0_source.addr],
@@ -231,7 +230,7 @@ await respecfully(sir, `Multi-round/timeline permutations`, async () => {
231
230
  // Verify Receiver has correct KV (Pre-Sync Check)
232
231
  // This ensures the conflict precondition exists.
233
232
  await respecfully(sir, `r2 verify pre`, async () => {
234
- await ifWe(sir, 'dest has alpha v1 common', async () => {
233
+ await ifWeMight(sir, 'dest has alpha v1 common', async () => {
235
234
  try {
236
235
  const destKV = await receiverCoordinator.getKnowledgeMap({
237
236
  space: destSpace,
@@ -265,7 +264,6 @@ await respecfully(sir, `Multi-round/timeline permutations`, async () => {
265
264
  metaspace,
266
265
  domainIbGibs: [r2_alpha_v3_source_rel8dBeta.ibGib],
267
266
  conflictStrategy: SyncConflictStrategy.optimisticWithLCS,
268
- useSessionIdentity: false,
269
267
  });
270
268
 
271
269
  if (logalot) { console.log(`${lc} awaiting r2_syncSaga.done`) }
@@ -310,7 +308,7 @@ await respecfully(sir, `Multi-round/timeline permutations`, async () => {
310
308
  if (!alpha_dest_tipAddr) {
311
309
  throw new Error(`dest Space missing timeline tip for ${alpha_tjpAddr} (E: 30b018c6349917aa28c9f538fa567826)`);
312
310
  }
313
- await ifWe(sir, 'tip addrs', async () => {
311
+ await ifWeMight(sir, 'tip addrs', async () => {
314
312
  iReckon(sir, alpha_source_tipAddr).asTo('source/dest have same tip addrs').isGonnaBe(alpha_dest_tipAddr);
315
313
  })
316
314
 
@@ -336,7 +334,7 @@ await respecfully(sir, `Multi-round/timeline permutations`, async () => {
336
334
  // #endregion DEBUG SANITY CHECK
337
335
 
338
336
 
339
- await ifWe(sir, 'r2 basics of alpha merge', async () => {
337
+ await ifWeMight(sir, 'r2 basics of alpha merge', async () => {
340
338
  iReckon(sir, alpha_source_tipAddr)
341
339
  .asTo(`Source Tip (${alpha_source_tipAddr}) should NOT be r2_alpha_v3_source_rel8dBeta`)
342
340
  .not.isGonnaBe(r2_alpha_v3_source_rel8dBeta.addr);
@@ -359,7 +357,7 @@ await respecfully(sir, `Multi-round/timeline permutations`, async () => {
359
357
  iReckon(sir, gotten_alpha_source_tipIbGib.data![r2_dest_mut8Info.key!]).asTo(`New Tip has dest field ${r2_dest_mut8Info.key!}`).isGonnaBe(r2_dest_mut8Info.value!);
360
358
  });
361
359
 
362
- await ifWe(sir, 'r2 alpha and deps synced', async () => {
360
+ await ifWeMight(sir, 'r2 alpha and deps synced', async () => {
363
361
  // alpha's full dep graph should exist on dest, even though its
364
362
  // timeline was grafted
365
363
  const [alpha_dest] = await getIbGibsFromCache_fallbackToSpaces({
@@ -392,7 +390,7 @@ await respecfully(sir, `Multi-round/timeline permutations`, async () => {
392
390
  }
393
391
  });
394
392
 
395
- await ifWe(sir, 'r2 beta and deps synced', async () => {
393
+ await ifWeMight(sir, 'r2 beta and deps synced', async () => {
396
394
  // beta's full dep graph should exist on dest
397
395
  const [beta_dest] = await getIbGibsFromCache_fallbackToSpaces({
398
396
  addrs: [r2_beta_v0_source.addr],
@@ -512,7 +510,7 @@ await respecfully(sir, `Multi-round/timeline permutations`, async () => {
512
510
  // #endregion r3 dest edits
513
511
 
514
512
  await respecfully(sir, `r3 verify pre`, async () => {
515
- await ifWe(sir, 'dest has both alpha and beta tips (pre-conflict)', async () => {
513
+ await ifWeMight(sir, 'dest has both alpha and beta tips (pre-conflict)', async () => {
516
514
  try {
517
515
  const destKV = await receiverCoordinator.getKnowledgeMap({
518
516
  space: destSpace,
@@ -544,7 +542,6 @@ await respecfully(sir, `Multi-round/timeline permutations`, async () => {
544
542
  metaspace,
545
543
  domainIbGibs: [r3_alpha_v4_source_mut8fieldC.ibGib, r3_beta_v1_source.ibGib],
546
544
  conflictStrategy: SyncConflictStrategy.optimisticWithLCS,
547
- useSessionIdentity: false,
548
545
  });
549
546
 
550
547
  if (logalot) { console.log(`${lc} awaiting r3_syncSaga.done`) }
@@ -588,13 +585,13 @@ await respecfully(sir, `Multi-round/timeline permutations`, async () => {
588
585
  });
589
586
  const r3_beta_dest_tipAddr = beta_destKV_afterR3[beta_tjpAddr];
590
587
  if (!r3_beta_dest_tipAddr) {
591
- await ifWe(sir, 'r3_beta_dest_tipAddr is falsy?', async () => {
588
+ await ifWeMight(sir, 'r3_beta_dest_tipAddr is falsy?', async () => {
592
589
  iReckon(sir, true).asTo('fail').isGonnaBeFalse();
593
590
  });
594
591
  return; /* <<<< returns early */
595
592
  }
596
593
 
597
- await ifWe(sir, 'r3 tip addrs match (both timelines)', async () => {
594
+ await ifWeMight(sir, 'r3 tip addrs match (both timelines)', async () => {
598
595
  iReckon(sir, r3_alpha_source_tipAddr).asTo('alpha source/dest have same tip addrs').isGonnaBe(r3_alpha_dest_tipAddr);
599
596
  iReckon(sir, r3_beta_source_tipAddr).asTo('beta source/dest have same tip addrs').isGonnaBe(r3_beta_dest_tipAddr);
600
597
  });
@@ -613,7 +610,7 @@ await respecfully(sir, `Multi-round/timeline permutations`, async () => {
613
610
  const resGet_r3_beta_tip = await getFromSpace({ space: sourceSpace, addr: r3_beta_source_tipAddr });
614
611
  const r3_beta_tipIbGib = resGet_r3_beta_tip.ibGibs![0] as IbGib_V1<TestData>;
615
612
 
616
- await ifWe(sir, 'r3 alpha merge has all four fields (commonField, fieldA, fieldB, fieldC, fieldD)', async () => {
613
+ await ifWeMight(sir, 'r3 alpha merge has all four fields (commonField, fieldA, fieldB, fieldC, fieldD)', async () => {
617
614
  // Should have new graft point with different addr than before
618
615
  iReckon(sir, r3_alpha_source_tipAddr)
619
616
  .asTo(`Alpha R3 tip should NOT be r3_alpha_v4_source_mut8fieldC`)
@@ -634,7 +631,7 @@ await respecfully(sir, `Multi-round/timeline permutations`, async () => {
634
631
  .isGonnaBe(r3_alpha_v4_dest_mut8Info.value!);
635
632
  });
636
633
 
637
- await ifWe(sir, 'r3 beta merge has both fields (betaFieldA, betaFieldB)', async () => {
634
+ await ifWeMight(sir, 'r3 beta merge has both fields (betaFieldA, betaFieldB)', async () => {
638
635
  // Should have new graft point with different addr than before
639
636
  iReckon(sir, r3_beta_source_tipAddr)
640
637
  .asTo(`Beta R3 tip should NOT be r3_beta_v1_source`)
@@ -655,7 +652,7 @@ await respecfully(sir, `Multi-round/timeline permutations`, async () => {
655
652
  .isGonnaBe(r3_dest_beta_mut8Info.value!);
656
653
  });
657
654
 
658
- await ifWe(sir, 'r3 alpha and deps synced', async () => {
655
+ await ifWeMight(sir, 'r3 alpha and deps synced', async () => {
659
656
  const [alpha_dest] = await getIbGibsFromCache_fallbackToSpaces({
660
657
  // addrs: [r1_alpha_v0_source.addr],
661
658
  addrs: [r3_alpha_source_tipAddr],
@@ -687,7 +684,7 @@ await respecfully(sir, `Multi-round/timeline permutations`, async () => {
687
684
  }
688
685
  });
689
686
 
690
- await ifWe(sir, 'r3 beta and deps synced', async () => {
687
+ await ifWeMight(sir, 'r3 beta and deps synced', async () => {
691
688
  const [beta_dest] = await getIbGibsFromCache_fallbackToSpaces({
692
689
  // addrs: [r2_beta_v0_source.addr],
693
690
  addrs: [r3_beta_dest_tipAddr],
@@ -839,7 +836,7 @@ await respecfully(sir, `Multi-round/timeline permutations`, async () => {
839
836
  // #endregion r4 dest edits
840
837
 
841
838
  await respecfully(sir, `r4 verify pre`, async () => {
842
- await ifWe(sir, 'dest has alpha and beta post-R3 tips', async () => {
839
+ await ifWeMight(sir, 'dest has alpha and beta post-R3 tips', async () => {
843
840
  try {
844
841
  const destKV = await receiverCoordinator.getKnowledgeMap({
845
842
  space: destSpace,
@@ -871,7 +868,6 @@ await respecfully(sir, `Multi-round/timeline permutations`, async () => {
871
868
  metaspace,
872
869
  domainIbGibs: [r4_alpha_v7_source.ibGib, r4_gamma_v0_source.ibGib, r4_beta_v2_source.ibGib],
873
870
  conflictStrategy: SyncConflictStrategy.optimisticWithLCS,
874
- useSessionIdentity: false,
875
871
  });
876
872
 
877
873
  if (logalot) { console.log(`${lc} awaiting r4_syncSaga.done`) }
@@ -917,7 +913,7 @@ await respecfully(sir, `Multi-round/timeline permutations`, async () => {
917
913
  });
918
914
  const r4_beta_dest_tipAddr = r4_beta_destKV[beta_tjpAddr];
919
915
  if (!r4_beta_dest_tipAddr) {
920
- await ifWe(sir, 'r4_beta_dest_tipAddr is falsy?', async () => {
916
+ await ifWeMight(sir, 'r4_beta_dest_tipAddr is falsy?', async () => {
921
917
  iReckon(sir, true).asTo('fail').isGonnaBeFalse();
922
918
  });
923
919
  return; /* <<<< returns early */
@@ -937,7 +933,7 @@ await respecfully(sir, `Multi-round/timeline permutations`, async () => {
937
933
  });
938
934
  const r4_gamma_dest_tipAddr = r4_gamma_destKV[gamma_tjpAddr];
939
935
 
940
- await ifWe(sir, 'r4 tip addrs match (alpha, beta, gamma)', async () => {
936
+ await ifWeMight(sir, 'r4 tip addrs match (alpha, beta, gamma)', async () => {
941
937
  iReckon(sir, r4_alpha_source_tipAddr).asTo('alpha source/dest have same tip addrs').isGonnaBe(r4_alpha_dest_tipAddr);
942
938
  iReckon(sir, r4_beta_source_tipAddr).asTo('beta source/dest have same tip addrs').isGonnaBe(r4_beta_dest_tipAddr);
943
939
  iReckon(sir, r4_gamma_source_tipAddr).asTo('gamma source/dest have same tip addrs').isGonnaBe(r4_gamma_dest_tipAddr);
@@ -962,7 +958,7 @@ await respecfully(sir, `Multi-round/timeline permutations`, async () => {
962
958
  const resGet_r4_gamma_tip = await getFromSpace({ space: sourceSpace, addr: r4_gamma_source_tipAddr });
963
959
  const r4_gamma_tipIbGib = resGet_r4_gamma_tip.ibGibs![0] as IbGib_V1<TestData>;
964
960
 
965
- await ifWe(sir, 'r4 alpha has complete chain of edits and gamma relation', async () => {
961
+ await ifWeMight(sir, 'r4 alpha has complete chain of edits and gamma relation', async () => {
966
962
  // Should have new graft point with different addr than either pre-graft version
967
963
  iReckon(sir, r4_alpha_source_tipAddr)
968
964
  .asTo(`Alpha R4 tip should NOT be r4_alpha_v7_source`)
@@ -998,7 +994,7 @@ await respecfully(sir, `Multi-round/timeline permutations`, async () => {
998
994
  .isGonnaBeTrue();
999
995
  });
1000
996
 
1001
- await ifWe(sir, 'r4 beta has all edits', async () => {
997
+ await ifWeMight(sir, 'r4 beta has all edits', async () => {
1002
998
  // Beta should have new graft from R4
1003
999
  iReckon(sir, r4_beta_source_tipAddr)
1004
1000
  .asTo(`Beta R4 tip should NOT be r4_beta_v2_source (source version pre-graft)`)
@@ -1019,7 +1015,7 @@ await respecfully(sir, `Multi-round/timeline permutations`, async () => {
1019
1015
  .isGonnaBe(r4_dest_beta_mut8Info.value!);
1020
1016
  });
1021
1017
 
1022
- await ifWe(sir, 'r4 gamma synced with deps', async () => {
1018
+ await ifWeMight(sir, 'r4 gamma synced with deps', async () => {
1023
1019
  const [gamma_dest] = await getIbGibsFromCache_fallbackToSpaces({
1024
1020
  addrs: [r4_gamma_v0_source.addr],
1025
1021
  space: destSpace,
@@ -1050,7 +1046,7 @@ await respecfully(sir, `Multi-round/timeline permutations`, async () => {
1050
1046
  }
1051
1047
  });
1052
1048
 
1053
- await ifWe(sir, 'r4 all timelines dep graphs synced', async () => {
1049
+ await ifWeMight(sir, 'r4 all timelines dep graphs synced', async () => {
1054
1050
  // Verify alpha dep graphs
1055
1051
  const [alpha_dest] = await getIbGibsFromCache_fallbackToSpaces({
1056
1052
  addrs: [r4_alpha_source_tipAddr],
@@ -17,7 +17,7 @@ import { SyncSagaCoordinator } from './sync-saga-coordinator.mjs';
17
17
  import { getFromSpace } from '../witness/space/space-helper.mjs';
18
18
  import { Metaspace_Innerspace } from '../witness/space/metaspace/metaspace-innerspace/metaspace-innerspace.mjs';
19
19
  import { InnerSpace_V1 } from '../witness/space/inner-space/inner-space-v1.mjs';
20
- import { createTimelineRootTestHelper, getTestKeystoneServiceHelper } from '../test-helpers.mjs';
20
+ import { createTimelineRootTestHelper, } from '../test-helpers.mjs';
21
21
  import { mut8Timeline } from '../timeline/timeline-api.mjs';
22
22
  import { SyncPeerInnerspace_V1 } from './sync-peer/sync-peer-innerspace/sync-peer-innerspace-v1.mjs';
23
23
  import { DEFAULT_INNER_SPACE_DATA_V1 } from '../witness/space/inner-space/inner-space-types.mjs';
@@ -215,13 +215,13 @@ await respecfully(sir, `Two different fields`, async () => {
215
215
 
216
216
  // 4. Run Sync (Optimistic)
217
217
  console.log(`${lc} Setting up Coordinators...`);
218
- const mockKeystone = await getTestKeystoneServiceHelper();
219
- const senderCoordinator = new SyncSagaCoordinator(mockKeystone);
220
- const receiverCoordinator = new SyncSagaCoordinator(mockKeystone);
218
+ const senderCoordinator = new SyncSagaCoordinator();
219
+ const receiverCoordinator = new SyncSagaCoordinator();
221
220
 
222
221
  const peer = new SyncPeerInnerspace_V1(clone(SYNC_PEER_INNERSPACE_DEFAULT_DATA_V1));
223
222
  await peer.initialized;
224
223
  await peer.initializeOpts({
224
+ localMetaspace: metaspace,
225
225
  localSpace: sourceSpace, // "Client"
226
226
  receiverSpace: destSpace, // "Server"
227
227
  receiverCoordinator,
@@ -230,7 +230,7 @@ await respecfully(sir, `Two different fields`, async () => {
230
230
 
231
231
  // Verify Receiver has correct KV (Pre-Sync Check)
232
232
  // This ensures the conflict precondition exists.
233
- await ifWe(sir, 'verify receiver KV pre-sync', async () => {
233
+ await ifWeMight(sir, 'verify receiver KV pre-sync', async () => {
234
234
  try {
235
235
  const destKV = await receiverCoordinator.getKnowledgeMap({
236
236
  space: destSpace,
@@ -264,7 +264,6 @@ await respecfully(sir, `Two different fields`, async () => {
264
264
  metaspace,
265
265
  domainIbGibs: [v2a],
266
266
  conflictStrategy: SyncConflictStrategy.optimisticWithLCS,
267
- useSessionIdentity: false,
268
267
  });
269
268
 
270
269
  const sublc = `${lc}[updates$]`;
@@ -305,7 +304,7 @@ await respecfully(sir, `Two different fields`, async () => {
305
304
 
306
305
  const resSourceTip = await getFromSpace({ space: sourceSpace, addr: getIbGibAddr({ ibGib: v2a }) });
307
306
 
308
- await ifWe(sir, `verify merge`, async () => {
307
+ await ifWeMight(sir, `verify merge`, async () => {
309
308
  // Retrieve updated KV from Source (or check what happened to v2a)
310
309
  // Ideally, we just check the source space for the timeline tip
311
310
  // The timeline tip for testRoot/v0 should now be NEW.
@@ -18,7 +18,7 @@ import { SyncSagaCoordinator } from './sync-saga-coordinator.mjs';
18
18
  import { getFromSpace } from '../witness/space/space-helper.mjs';
19
19
  import { Metaspace_Innerspace } from '../witness/space/metaspace/metaspace-innerspace/metaspace-innerspace.mjs';
20
20
  import { InnerSpace_V1 } from '../witness/space/inner-space/inner-space-v1.mjs';
21
- import { createTimelineRootTestHelper, getTestKeystoneServiceHelper } from '../test-helpers.mjs';
21
+ import { createTimelineRootTestHelper, } from '../test-helpers.mjs';
22
22
  import { appendToTimeline, createTimeline, mut8Timeline } from '../timeline/timeline-api.mjs';
23
23
  import { SyncPeerInnerspace_V1 } from './sync-peer/sync-peer-innerspace/sync-peer-innerspace-v1.mjs';
24
24
  import { DEFAULT_INNER_SPACE_DATA_V1 } from '../witness/space/inner-space/inner-space-types.mjs';
@@ -201,13 +201,13 @@ await respecfully(sir, `Two different fields and rel8d`, async () => {
201
201
 
202
202
  // 4. Run Sync (Optimistic)
203
203
  console.log(`${lc} Setting up Coordinators...`);
204
- const mockKeystone = await getTestKeystoneServiceHelper();
205
- const senderCoordinator = new SyncSagaCoordinator(mockKeystone);
206
- const receiverCoordinator = new SyncSagaCoordinator(mockKeystone);
204
+ const senderCoordinator = new SyncSagaCoordinator();
205
+ const receiverCoordinator = new SyncSagaCoordinator();
207
206
 
208
207
  const peer = new SyncPeerInnerspace_V1(clone(SYNC_PEER_INNERSPACE_DEFAULT_DATA_V1));
209
208
  await peer.initialized;
210
209
  await peer.initializeOpts({
210
+ localMetaspace: metaspace,
211
211
  localSpace: sourceSpace, // "Client"
212
212
  receiverSpace: destSpace, // "Server"
213
213
  receiverCoordinator,
@@ -216,7 +216,7 @@ await respecfully(sir, `Two different fields and rel8d`, async () => {
216
216
 
217
217
  // Verify Receiver has correct KV (Pre-Sync Check)
218
218
  // This ensures the conflict precondition exists.
219
- await ifWe(sir, 'verify receiver KV pre-sync', async () => {
219
+ await ifWeMight(sir, 'verify receiver KV pre-sync', async () => {
220
220
  try {
221
221
  const destKV = await receiverCoordinator.getKnowledgeMap({
222
222
  space: destSpace,
@@ -249,7 +249,6 @@ await respecfully(sir, `Two different fields and rel8d`, async () => {
249
249
  metaspace,
250
250
  domainIbGibs: [alpha_v3_source_rel8beta],
251
251
  conflictStrategy: SyncConflictStrategy.optimisticWithLCS,
252
- useSessionIdentity: false,
253
252
  });
254
253
 
255
254
  const sublc = `${lc}[updates$]`;
@@ -317,7 +316,7 @@ await respecfully(sir, `Two different fields and rel8d`, async () => {
317
316
  const resTip = await getFromSpace({ space: sourceSpace, addr: sourceTipAddr });
318
317
  const newTip = resTip.ibGibs![0] as IbGib_V1<TestData>;
319
318
 
320
- await ifWe(sir, 'basics of alpha merge', async () => {
319
+ await ifWeMight(sir, 'basics of alpha merge', async () => {
321
320
  iReckon(sir, sourceTipAddr).asTo(`Source Tip (${sourceTipAddr}) should NOT be alpha_v3_source_rel8beta`).not.isGonnaBe(getIbGibAddr({ ibGib: alpha_v3_source_rel8beta }));
322
321
  iReckon(sir, sourceTipAddr).asTo(`Source Tip (${sourceTipAddr}) should NOT be v2dest`).not.isGonnaBe(getIbGibAddr({ ibGib: alpha_v2_dest }));
323
322
 
@@ -330,7 +329,7 @@ await respecfully(sir, `Two different fields and rel8d`, async () => {
330
329
  // Check Graft Structure
331
330
  // Look for 'graftinfo' rel8n
332
331
 
333
- await ifWe(sir, 'graft info is valid', async () => {
332
+ await ifWeMight(sir, 'graft info is valid', async () => {
334
333
  if (!newTip.rel8ns) { throw new Error(`(UNEXPECTED) newTip.rel8ns falsy? (E: eb4078712ea2f02c7ee84b983ed77826)`); }
335
334
  const graftInfoRel = newTip.rel8ns[GRAFT_INFO_REL8N_NAME];
336
335
  iReckon(sir, graftInfoRel).asTo('New Tip should have graftinfo rel8n').isGonnaBeTruthy();
@@ -354,7 +353,7 @@ await respecfully(sir, `Two different fields and rel8d`, async () => {
354
353
  iReckon(sir, orphanRel![0]).asTo('orphan rel8ns will be later addr').isGonnaBe(orphanAddr);
355
354
  });
356
355
 
357
- await ifWe(sir, 'alpha and deps synced', async () => {
356
+ await ifWeMight(sir, 'alpha and deps synced', async () => {
358
357
  // alpha's full dep graph should exist on dest
359
358
  const [beta_dest] = await getIbGibsFromCache_fallbackToSpaces({
360
359
  addrs: [betaAddr_v0],
@@ -374,7 +373,7 @@ await respecfully(sir, `Two different fields and rel8d`, async () => {
374
373
  }
375
374
  });
376
375
 
377
- await ifWe(sir, 'beta and deps synced', async () => {
376
+ await ifWeMight(sir, 'beta and deps synced', async () => {
378
377
  // beta's full dep graph should exist on dest
379
378
  const [beta_dest] = await getIbGibsFromCache_fallbackToSpaces({
380
379
  addrs: [betaAddr_v0],