@aztec/pxe 0.0.1-commit.7d4e6cd → 0.0.1-commit.8227e42

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 (265) hide show
  1. package/dest/access_scopes.d.ts +9 -0
  2. package/dest/access_scopes.d.ts.map +1 -0
  3. package/dest/access_scopes.js +6 -0
  4. package/dest/bin/check_oracle_version.js +1 -1
  5. package/dest/block_synchronizer/block_synchronizer.d.ts +11 -5
  6. package/dest/block_synchronizer/block_synchronizer.d.ts.map +1 -1
  7. package/dest/block_synchronizer/block_synchronizer.js +72 -21
  8. package/dest/config/index.d.ts +3 -1
  9. package/dest/config/index.d.ts.map +1 -1
  10. package/dest/config/index.js +17 -0
  11. package/dest/config/package_info.js +1 -1
  12. package/dest/contract_function_simulator/benchmarked_node.d.ts +9 -0
  13. package/dest/contract_function_simulator/benchmarked_node.d.ts.map +1 -0
  14. package/dest/contract_function_simulator/benchmarked_node.js +77 -0
  15. package/dest/contract_function_simulator/contract_function_simulator.d.ts +57 -35
  16. package/dest/contract_function_simulator/contract_function_simulator.d.ts.map +1 -1
  17. package/dest/contract_function_simulator/contract_function_simulator.js +198 -84
  18. package/dest/contract_function_simulator/execution_note_cache.d.ts +18 -9
  19. package/dest/contract_function_simulator/execution_note_cache.d.ts.map +1 -1
  20. package/dest/contract_function_simulator/execution_note_cache.js +45 -28
  21. package/dest/contract_function_simulator/index.d.ts +2 -2
  22. package/dest/contract_function_simulator/index.d.ts.map +1 -1
  23. package/dest/contract_function_simulator/index.js +1 -1
  24. package/dest/contract_function_simulator/noir-structs/event_validation_request.d.ts +1 -1
  25. package/dest/contract_function_simulator/noir-structs/event_validation_request.js +2 -2
  26. package/dest/contract_function_simulator/noir-structs/note_validation_request.d.ts +3 -3
  27. package/dest/contract_function_simulator/noir-structs/note_validation_request.d.ts.map +1 -1
  28. package/dest/contract_function_simulator/noir-structs/note_validation_request.js +2 -2
  29. package/dest/contract_function_simulator/noir-structs/utility_context.d.ts +4 -10
  30. package/dest/contract_function_simulator/noir-structs/utility_context.d.ts.map +1 -1
  31. package/dest/contract_function_simulator/noir-structs/utility_context.js +7 -18
  32. package/dest/contract_function_simulator/oracle/interfaces.d.ts +17 -13
  33. package/dest/contract_function_simulator/oracle/interfaces.d.ts.map +1 -1
  34. package/dest/contract_function_simulator/oracle/message_load_oracle_inputs.d.ts +3 -1
  35. package/dest/contract_function_simulator/oracle/message_load_oracle_inputs.d.ts.map +1 -1
  36. package/dest/contract_function_simulator/oracle/note_packing_utils.d.ts +6 -6
  37. package/dest/contract_function_simulator/oracle/note_packing_utils.d.ts.map +1 -1
  38. package/dest/contract_function_simulator/oracle/note_packing_utils.js +8 -8
  39. package/dest/contract_function_simulator/oracle/oracle.d.ts +12 -10
  40. package/dest/contract_function_simulator/oracle/oracle.d.ts.map +1 -1
  41. package/dest/contract_function_simulator/oracle/oracle.js +67 -44
  42. package/dest/contract_function_simulator/oracle/private_execution.d.ts +2 -26
  43. package/dest/contract_function_simulator/oracle/private_execution.d.ts.map +1 -1
  44. package/dest/contract_function_simulator/oracle/private_execution.js +0 -35
  45. package/dest/contract_function_simulator/oracle/private_execution_oracle.d.ts +44 -35
  46. package/dest/contract_function_simulator/oracle/private_execution_oracle.d.ts.map +1 -1
  47. package/dest/contract_function_simulator/oracle/private_execution_oracle.js +82 -25
  48. package/dest/contract_function_simulator/oracle/utility_execution_oracle.d.ts +66 -33
  49. package/dest/contract_function_simulator/oracle/utility_execution_oracle.d.ts.map +1 -1
  50. package/dest/contract_function_simulator/oracle/utility_execution_oracle.js +130 -111
  51. package/dest/contract_logging.d.ts +22 -0
  52. package/dest/contract_logging.d.ts.map +1 -0
  53. package/dest/contract_logging.js +23 -0
  54. package/dest/contract_sync/contract_sync_service.d.ts +43 -0
  55. package/dest/contract_sync/contract_sync_service.d.ts.map +1 -0
  56. package/dest/contract_sync/contract_sync_service.js +97 -0
  57. package/dest/contract_sync/helpers.d.ts +29 -0
  58. package/dest/contract_sync/helpers.d.ts.map +1 -0
  59. package/dest/contract_sync/helpers.js +55 -0
  60. package/dest/debug/pxe_debug_utils.d.ts +24 -10
  61. package/dest/debug/pxe_debug_utils.d.ts.map +1 -1
  62. package/dest/debug/pxe_debug_utils.js +28 -17
  63. package/dest/entrypoints/client/bundle/index.d.ts +4 -1
  64. package/dest/entrypoints/client/bundle/index.d.ts.map +1 -1
  65. package/dest/entrypoints/client/bundle/index.js +3 -0
  66. package/dest/entrypoints/client/bundle/utils.d.ts +1 -1
  67. package/dest/entrypoints/client/bundle/utils.d.ts.map +1 -1
  68. package/dest/entrypoints/client/bundle/utils.js +21 -7
  69. package/dest/entrypoints/client/lazy/index.d.ts +4 -1
  70. package/dest/entrypoints/client/lazy/index.d.ts.map +1 -1
  71. package/dest/entrypoints/client/lazy/index.js +3 -0
  72. package/dest/entrypoints/client/lazy/utils.d.ts +2 -2
  73. package/dest/entrypoints/client/lazy/utils.d.ts.map +1 -1
  74. package/dest/entrypoints/client/lazy/utils.js +22 -8
  75. package/dest/entrypoints/pxe_creation_options.d.ts +3 -2
  76. package/dest/entrypoints/pxe_creation_options.d.ts.map +1 -1
  77. package/dest/entrypoints/server/index.d.ts +5 -1
  78. package/dest/entrypoints/server/index.d.ts.map +1 -1
  79. package/dest/entrypoints/server/index.js +4 -0
  80. package/dest/entrypoints/server/utils.d.ts +1 -1
  81. package/dest/entrypoints/server/utils.d.ts.map +1 -1
  82. package/dest/entrypoints/server/utils.js +28 -9
  83. package/dest/events/event_service.d.ts +6 -6
  84. package/dest/events/event_service.d.ts.map +1 -1
  85. package/dest/events/event_service.js +19 -22
  86. package/dest/events/private_event_filter_validator.d.ts +5 -5
  87. package/dest/events/private_event_filter_validator.d.ts.map +1 -1
  88. package/dest/events/private_event_filter_validator.js +5 -6
  89. package/dest/job_coordinator/job_coordinator.d.ts +3 -2
  90. package/dest/job_coordinator/job_coordinator.d.ts.map +1 -1
  91. package/dest/job_coordinator/job_coordinator.js +3 -2
  92. package/dest/logs/log_service.d.ts +8 -5
  93. package/dest/logs/log_service.d.ts.map +1 -1
  94. package/dest/logs/log_service.js +28 -30
  95. package/dest/notes/note_service.d.ts +10 -9
  96. package/dest/notes/note_service.d.ts.map +1 -1
  97. package/dest/notes/note_service.js +34 -38
  98. package/dest/notes_filter.d.ts +25 -0
  99. package/dest/notes_filter.d.ts.map +1 -0
  100. package/dest/notes_filter.js +4 -0
  101. package/dest/oracle_version.d.ts +3 -3
  102. package/dest/oracle_version.d.ts.map +1 -1
  103. package/dest/oracle_version.js +4 -3
  104. package/dest/private_kernel/hints/compute_tx_expiration_timestamp.d.ts +4 -0
  105. package/dest/private_kernel/hints/compute_tx_expiration_timestamp.d.ts.map +1 -0
  106. package/dest/private_kernel/hints/{compute_tx_include_by_timestamp.js → compute_tx_expiration_timestamp.js} +12 -12
  107. package/dest/private_kernel/hints/index.d.ts +3 -3
  108. package/dest/private_kernel/hints/index.d.ts.map +1 -1
  109. package/dest/private_kernel/hints/index.js +2 -2
  110. package/dest/private_kernel/hints/private_kernel_reset_private_inputs_builder.d.ts +29 -0
  111. package/dest/private_kernel/hints/private_kernel_reset_private_inputs_builder.d.ts.map +1 -0
  112. package/dest/private_kernel/hints/{build_private_kernel_reset_private_inputs.js → private_kernel_reset_private_inputs_builder.js} +140 -73
  113. package/dest/private_kernel/hints/test_utils.d.ts +122 -0
  114. package/dest/private_kernel/hints/test_utils.d.ts.map +1 -0
  115. package/dest/private_kernel/hints/test_utils.js +203 -0
  116. package/dest/private_kernel/private_kernel_execution_prover.d.ts +3 -2
  117. package/dest/private_kernel/private_kernel_execution_prover.d.ts.map +1 -1
  118. package/dest/private_kernel/private_kernel_execution_prover.js +22 -14
  119. package/dest/private_kernel/private_kernel_oracle.d.ts +23 -24
  120. package/dest/private_kernel/private_kernel_oracle.d.ts.map +1 -1
  121. package/dest/private_kernel/private_kernel_oracle.js +94 -2
  122. package/dest/pxe.d.ts +75 -58
  123. package/dest/pxe.d.ts.map +1 -1
  124. package/dest/pxe.js +124 -132
  125. package/dest/storage/address_store/address_store.d.ts +1 -1
  126. package/dest/storage/address_store/address_store.d.ts.map +1 -1
  127. package/dest/storage/address_store/address_store.js +12 -11
  128. package/dest/storage/anchor_block_store/anchor_block_store.d.ts +9 -1
  129. package/dest/storage/anchor_block_store/anchor_block_store.d.ts.map +1 -1
  130. package/dest/storage/anchor_block_store/anchor_block_store.js +8 -1
  131. package/dest/storage/capsule_store/capsule_store.d.ts +24 -9
  132. package/dest/storage/capsule_store/capsule_store.d.ts.map +1 -1
  133. package/dest/storage/capsule_store/capsule_store.js +130 -23
  134. package/dest/storage/contract_store/contract_store.d.ts +42 -16
  135. package/dest/storage/contract_store/contract_store.d.ts.map +1 -1
  136. package/dest/storage/contract_store/contract_store.js +157 -84
  137. package/dest/storage/metadata.d.ts +1 -1
  138. package/dest/storage/metadata.js +1 -1
  139. package/dest/storage/note_store/note_store.d.ts +50 -51
  140. package/dest/storage/note_store/note_store.d.ts.map +1 -1
  141. package/dest/storage/note_store/note_store.js +284 -263
  142. package/dest/storage/note_store/stored_note.d.ts +16 -0
  143. package/dest/storage/note_store/stored_note.d.ts.map +1 -0
  144. package/dest/storage/note_store/stored_note.js +43 -0
  145. package/dest/storage/private_event_store/private_event_store.d.ts +43 -8
  146. package/dest/storage/private_event_store/private_event_store.d.ts.map +1 -1
  147. package/dest/storage/private_event_store/private_event_store.js +226 -111
  148. package/dest/storage/private_event_store/stored_private_event.d.ts +23 -0
  149. package/dest/storage/private_event_store/stored_private_event.d.ts.map +1 -0
  150. package/dest/storage/private_event_store/stored_private_event.js +56 -0
  151. package/dest/storage/tagging_store/recipient_tagging_store.d.ts +15 -8
  152. package/dest/storage/tagging_store/recipient_tagging_store.d.ts.map +1 -1
  153. package/dest/storage/tagging_store/recipient_tagging_store.js +88 -19
  154. package/dest/storage/tagging_store/sender_address_book_store.d.ts +1 -1
  155. package/dest/storage/tagging_store/sender_address_book_store.d.ts.map +1 -1
  156. package/dest/storage/tagging_store/sender_address_book_store.js +20 -14
  157. package/dest/storage/tagging_store/sender_tagging_store.d.ts +19 -9
  158. package/dest/storage/tagging_store/sender_tagging_store.d.ts.map +1 -1
  159. package/dest/storage/tagging_store/sender_tagging_store.js +252 -100
  160. package/dest/tagging/get_all_logs_by_tags.d.ts +24 -0
  161. package/dest/tagging/get_all_logs_by_tags.d.ts.map +1 -0
  162. package/dest/tagging/get_all_logs_by_tags.js +60 -0
  163. package/dest/tagging/index.d.ts +2 -1
  164. package/dest/tagging/index.d.ts.map +1 -1
  165. package/dest/tagging/index.js +1 -0
  166. package/dest/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.d.ts +3 -2
  167. package/dest/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.d.ts.map +1 -1
  168. package/dest/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.js +10 -10
  169. package/dest/tagging/recipient_sync/utils/find_highest_indexes.js +2 -2
  170. package/dest/tagging/recipient_sync/utils/load_logs_for_range.d.ts +3 -2
  171. package/dest/tagging/recipient_sync/utils/load_logs_for_range.d.ts.map +1 -1
  172. package/dest/tagging/recipient_sync/utils/load_logs_for_range.js +5 -2
  173. package/dest/tagging/sender_sync/sync_sender_tagging_indexes.d.ts +3 -2
  174. package/dest/tagging/sender_sync/sync_sender_tagging_indexes.d.ts.map +1 -1
  175. package/dest/tagging/sender_sync/sync_sender_tagging_indexes.js +7 -7
  176. package/dest/tagging/sender_sync/utils/get_status_change_of_pending.d.ts +1 -1
  177. package/dest/tagging/sender_sync/utils/get_status_change_of_pending.d.ts.map +1 -1
  178. package/dest/tagging/sender_sync/utils/get_status_change_of_pending.js +5 -8
  179. package/dest/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.d.ts +5 -2
  180. package/dest/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.d.ts.map +1 -1
  181. package/dest/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.js +10 -5
  182. package/package.json +27 -18
  183. package/src/access_scopes.ts +9 -0
  184. package/src/bin/check_oracle_version.ts +1 -0
  185. package/src/block_synchronizer/block_synchronizer.ts +91 -33
  186. package/src/config/index.ts +14 -0
  187. package/src/config/package_info.ts +1 -1
  188. package/src/contract_function_simulator/benchmarked_node.ts +103 -0
  189. package/src/contract_function_simulator/contract_function_simulator.ts +349 -148
  190. package/src/contract_function_simulator/execution_note_cache.ts +44 -25
  191. package/src/contract_function_simulator/index.ts +1 -1
  192. package/src/contract_function_simulator/noir-structs/event_validation_request.ts +2 -2
  193. package/src/contract_function_simulator/noir-structs/note_validation_request.ts +2 -2
  194. package/src/contract_function_simulator/noir-structs/utility_context.ts +6 -25
  195. package/src/contract_function_simulator/oracle/interfaces.ts +22 -12
  196. package/src/contract_function_simulator/oracle/note_packing_utils.ts +10 -10
  197. package/src/contract_function_simulator/oracle/oracle.ts +79 -47
  198. package/src/contract_function_simulator/oracle/private_execution.ts +1 -67
  199. package/src/contract_function_simulator/oracle/private_execution_oracle.ts +118 -104
  200. package/src/contract_function_simulator/oracle/utility_execution_oracle.ts +197 -116
  201. package/src/contract_logging.ts +39 -0
  202. package/src/contract_sync/contract_sync_service.ts +152 -0
  203. package/src/contract_sync/helpers.ts +98 -0
  204. package/src/debug/pxe_debug_utils.ts +63 -18
  205. package/src/entrypoints/client/bundle/index.ts +3 -0
  206. package/src/entrypoints/client/bundle/utils.ts +16 -15
  207. package/src/entrypoints/client/lazy/index.ts +3 -0
  208. package/src/entrypoints/client/lazy/utils.ts +17 -15
  209. package/src/entrypoints/pxe_creation_options.ts +2 -1
  210. package/src/entrypoints/server/index.ts +4 -0
  211. package/src/entrypoints/server/utils.ts +22 -26
  212. package/src/events/event_service.ts +17 -25
  213. package/src/events/private_event_filter_validator.ts +3 -5
  214. package/src/job_coordinator/job_coordinator.ts +4 -3
  215. package/src/logs/log_service.ts +40 -34
  216. package/src/notes/note_service.ts +41 -45
  217. package/src/notes_filter.ts +26 -0
  218. package/src/oracle_version.ts +4 -3
  219. package/src/private_kernel/hints/{compute_tx_include_by_timestamp.ts → compute_tx_expiration_timestamp.ts} +13 -13
  220. package/src/private_kernel/hints/index.ts +2 -2
  221. package/src/private_kernel/hints/{build_private_kernel_reset_private_inputs.ts → private_kernel_reset_private_inputs_builder.ts} +195 -136
  222. package/src/private_kernel/hints/test_utils.ts +325 -0
  223. package/src/private_kernel/private_kernel_execution_prover.ts +26 -16
  224. package/src/private_kernel/private_kernel_oracle.ts +116 -37
  225. package/src/pxe.ts +235 -209
  226. package/src/storage/address_store/address_store.ts +15 -15
  227. package/src/storage/anchor_block_store/anchor_block_store.ts +8 -0
  228. package/src/storage/capsule_store/capsule_store.ts +159 -23
  229. package/src/storage/contract_store/contract_store.ts +186 -96
  230. package/src/storage/metadata.ts +1 -1
  231. package/src/storage/note_store/note_store.ts +326 -320
  232. package/src/storage/note_store/stored_note.ts +48 -0
  233. package/src/storage/private_event_store/private_event_store.ts +292 -124
  234. package/src/storage/private_event_store/stored_private_event.ts +73 -0
  235. package/src/storage/tagging_store/recipient_tagging_store.ts +106 -20
  236. package/src/storage/tagging_store/sender_address_book_store.ts +20 -14
  237. package/src/storage/tagging_store/sender_tagging_store.ts +293 -108
  238. package/src/tagging/get_all_logs_by_tags.ts +92 -0
  239. package/src/tagging/index.ts +1 -0
  240. package/src/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.ts +20 -9
  241. package/src/tagging/recipient_sync/utils/find_highest_indexes.ts +2 -2
  242. package/src/tagging/recipient_sync/utils/load_logs_for_range.ts +7 -1
  243. package/src/tagging/sender_sync/sync_sender_tagging_indexes.ts +9 -6
  244. package/src/tagging/sender_sync/utils/get_status_change_of_pending.ts +5 -17
  245. package/src/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.ts +16 -4
  246. package/dest/contract_function_simulator/proxied_node.d.ts +0 -9
  247. package/dest/contract_function_simulator/proxied_node.d.ts.map +0 -1
  248. package/dest/contract_function_simulator/proxied_node.js +0 -27
  249. package/dest/private_kernel/hints/build_private_kernel_reset_private_inputs.d.ts +0 -28
  250. package/dest/private_kernel/hints/build_private_kernel_reset_private_inputs.d.ts.map +0 -1
  251. package/dest/private_kernel/hints/compute_tx_include_by_timestamp.d.ts +0 -4
  252. package/dest/private_kernel/hints/compute_tx_include_by_timestamp.d.ts.map +0 -1
  253. package/dest/private_kernel/private_kernel_oracle_impl.d.ts +0 -46
  254. package/dest/private_kernel/private_kernel_oracle_impl.d.ts.map +0 -1
  255. package/dest/private_kernel/private_kernel_oracle_impl.js +0 -85
  256. package/dest/public_storage/public_storage_service.d.ts +0 -24
  257. package/dest/public_storage/public_storage_service.d.ts.map +0 -1
  258. package/dest/public_storage/public_storage_service.js +0 -26
  259. package/dest/tree_membership/tree_membership_service.d.ts +0 -52
  260. package/dest/tree_membership/tree_membership_service.d.ts.map +0 -1
  261. package/dest/tree_membership/tree_membership_service.js +0 -84
  262. package/src/contract_function_simulator/proxied_node.ts +0 -33
  263. package/src/private_kernel/private_kernel_oracle_impl.ts +0 -127
  264. package/src/public_storage/public_storage_service.ts +0 -33
  265. package/src/tree_membership/tree_membership_service.ts +0 -112
@@ -1,3 +1,3 @@
1
1
  export function getPackageInfo() {
2
- return { version: '4.0.0', name: '@aztec/pxe' };
2
+ return { version: '5.0.0', name: '@aztec/pxe' };
3
3
  }
@@ -0,0 +1,103 @@
1
+ import { Timer } from '@aztec/foundation/timer';
2
+ import type { AztecNode } from '@aztec/stdlib/interfaces/client';
3
+ import type { NodeStats, RoundTripStats } from '@aztec/stdlib/tx';
4
+
5
+ /*
6
+ * Proxy generator for an AztecNode that tracks the time taken for each RPC call and the number of round trips (actual
7
+ * blocking waits for node responses).
8
+ *
9
+ * A round trip is counted when we transition from 0 to 1 in-flight calls, and ends when all concurrent calls complete.
10
+ * This means parallel calls in Promise.all count as a single round trip.
11
+ *
12
+ * Note that batching of RPC calls in `safe_json_rpc_client.ts` could affect the round trip counts but in places we
13
+ * currently use this information we do not even use HTTP as we have direct access to the Aztec Node instance in TS
14
+ * (i.e. not running against external node) so this is not a problem for now.
15
+ *
16
+ * If you want to use this against external node and the info gets skewed by batching you can set the `maxBatchSize`
17
+ * value in `safe_json_rpc_client.ts` to 1 (the main motivation for batching was to get around parallel http requests
18
+ * limits in web browsers which is not a problem when debugging in node.js).
19
+ */
20
+ export type BenchmarkedNode = AztecNode & { getStats(): NodeStats };
21
+
22
+ export class BenchmarkedNodeFactory {
23
+ static create(node: AztecNode): BenchmarkedNode {
24
+ // Per-method call stats
25
+ const perMethod: Partial<Record<keyof AztecNode, { times: number[] }>> = {};
26
+
27
+ // Round trip tracking
28
+ let inFlightCount = 0;
29
+ let currentRoundTripTimer: Timer | null = null;
30
+ let currentRoundTripMethods: string[] = [];
31
+ const roundTrips: RoundTripStats = {
32
+ roundTrips: 0,
33
+ totalBlockingTime: 0,
34
+ roundTripDurations: [],
35
+ roundTripMethods: [],
36
+ };
37
+
38
+ return new Proxy(node, {
39
+ get(target, prop: keyof BenchmarkedNode) {
40
+ if (prop === 'getStats') {
41
+ return (): NodeStats => {
42
+ return { perMethod, roundTrips };
43
+ };
44
+ } else {
45
+ return function (...args: any[]) {
46
+ // Track per-method stats
47
+ if (!perMethod[prop]) {
48
+ perMethod[prop] = { times: [] };
49
+ }
50
+
51
+ // Start of a new round trip batch?
52
+ if (inFlightCount === 0) {
53
+ roundTrips.roundTrips++;
54
+ currentRoundTripTimer = new Timer();
55
+ currentRoundTripMethods = [];
56
+ }
57
+ inFlightCount++;
58
+ currentRoundTripMethods.push(prop);
59
+
60
+ const callTimer = new Timer();
61
+ const result = (target[prop] as any).apply(target, args);
62
+
63
+ // Handle completion - called when the call finishes (after Promise resolves)
64
+ const handleCompletion = () => {
65
+ const callTime = callTimer.ms();
66
+ perMethod[prop]!.times.push(callTime);
67
+
68
+ inFlightCount--;
69
+
70
+ // End of round trip batch - all concurrent calls completed
71
+ if (inFlightCount === 0 && currentRoundTripTimer) {
72
+ const roundTripTime = currentRoundTripTimer.ms();
73
+ roundTrips.totalBlockingTime += roundTripTime;
74
+ roundTrips.roundTripDurations.push(roundTripTime);
75
+ roundTrips.roundTripMethods.push(currentRoundTripMethods);
76
+ currentRoundTripTimer = null;
77
+ currentRoundTripMethods = [];
78
+ }
79
+ };
80
+
81
+ // If the result is a Promise, chain the completion handler
82
+ if (result && typeof result.then === 'function') {
83
+ return result.then(
84
+ (value: any) => {
85
+ handleCompletion();
86
+ return value;
87
+ },
88
+ (error: any) => {
89
+ handleCompletion();
90
+ throw error;
91
+ },
92
+ );
93
+ } else {
94
+ // Synchronous method - handle completion immediately
95
+ handleCompletion();
96
+ return result;
97
+ }
98
+ };
99
+ }
100
+ },
101
+ }) as BenchmarkedNode;
102
+ }
103
+ }