@cratis/arc 19.11.1 → 20.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (505) hide show
  1. package/Globals.ts +20 -1
  2. package/dist/cjs/Globals.d.ts +4 -0
  3. package/dist/cjs/Globals.d.ts.map +1 -1
  4. package/dist/cjs/Globals.js +6 -1
  5. package/dist/cjs/Globals.js.map +1 -1
  6. package/dist/cjs/queries/HubConnectionKeepAlive.d.ts +11 -0
  7. package/dist/cjs/queries/HubConnectionKeepAlive.d.ts.map +1 -0
  8. package/dist/cjs/queries/HubConnectionKeepAlive.js +33 -0
  9. package/dist/cjs/queries/HubConnectionKeepAlive.js.map +1 -0
  10. package/dist/cjs/queries/IObservableQueryHubConnection.d.ts +11 -0
  11. package/dist/cjs/queries/IObservableQueryHubConnection.d.ts.map +1 -0
  12. package/dist/cjs/queries/IReconnectPolicy.d.ts +8 -0
  13. package/dist/cjs/queries/IReconnectPolicy.d.ts.map +1 -0
  14. package/dist/cjs/queries/ObservableQueryConnection.d.ts +3 -1
  15. package/dist/cjs/queries/ObservableQueryConnection.d.ts.map +1 -1
  16. package/dist/cjs/queries/ObservableQueryConnection.js +8 -21
  17. package/dist/cjs/queries/ObservableQueryConnection.js.map +1 -1
  18. package/dist/cjs/queries/ObservableQueryConnectionFactory.d.ts +13 -0
  19. package/dist/cjs/queries/ObservableQueryConnectionFactory.d.ts.map +1 -0
  20. package/dist/cjs/queries/ObservableQueryConnectionFactory.js +62 -0
  21. package/dist/cjs/queries/ObservableQueryConnectionFactory.js.map +1 -0
  22. package/dist/cjs/queries/ObservableQueryConnectionPool.d.ts +9 -0
  23. package/dist/cjs/queries/ObservableQueryConnectionPool.d.ts.map +1 -0
  24. package/dist/cjs/queries/ObservableQueryConnectionPool.js +23 -0
  25. package/dist/cjs/queries/ObservableQueryConnectionPool.js.map +1 -0
  26. package/dist/cjs/queries/ObservableQueryFor.d.ts +1 -0
  27. package/dist/cjs/queries/ObservableQueryFor.d.ts.map +1 -1
  28. package/dist/cjs/queries/ObservableQueryFor.js +10 -5
  29. package/dist/cjs/queries/ObservableQueryFor.js.map +1 -1
  30. package/dist/cjs/queries/ObservableQueryMultiplexer.d.ts +30 -0
  31. package/dist/cjs/queries/ObservableQueryMultiplexer.d.ts.map +1 -0
  32. package/dist/cjs/queries/ObservableQueryMultiplexer.js +120 -0
  33. package/dist/cjs/queries/ObservableQueryMultiplexer.js.map +1 -0
  34. package/dist/cjs/queries/QueryInstanceCache.d.ts +29 -0
  35. package/dist/cjs/queries/QueryInstanceCache.d.ts.map +1 -0
  36. package/dist/cjs/queries/QueryInstanceCache.js +95 -0
  37. package/dist/cjs/queries/QueryInstanceCache.js.map +1 -0
  38. package/dist/cjs/queries/QueryTransportMethod.d.ts +5 -0
  39. package/dist/cjs/queries/QueryTransportMethod.d.ts.map +1 -0
  40. package/dist/cjs/queries/QueryTransportMethod.js +8 -0
  41. package/dist/cjs/queries/QueryTransportMethod.js.map +1 -0
  42. package/dist/cjs/queries/ReconnectPolicy.d.ts +15 -0
  43. package/dist/cjs/queries/ReconnectPolicy.d.ts.map +1 -0
  44. package/dist/cjs/queries/ReconnectPolicy.js +43 -0
  45. package/dist/cjs/queries/ReconnectPolicy.js.map +1 -0
  46. package/dist/cjs/queries/ServerSentEventHubConnection.d.ts +39 -0
  47. package/dist/cjs/queries/ServerSentEventHubConnection.d.ts.map +1 -0
  48. package/dist/cjs/queries/ServerSentEventHubConnection.js +233 -0
  49. package/dist/cjs/queries/ServerSentEventHubConnection.js.map +1 -0
  50. package/dist/cjs/queries/ServerSentEventQueryConnection.d.ts +14 -0
  51. package/dist/cjs/queries/ServerSentEventQueryConnection.d.ts.map +1 -0
  52. package/dist/cjs/queries/ServerSentEventQueryConnection.js +59 -0
  53. package/dist/cjs/queries/ServerSentEventQueryConnection.js.map +1 -0
  54. package/dist/cjs/queries/WebSocketHubConnection.d.ts +55 -0
  55. package/dist/cjs/queries/WebSocketHubConnection.d.ts.map +1 -0
  56. package/dist/cjs/queries/WebSocketHubConnection.js +193 -0
  57. package/dist/cjs/queries/WebSocketHubConnection.js.map +1 -0
  58. package/dist/cjs/queries/for_HubConnectionKeepAlive/behavior.d.ts +2 -0
  59. package/dist/cjs/queries/for_HubConnectionKeepAlive/behavior.d.ts.map +1 -0
  60. package/dist/cjs/queries/for_ObservableQueryConnection/given/an_observable_query_connection.d.ts +1 -2
  61. package/dist/cjs/queries/for_ObservableQueryConnection/given/an_observable_query_connection.d.ts.map +1 -1
  62. package/dist/cjs/queries/for_ObservableQueryConnectionFactory/given/a_descriptor.d.ts +9 -0
  63. package/dist/cjs/queries/for_ObservableQueryConnectionFactory/given/a_descriptor.d.ts.map +1 -0
  64. package/dist/cjs/queries/for_ObservableQueryConnectionFactory/when_creating/with_direct_mode_and_sse_transport.d.ts +2 -0
  65. package/dist/cjs/queries/for_ObservableQueryConnectionFactory/when_creating/with_direct_mode_and_sse_transport.d.ts.map +1 -0
  66. package/dist/cjs/queries/for_ObservableQueryConnectionFactory/when_creating/with_direct_mode_and_websocket_transport.d.ts +2 -0
  67. package/dist/cjs/queries/for_ObservableQueryConnectionFactory/when_creating/with_direct_mode_and_websocket_transport.d.ts.map +1 -0
  68. package/dist/cjs/queries/for_ObservableQueryConnectionFactory/when_creating/with_hub_mode_and_sse_transport.d.ts +2 -0
  69. package/dist/cjs/queries/for_ObservableQueryConnectionFactory/when_creating/with_hub_mode_and_sse_transport.d.ts.map +1 -0
  70. package/dist/cjs/queries/for_ObservableQueryConnectionFactory/when_creating/with_hub_mode_and_websocket_transport.d.ts +2 -0
  71. package/dist/cjs/queries/for_ObservableQueryConnectionFactory/when_creating/with_hub_mode_and_websocket_transport.d.ts.map +1 -0
  72. package/dist/cjs/queries/for_ObservableQueryConnectionPool/when_acquiring/with_multiple_slots/and_least_loaded_slot_is_chosen.d.ts +2 -0
  73. package/dist/cjs/queries/for_ObservableQueryConnectionPool/when_acquiring/with_multiple_slots/and_least_loaded_slot_is_chosen.d.ts.map +1 -0
  74. package/dist/cjs/queries/for_ObservableQueryConnectionPool/when_acquiring/with_multiple_slots/and_size_is_zero.d.ts +2 -0
  75. package/dist/cjs/queries/for_ObservableQueryConnectionPool/when_acquiring/with_multiple_slots/and_size_is_zero.d.ts.map +1 -0
  76. package/dist/cjs/queries/for_ObservableQueryConnectionPool/when_acquiring/with_single_slot/and_one_subscriber.d.ts +2 -0
  77. package/dist/cjs/queries/for_ObservableQueryConnectionPool/when_acquiring/with_single_slot/and_one_subscriber.d.ts.map +1 -0
  78. package/dist/cjs/queries/for_ObservableQueryFor/when_subscribing/with_direct_mode_and_sse_transport.d.ts +2 -0
  79. package/dist/cjs/queries/for_ObservableQueryFor/when_subscribing/with_direct_mode_and_sse_transport.d.ts.map +1 -0
  80. package/dist/cjs/queries/for_ObservableQueryFor/when_subscribing/with_direct_mode_disabled_and_sse_transport.d.ts +2 -0
  81. package/dist/cjs/queries/for_ObservableQueryFor/when_subscribing/with_direct_mode_disabled_and_sse_transport.d.ts.map +1 -0
  82. package/dist/cjs/queries/for_ObservableQueryFor/when_subscribing/with_direct_mode_enabled.d.ts +2 -0
  83. package/dist/cjs/queries/for_ObservableQueryFor/when_subscribing/with_direct_mode_enabled.d.ts.map +1 -0
  84. package/dist/cjs/queries/for_QueryInstanceCache/when_building_key/with_arguments.d.ts +2 -0
  85. package/dist/cjs/queries/for_QueryInstanceCache/when_building_key/with_arguments.d.ts.map +1 -0
  86. package/dist/cjs/queries/for_QueryInstanceCache/when_building_key/with_empty_arguments_object.d.ts +2 -0
  87. package/dist/cjs/queries/for_QueryInstanceCache/when_building_key/with_empty_arguments_object.d.ts.map +1 -0
  88. package/dist/cjs/queries/for_QueryInstanceCache/when_building_key/with_same_arguments_different_order.d.ts +2 -0
  89. package/dist/cjs/queries/for_QueryInstanceCache/when_building_key/with_same_arguments_different_order.d.ts.map +1 -0
  90. package/dist/cjs/queries/for_QueryInstanceCache/when_building_key/without_arguments.d.ts +2 -0
  91. package/dist/cjs/queries/for_QueryInstanceCache/when_building_key/without_arguments.d.ts.map +1 -0
  92. package/dist/cjs/queries/for_QueryInstanceCache/when_getting_last_result/with_no_result_stored.d.ts +2 -0
  93. package/dist/cjs/queries/for_QueryInstanceCache/when_getting_last_result/with_no_result_stored.d.ts.map +1 -0
  94. package/dist/cjs/queries/for_QueryInstanceCache/when_getting_last_result/with_stored_result.d.ts +2 -0
  95. package/dist/cjs/queries/for_QueryInstanceCache/when_getting_last_result/with_stored_result.d.ts.map +1 -0
  96. package/dist/cjs/queries/for_QueryInstanceCache/when_getting_or_creating/with_existing_entry.d.ts +2 -0
  97. package/dist/cjs/queries/for_QueryInstanceCache/when_getting_or_creating/with_existing_entry.d.ts.map +1 -0
  98. package/dist/cjs/queries/for_QueryInstanceCache/when_getting_or_creating/with_new_entry.d.ts +2 -0
  99. package/dist/cjs/queries/for_QueryInstanceCache/when_getting_or_creating/with_new_entry.d.ts.map +1 -0
  100. package/dist/cjs/queries/for_QueryInstanceCache/when_releasing/a_key_that_does_not_exist.d.ts +2 -0
  101. package/dist/cjs/queries/for_QueryInstanceCache/when_releasing/a_key_that_does_not_exist.d.ts.map +1 -0
  102. package/dist/cjs/queries/for_QueryInstanceCache/when_releasing/one_of_two_subscribers.d.ts +2 -0
  103. package/dist/cjs/queries/for_QueryInstanceCache/when_releasing/one_of_two_subscribers.d.ts.map +1 -0
  104. package/dist/cjs/queries/for_QueryInstanceCache/when_releasing/the_only_subscriber.d.ts +2 -0
  105. package/dist/cjs/queries/for_QueryInstanceCache/when_releasing/the_only_subscriber.d.ts.map +1 -0
  106. package/dist/cjs/queries/for_QueryInstanceCache/when_setting_last_result/with_a_result.d.ts +2 -0
  107. package/dist/cjs/queries/for_QueryInstanceCache/when_setting_last_result/with_a_result.d.ts.map +1 -0
  108. package/dist/cjs/queries/for_ReconnectPolicy/when_canceling/with_pending_timer.d.ts +2 -0
  109. package/dist/cjs/queries/for_ReconnectPolicy/when_canceling/with_pending_timer.d.ts.map +1 -0
  110. package/dist/cjs/queries/for_ReconnectPolicy/when_cancelling/with_pending_timer.d.ts +2 -0
  111. package/dist/cjs/queries/for_ReconnectPolicy/when_cancelling/with_pending_timer.d.ts.map +1 -0
  112. package/dist/cjs/queries/for_ReconnectPolicy/when_resetting/after_scheduling.d.ts +2 -0
  113. package/dist/cjs/queries/for_ReconnectPolicy/when_resetting/after_scheduling.d.ts.map +1 -0
  114. package/dist/cjs/queries/for_ReconnectPolicy/when_scheduling/and_max_attempts_not_reached/delay_is_capped_at_max.d.ts +2 -0
  115. package/dist/cjs/queries/for_ReconnectPolicy/when_scheduling/and_max_attempts_not_reached/delay_is_capped_at_max.d.ts.map +1 -0
  116. package/dist/cjs/queries/for_ReconnectPolicy/when_scheduling/and_max_attempts_not_reached/first_attempt.d.ts +2 -0
  117. package/dist/cjs/queries/for_ReconnectPolicy/when_scheduling/and_max_attempts_not_reached/first_attempt.d.ts.map +1 -0
  118. package/dist/cjs/queries/for_ReconnectPolicy/when_scheduling/and_max_attempts_reached/abandons_reconnect.d.ts +2 -0
  119. package/dist/cjs/queries/for_ReconnectPolicy/when_scheduling/and_max_attempts_reached/abandons_reconnect.d.ts.map +1 -0
  120. package/dist/cjs/queries/for_ServerSentEventHubConnection/given/a_server_sent_event_hub_connection.d.ts +21 -0
  121. package/dist/cjs/queries/for_ServerSentEventHubConnection/given/a_server_sent_event_hub_connection.d.ts.map +1 -0
  122. package/dist/cjs/queries/for_ServerSentEventHubConnection/when_connect_timeout_fires/triggers_reconnect.d.ts +2 -0
  123. package/dist/cjs/queries/for_ServerSentEventHubConnection/when_connect_timeout_fires/triggers_reconnect.d.ts.map +1 -0
  124. package/dist/cjs/queries/for_ServerSentEventHubConnection/when_disposing/cleans_up_resources.d.ts +2 -0
  125. package/dist/cjs/queries/for_ServerSentEventHubConnection/when_disposing/cleans_up_resources.d.ts.map +1 -0
  126. package/dist/cjs/queries/for_ServerSentEventHubConnection/when_keep_alive_is_idle/triggers_reconnect.d.ts +2 -0
  127. package/dist/cjs/queries/for_ServerSentEventHubConnection/when_keep_alive_is_idle/triggers_reconnect.d.ts.map +1 -0
  128. package/dist/cjs/queries/for_ServerSentEventHubConnection/when_reconnecting/after_error.d.ts +2 -0
  129. package/dist/cjs/queries/for_ServerSentEventHubConnection/when_reconnecting/after_error.d.ts.map +1 -0
  130. package/dist/cjs/queries/for_ServerSentEventHubConnection/when_subscribing/queues_until_connected.d.ts +2 -0
  131. package/dist/cjs/queries/for_ServerSentEventHubConnection/when_subscribing/queues_until_connected.d.ts.map +1 -0
  132. package/dist/cjs/queries/for_ServerSentEventHubConnection/when_subscribing/sends_subscribe_post.d.ts +2 -0
  133. package/dist/cjs/queries/for_ServerSentEventHubConnection/when_subscribing/sends_subscribe_post.d.ts.map +1 -0
  134. package/dist/cjs/queries/for_ServerSentEventHubConnection/when_unsubscribing/the_only_query.d.ts +2 -0
  135. package/dist/cjs/queries/for_ServerSentEventHubConnection/when_unsubscribing/the_only_query.d.ts.map +1 -0
  136. package/dist/cjs/queries/for_ServerSentEventQueryConnection/when_connecting/with_query_arguments.d.ts +2 -0
  137. package/dist/cjs/queries/for_ServerSentEventQueryConnection/when_connecting/with_query_arguments.d.ts.map +1 -0
  138. package/dist/cjs/queries/for_ServerSentEventQueryConnection/when_connecting/without_event_source_available.d.ts +2 -0
  139. package/dist/cjs/queries/for_ServerSentEventQueryConnection/when_connecting/without_event_source_available.d.ts.map +1 -0
  140. package/dist/cjs/queries/for_ServerSentEventQueryConnection/when_disconnecting/after_connecting.d.ts +2 -0
  141. package/dist/cjs/queries/for_ServerSentEventQueryConnection/when_disconnecting/after_connecting.d.ts.map +1 -0
  142. package/dist/cjs/queries/for_ServerSentEventQueryConnection/when_disconnecting/before_message_arrives.d.ts +2 -0
  143. package/dist/cjs/queries/for_ServerSentEventQueryConnection/when_disconnecting/before_message_arrives.d.ts.map +1 -0
  144. package/dist/cjs/queries/for_WebSocketHubConnection/given/a_web_socket_hub_connection.d.ts +23 -0
  145. package/dist/cjs/queries/for_WebSocketHubConnection/given/a_web_socket_hub_connection.d.ts.map +1 -0
  146. package/dist/cjs/queries/for_WebSocketHubConnection/when_disposing/cleans_up_resources.d.ts +2 -0
  147. package/dist/cjs/queries/for_WebSocketHubConnection/when_disposing/cleans_up_resources.d.ts.map +1 -0
  148. package/dist/cjs/queries/for_WebSocketHubConnection/when_keep_alive_is_idle/sends_a_ping.d.ts +2 -0
  149. package/dist/cjs/queries/for_WebSocketHubConnection/when_keep_alive_is_idle/sends_a_ping.d.ts.map +1 -0
  150. package/dist/cjs/queries/for_WebSocketHubConnection/when_receiving_a_message/resets_keep_alive_timer.d.ts +2 -0
  151. package/dist/cjs/queries/for_WebSocketHubConnection/when_receiving_a_message/resets_keep_alive_timer.d.ts.map +1 -0
  152. package/dist/cjs/queries/for_WebSocketHubConnection/when_reconnecting/after_unexpected_close.d.ts +2 -0
  153. package/dist/cjs/queries/for_WebSocketHubConnection/when_reconnecting/after_unexpected_close.d.ts.map +1 -0
  154. package/dist/cjs/queries/for_WebSocketHubConnection/when_reconnecting/resubscribes_all_queries.d.ts +2 -0
  155. package/dist/cjs/queries/for_WebSocketHubConnection/when_reconnecting/resubscribes_all_queries.d.ts.map +1 -0
  156. package/dist/cjs/queries/for_WebSocketHubConnection/when_subscribing/to_a_query.d.ts +2 -0
  157. package/dist/cjs/queries/for_WebSocketHubConnection/when_subscribing/to_a_query.d.ts.map +1 -0
  158. package/dist/cjs/queries/for_WebSocketHubConnection/when_unsubscribing/the_only_query.d.ts +2 -0
  159. package/dist/cjs/queries/for_WebSocketHubConnection/when_unsubscribing/the_only_query.d.ts.map +1 -0
  160. package/dist/cjs/queries/index.d.ts +12 -0
  161. package/dist/cjs/queries/index.d.ts.map +1 -1
  162. package/dist/cjs/queries/index.js +34 -0
  163. package/dist/cjs/queries/index.js.map +1 -1
  164. package/dist/esm/Globals.d.ts +4 -0
  165. package/dist/esm/Globals.d.ts.map +1 -1
  166. package/dist/esm/Globals.js +6 -1
  167. package/dist/esm/Globals.js.map +1 -1
  168. package/dist/esm/queries/HubConnectionKeepAlive.d.ts +11 -0
  169. package/dist/esm/queries/HubConnectionKeepAlive.d.ts.map +1 -0
  170. package/dist/esm/queries/HubConnectionKeepAlive.js +31 -0
  171. package/dist/esm/queries/HubConnectionKeepAlive.js.map +1 -0
  172. package/dist/esm/queries/IObservableQueryHubConnection.d.ts +11 -0
  173. package/dist/esm/queries/IObservableQueryHubConnection.d.ts.map +1 -0
  174. package/dist/esm/queries/IObservableQueryHubConnection.js +2 -0
  175. package/dist/esm/queries/IObservableQueryHubConnection.js.map +1 -0
  176. package/dist/esm/queries/IReconnectPolicy.d.ts +8 -0
  177. package/dist/esm/queries/IReconnectPolicy.d.ts.map +1 -0
  178. package/dist/esm/queries/IReconnectPolicy.js +2 -0
  179. package/dist/esm/queries/IReconnectPolicy.js.map +1 -0
  180. package/dist/esm/queries/ObservableQueryConnection.d.ts +3 -1
  181. package/dist/esm/queries/ObservableQueryConnection.d.ts.map +1 -1
  182. package/dist/esm/queries/ObservableQueryConnection.js +8 -21
  183. package/dist/esm/queries/ObservableQueryConnection.js.map +1 -1
  184. package/dist/esm/queries/ObservableQueryConnectionFactory.d.ts +13 -0
  185. package/dist/esm/queries/ObservableQueryConnectionFactory.d.ts.map +1 -0
  186. package/dist/esm/queries/ObservableQueryConnectionFactory.js +58 -0
  187. package/dist/esm/queries/ObservableQueryConnectionFactory.js.map +1 -0
  188. package/dist/esm/queries/ObservableQueryConnectionPool.d.ts +9 -0
  189. package/dist/esm/queries/ObservableQueryConnectionPool.d.ts.map +1 -0
  190. package/dist/esm/queries/ObservableQueryConnectionPool.js +21 -0
  191. package/dist/esm/queries/ObservableQueryConnectionPool.js.map +1 -0
  192. package/dist/esm/queries/ObservableQueryFor.d.ts +1 -0
  193. package/dist/esm/queries/ObservableQueryFor.d.ts.map +1 -1
  194. package/dist/esm/queries/ObservableQueryFor.js +10 -5
  195. package/dist/esm/queries/ObservableQueryFor.js.map +1 -1
  196. package/dist/esm/queries/ObservableQueryMultiplexer.d.ts +30 -0
  197. package/dist/esm/queries/ObservableQueryMultiplexer.d.ts.map +1 -0
  198. package/dist/esm/queries/ObservableQueryMultiplexer.js +114 -0
  199. package/dist/esm/queries/ObservableQueryMultiplexer.js.map +1 -0
  200. package/dist/esm/queries/QueryInstanceCache.d.ts +29 -0
  201. package/dist/esm/queries/QueryInstanceCache.d.ts.map +1 -0
  202. package/dist/esm/queries/QueryInstanceCache.js +93 -0
  203. package/dist/esm/queries/QueryInstanceCache.js.map +1 -0
  204. package/dist/esm/queries/QueryTransportMethod.d.ts +5 -0
  205. package/dist/esm/queries/QueryTransportMethod.d.ts.map +1 -0
  206. package/dist/esm/queries/QueryTransportMethod.js +8 -0
  207. package/dist/esm/queries/QueryTransportMethod.js.map +1 -0
  208. package/dist/esm/queries/ReconnectPolicy.d.ts +15 -0
  209. package/dist/esm/queries/ReconnectPolicy.d.ts.map +1 -0
  210. package/dist/esm/queries/ReconnectPolicy.js +41 -0
  211. package/dist/esm/queries/ReconnectPolicy.js.map +1 -0
  212. package/dist/esm/queries/ServerSentEventHubConnection.d.ts +39 -0
  213. package/dist/esm/queries/ServerSentEventHubConnection.d.ts.map +1 -0
  214. package/dist/esm/queries/ServerSentEventHubConnection.js +231 -0
  215. package/dist/esm/queries/ServerSentEventHubConnection.js.map +1 -0
  216. package/dist/esm/queries/ServerSentEventQueryConnection.d.ts +14 -0
  217. package/dist/esm/queries/ServerSentEventQueryConnection.d.ts.map +1 -0
  218. package/dist/esm/queries/ServerSentEventQueryConnection.js +56 -0
  219. package/dist/esm/queries/ServerSentEventQueryConnection.js.map +1 -0
  220. package/dist/esm/queries/WebSocketHubConnection.d.ts +55 -0
  221. package/dist/esm/queries/WebSocketHubConnection.d.ts.map +1 -0
  222. package/dist/esm/queries/WebSocketHubConnection.js +191 -0
  223. package/dist/esm/queries/WebSocketHubConnection.js.map +1 -0
  224. package/dist/esm/queries/for_HubConnectionKeepAlive/behavior.d.ts +2 -0
  225. package/dist/esm/queries/for_HubConnectionKeepAlive/behavior.d.ts.map +1 -0
  226. package/dist/esm/queries/for_HubConnectionKeepAlive/behavior.js +57 -0
  227. package/dist/esm/queries/for_HubConnectionKeepAlive/behavior.js.map +1 -0
  228. package/dist/esm/queries/for_ObservableQueryConnection/given/an_observable_query_connection.d.ts +1 -2
  229. package/dist/esm/queries/for_ObservableQueryConnection/given/an_observable_query_connection.d.ts.map +1 -1
  230. package/dist/esm/queries/for_ObservableQueryConnection/given/an_observable_query_connection.js +9 -5
  231. package/dist/esm/queries/for_ObservableQueryConnection/given/an_observable_query_connection.js.map +1 -1
  232. package/dist/esm/queries/for_ObservableQueryConnectionFactory/given/a_descriptor.d.ts +9 -0
  233. package/dist/esm/queries/for_ObservableQueryConnectionFactory/given/a_descriptor.d.ts.map +1 -0
  234. package/dist/esm/queries/for_ObservableQueryConnectionFactory/given/a_descriptor.js +19 -0
  235. package/dist/esm/queries/for_ObservableQueryConnectionFactory/given/a_descriptor.js.map +1 -0
  236. package/dist/esm/queries/for_ObservableQueryConnectionFactory/when_creating/with_direct_mode_and_sse_transport.d.ts +2 -0
  237. package/dist/esm/queries/for_ObservableQueryConnectionFactory/when_creating/with_direct_mode_and_sse_transport.d.ts.map +1 -0
  238. package/dist/esm/queries/for_ObservableQueryConnectionFactory/when_creating/with_direct_mode_and_sse_transport.js +49 -0
  239. package/dist/esm/queries/for_ObservableQueryConnectionFactory/when_creating/with_direct_mode_and_sse_transport.js.map +1 -0
  240. package/dist/esm/queries/for_ObservableQueryConnectionFactory/when_creating/with_direct_mode_and_websocket_transport.d.ts +2 -0
  241. package/dist/esm/queries/for_ObservableQueryConnectionFactory/when_creating/with_direct_mode_and_websocket_transport.d.ts.map +1 -0
  242. package/dist/esm/queries/for_ObservableQueryConnectionFactory/when_creating/with_direct_mode_and_websocket_transport.js +47 -0
  243. package/dist/esm/queries/for_ObservableQueryConnectionFactory/when_creating/with_direct_mode_and_websocket_transport.js.map +1 -0
  244. package/dist/esm/queries/for_ObservableQueryConnectionFactory/when_creating/with_hub_mode_and_sse_transport.d.ts +2 -0
  245. package/dist/esm/queries/for_ObservableQueryConnectionFactory/when_creating/with_hub_mode_and_sse_transport.d.ts.map +1 -0
  246. package/dist/esm/queries/for_ObservableQueryConnectionFactory/when_creating/with_hub_mode_and_sse_transport.js +54 -0
  247. package/dist/esm/queries/for_ObservableQueryConnectionFactory/when_creating/with_hub_mode_and_sse_transport.js.map +1 -0
  248. package/dist/esm/queries/for_ObservableQueryConnectionFactory/when_creating/with_hub_mode_and_websocket_transport.d.ts +2 -0
  249. package/dist/esm/queries/for_ObservableQueryConnectionFactory/when_creating/with_hub_mode_and_websocket_transport.d.ts.map +1 -0
  250. package/dist/esm/queries/for_ObservableQueryConnectionFactory/when_creating/with_hub_mode_and_websocket_transport.js +49 -0
  251. package/dist/esm/queries/for_ObservableQueryConnectionFactory/when_creating/with_hub_mode_and_websocket_transport.js.map +1 -0
  252. package/dist/esm/queries/for_ObservableQueryConnectionPool/when_acquiring/with_multiple_slots/and_least_loaded_slot_is_chosen.d.ts +2 -0
  253. package/dist/esm/queries/for_ObservableQueryConnectionPool/when_acquiring/with_multiple_slots/and_least_loaded_slot_is_chosen.d.ts.map +1 -0
  254. package/dist/esm/queries/for_ObservableQueryConnectionPool/when_acquiring/with_multiple_slots/and_least_loaded_slot_is_chosen.js +34 -0
  255. package/dist/esm/queries/for_ObservableQueryConnectionPool/when_acquiring/with_multiple_slots/and_least_loaded_slot_is_chosen.js.map +1 -0
  256. package/dist/esm/queries/for_ObservableQueryConnectionPool/when_acquiring/with_multiple_slots/and_size_is_zero.d.ts +2 -0
  257. package/dist/esm/queries/for_ObservableQueryConnectionPool/when_acquiring/with_multiple_slots/and_size_is_zero.d.ts.map +1 -0
  258. package/dist/esm/queries/for_ObservableQueryConnectionPool/when_acquiring/with_multiple_slots/and_size_is_zero.js +18 -0
  259. package/dist/esm/queries/for_ObservableQueryConnectionPool/when_acquiring/with_multiple_slots/and_size_is_zero.js.map +1 -0
  260. package/dist/esm/queries/for_ObservableQueryConnectionPool/when_acquiring/with_single_slot/and_one_subscriber.d.ts +2 -0
  261. package/dist/esm/queries/for_ObservableQueryConnectionPool/when_acquiring/with_single_slot/and_one_subscriber.d.ts.map +1 -0
  262. package/dist/esm/queries/for_ObservableQueryConnectionPool/when_acquiring/with_single_slot/and_one_subscriber.js +32 -0
  263. package/dist/esm/queries/for_ObservableQueryConnectionPool/when_acquiring/with_single_slot/and_one_subscriber.js.map +1 -0
  264. package/dist/esm/queries/for_ObservableQueryFor/when_subscribing/with_direct_mode_and_sse_transport.d.ts +2 -0
  265. package/dist/esm/queries/for_ObservableQueryFor/when_subscribing/with_direct_mode_and_sse_transport.d.ts.map +1 -0
  266. package/dist/esm/queries/for_ObservableQueryFor/when_subscribing/with_direct_mode_and_sse_transport.js +54 -0
  267. package/dist/esm/queries/for_ObservableQueryFor/when_subscribing/with_direct_mode_and_sse_transport.js.map +1 -0
  268. package/dist/esm/queries/for_ObservableQueryFor/when_subscribing/with_direct_mode_disabled_and_sse_transport.d.ts +2 -0
  269. package/dist/esm/queries/for_ObservableQueryFor/when_subscribing/with_direct_mode_disabled_and_sse_transport.d.ts.map +1 -0
  270. package/dist/esm/queries/for_ObservableQueryFor/when_subscribing/with_direct_mode_disabled_and_sse_transport.js +55 -0
  271. package/dist/esm/queries/for_ObservableQueryFor/when_subscribing/with_direct_mode_disabled_and_sse_transport.js.map +1 -0
  272. package/dist/esm/queries/for_ObservableQueryFor/when_subscribing/with_direct_mode_enabled.d.ts +2 -0
  273. package/dist/esm/queries/for_ObservableQueryFor/when_subscribing/with_direct_mode_enabled.d.ts.map +1 -0
  274. package/dist/esm/queries/for_ObservableQueryFor/when_subscribing/with_direct_mode_enabled.js +45 -0
  275. package/dist/esm/queries/for_ObservableQueryFor/when_subscribing/with_direct_mode_enabled.js.map +1 -0
  276. package/dist/esm/queries/for_ObservableQueryFor/when_subscribing/with_partially_missing_required_arguments.js +18 -11
  277. package/dist/esm/queries/for_ObservableQueryFor/when_subscribing/with_partially_missing_required_arguments.js.map +1 -1
  278. package/dist/esm/queries/for_ObservableQueryFor/when_subscribing/with_route_and_query_args.js +12 -5
  279. package/dist/esm/queries/for_ObservableQueryFor/when_subscribing/with_route_and_query_args.js.map +1 -1
  280. package/dist/esm/queries/for_QueryInstanceCache/when_building_key/with_arguments.d.ts +2 -0
  281. package/dist/esm/queries/for_QueryInstanceCache/when_building_key/with_arguments.d.ts.map +1 -0
  282. package/dist/esm/queries/for_QueryInstanceCache/when_building_key/with_arguments.js +12 -0
  283. package/dist/esm/queries/for_QueryInstanceCache/when_building_key/with_arguments.js.map +1 -0
  284. package/dist/esm/queries/for_QueryInstanceCache/when_building_key/with_empty_arguments_object.d.ts +2 -0
  285. package/dist/esm/queries/for_QueryInstanceCache/when_building_key/with_empty_arguments_object.d.ts.map +1 -0
  286. package/dist/esm/queries/for_QueryInstanceCache/when_building_key/with_empty_arguments_object.js +11 -0
  287. package/dist/esm/queries/for_QueryInstanceCache/when_building_key/with_empty_arguments_object.js.map +1 -0
  288. package/dist/esm/queries/for_QueryInstanceCache/when_building_key/with_same_arguments_different_order.d.ts +2 -0
  289. package/dist/esm/queries/for_QueryInstanceCache/when_building_key/with_same_arguments_different_order.d.ts.map +1 -0
  290. package/dist/esm/queries/for_QueryInstanceCache/when_building_key/with_same_arguments_different_order.js +13 -0
  291. package/dist/esm/queries/for_QueryInstanceCache/when_building_key/with_same_arguments_different_order.js.map +1 -0
  292. package/dist/esm/queries/for_QueryInstanceCache/when_building_key/without_arguments.d.ts +2 -0
  293. package/dist/esm/queries/for_QueryInstanceCache/when_building_key/without_arguments.d.ts.map +1 -0
  294. package/dist/esm/queries/for_QueryInstanceCache/when_building_key/without_arguments.js +11 -0
  295. package/dist/esm/queries/for_QueryInstanceCache/when_building_key/without_arguments.js.map +1 -0
  296. package/dist/esm/queries/for_QueryInstanceCache/when_getting_last_result/with_no_result_stored.d.ts +2 -0
  297. package/dist/esm/queries/for_QueryInstanceCache/when_getting_last_result/with_no_result_stored.d.ts.map +1 -0
  298. package/dist/esm/queries/for_QueryInstanceCache/when_getting_last_result/with_no_result_stored.js +12 -0
  299. package/dist/esm/queries/for_QueryInstanceCache/when_getting_last_result/with_no_result_stored.js.map +1 -0
  300. package/dist/esm/queries/for_QueryInstanceCache/when_getting_last_result/with_stored_result.d.ts +2 -0
  301. package/dist/esm/queries/for_QueryInstanceCache/when_getting_last_result/with_stored_result.d.ts.map +1 -0
  302. package/dist/esm/queries/for_QueryInstanceCache/when_getting_last_result/with_stored_result.js +16 -0
  303. package/dist/esm/queries/for_QueryInstanceCache/when_getting_last_result/with_stored_result.js.map +1 -0
  304. package/dist/esm/queries/for_QueryInstanceCache/when_getting_or_creating/with_existing_entry.d.ts +2 -0
  305. package/dist/esm/queries/for_QueryInstanceCache/when_getting_or_creating/with_existing_entry.d.ts.map +1 -0
  306. package/dist/esm/queries/for_QueryInstanceCache/when_getting_or_creating/with_existing_entry.js +23 -0
  307. package/dist/esm/queries/for_QueryInstanceCache/when_getting_or_creating/with_existing_entry.js.map +1 -0
  308. package/dist/esm/queries/for_QueryInstanceCache/when_getting_or_creating/with_new_entry.d.ts +2 -0
  309. package/dist/esm/queries/for_QueryInstanceCache/when_getting_or_creating/with_new_entry.d.ts.map +1 -0
  310. package/dist/esm/queries/for_QueryInstanceCache/when_getting_or_creating/with_new_entry.js +16 -0
  311. package/dist/esm/queries/for_QueryInstanceCache/when_getting_or_creating/with_new_entry.js.map +1 -0
  312. package/dist/esm/queries/for_QueryInstanceCache/when_releasing/a_key_that_does_not_exist.d.ts +2 -0
  313. package/dist/esm/queries/for_QueryInstanceCache/when_releasing/a_key_that_does_not_exist.d.ts.map +1 -0
  314. package/dist/esm/queries/for_QueryInstanceCache/when_releasing/a_key_that_does_not_exist.js +17 -0
  315. package/dist/esm/queries/for_QueryInstanceCache/when_releasing/a_key_that_does_not_exist.js.map +1 -0
  316. package/dist/esm/queries/for_QueryInstanceCache/when_releasing/one_of_two_subscribers.d.ts +2 -0
  317. package/dist/esm/queries/for_QueryInstanceCache/when_releasing/one_of_two_subscribers.d.ts.map +1 -0
  318. package/dist/esm/queries/for_QueryInstanceCache/when_releasing/one_of_two_subscribers.js +13 -0
  319. package/dist/esm/queries/for_QueryInstanceCache/when_releasing/one_of_two_subscribers.js.map +1 -0
  320. package/dist/esm/queries/for_QueryInstanceCache/when_releasing/the_only_subscriber.d.ts +2 -0
  321. package/dist/esm/queries/for_QueryInstanceCache/when_releasing/the_only_subscriber.d.ts.map +1 -0
  322. package/dist/esm/queries/for_QueryInstanceCache/when_releasing/the_only_subscriber.js +17 -0
  323. package/dist/esm/queries/for_QueryInstanceCache/when_releasing/the_only_subscriber.js.map +1 -0
  324. package/dist/esm/queries/for_QueryInstanceCache/when_setting_last_result/with_a_result.d.ts +2 -0
  325. package/dist/esm/queries/for_QueryInstanceCache/when_setting_last_result/with_a_result.d.ts.map +1 -0
  326. package/dist/esm/queries/for_QueryInstanceCache/when_setting_last_result/with_a_result.js +15 -0
  327. package/dist/esm/queries/for_QueryInstanceCache/when_setting_last_result/with_a_result.js.map +1 -0
  328. package/dist/esm/queries/for_ReconnectPolicy/when_canceling/with_pending_timer.d.ts +2 -0
  329. package/dist/esm/queries/for_ReconnectPolicy/when_canceling/with_pending_timer.d.ts.map +1 -0
  330. package/dist/esm/queries/for_ReconnectPolicy/when_canceling/with_pending_timer.js +24 -0
  331. package/dist/esm/queries/for_ReconnectPolicy/when_canceling/with_pending_timer.js.map +1 -0
  332. package/dist/esm/queries/for_ReconnectPolicy/when_cancelling/with_pending_timer.d.ts +2 -0
  333. package/dist/esm/queries/for_ReconnectPolicy/when_cancelling/with_pending_timer.d.ts.map +1 -0
  334. package/dist/esm/queries/for_ReconnectPolicy/when_cancelling/with_pending_timer.js +24 -0
  335. package/dist/esm/queries/for_ReconnectPolicy/when_cancelling/with_pending_timer.js.map +1 -0
  336. package/dist/esm/queries/for_ReconnectPolicy/when_resetting/after_scheduling.d.ts +2 -0
  337. package/dist/esm/queries/for_ReconnectPolicy/when_resetting/after_scheduling.d.ts.map +1 -0
  338. package/dist/esm/queries/for_ReconnectPolicy/when_resetting/after_scheduling.js +29 -0
  339. package/dist/esm/queries/for_ReconnectPolicy/when_resetting/after_scheduling.js.map +1 -0
  340. package/dist/esm/queries/for_ReconnectPolicy/when_scheduling/and_max_attempts_not_reached/delay_is_capped_at_max.d.ts +2 -0
  341. package/dist/esm/queries/for_ReconnectPolicy/when_scheduling/and_max_attempts_not_reached/delay_is_capped_at_max.d.ts.map +1 -0
  342. package/dist/esm/queries/for_ReconnectPolicy/when_scheduling/and_max_attempts_not_reached/delay_is_capped_at_max.js +33 -0
  343. package/dist/esm/queries/for_ReconnectPolicy/when_scheduling/and_max_attempts_not_reached/delay_is_capped_at_max.js.map +1 -0
  344. package/dist/esm/queries/for_ReconnectPolicy/when_scheduling/and_max_attempts_not_reached/first_attempt.d.ts +2 -0
  345. package/dist/esm/queries/for_ReconnectPolicy/when_scheduling/and_max_attempts_not_reached/first_attempt.d.ts.map +1 -0
  346. package/dist/esm/queries/for_ReconnectPolicy/when_scheduling/and_max_attempts_not_reached/first_attempt.js +28 -0
  347. package/dist/esm/queries/for_ReconnectPolicy/when_scheduling/and_max_attempts_not_reached/first_attempt.js.map +1 -0
  348. package/dist/esm/queries/for_ReconnectPolicy/when_scheduling/and_max_attempts_reached/abandons_reconnect.d.ts +2 -0
  349. package/dist/esm/queries/for_ReconnectPolicy/when_scheduling/and_max_attempts_reached/abandons_reconnect.d.ts.map +1 -0
  350. package/dist/esm/queries/for_ReconnectPolicy/when_scheduling/and_max_attempts_reached/abandons_reconnect.js +29 -0
  351. package/dist/esm/queries/for_ReconnectPolicy/when_scheduling/and_max_attempts_reached/abandons_reconnect.js.map +1 -0
  352. package/dist/esm/queries/for_ServerSentEventHubConnection/given/a_server_sent_event_hub_connection.d.ts +21 -0
  353. package/dist/esm/queries/for_ServerSentEventHubConnection/given/a_server_sent_event_hub_connection.d.ts.map +1 -0
  354. package/dist/esm/queries/for_ServerSentEventHubConnection/given/a_server_sent_event_hub_connection.js +50 -0
  355. package/dist/esm/queries/for_ServerSentEventHubConnection/given/a_server_sent_event_hub_connection.js.map +1 -0
  356. package/dist/esm/queries/for_ServerSentEventHubConnection/when_connect_timeout_fires/triggers_reconnect.d.ts +2 -0
  357. package/dist/esm/queries/for_ServerSentEventHubConnection/when_connect_timeout_fires/triggers_reconnect.d.ts.map +1 -0
  358. package/dist/esm/queries/for_ServerSentEventHubConnection/when_connect_timeout_fires/triggers_reconnect.js +24 -0
  359. package/dist/esm/queries/for_ServerSentEventHubConnection/when_connect_timeout_fires/triggers_reconnect.js.map +1 -0
  360. package/dist/esm/queries/for_ServerSentEventHubConnection/when_disposing/cleans_up_resources.d.ts +2 -0
  361. package/dist/esm/queries/for_ServerSentEventHubConnection/when_disposing/cleans_up_resources.d.ts.map +1 -0
  362. package/dist/esm/queries/for_ServerSentEventHubConnection/when_disposing/cleans_up_resources.js +27 -0
  363. package/dist/esm/queries/for_ServerSentEventHubConnection/when_disposing/cleans_up_resources.js.map +1 -0
  364. package/dist/esm/queries/for_ServerSentEventHubConnection/when_keep_alive_is_idle/triggers_reconnect.d.ts +2 -0
  365. package/dist/esm/queries/for_ServerSentEventHubConnection/when_keep_alive_is_idle/triggers_reconnect.d.ts.map +1 -0
  366. package/dist/esm/queries/for_ServerSentEventHubConnection/when_keep_alive_is_idle/triggers_reconnect.js +26 -0
  367. package/dist/esm/queries/for_ServerSentEventHubConnection/when_keep_alive_is_idle/triggers_reconnect.js.map +1 -0
  368. package/dist/esm/queries/for_ServerSentEventHubConnection/when_reconnecting/after_error.d.ts +2 -0
  369. package/dist/esm/queries/for_ServerSentEventHubConnection/when_reconnecting/after_error.d.ts.map +1 -0
  370. package/dist/esm/queries/for_ServerSentEventHubConnection/when_reconnecting/after_error.js +46 -0
  371. package/dist/esm/queries/for_ServerSentEventHubConnection/when_reconnecting/after_error.js.map +1 -0
  372. package/dist/esm/queries/for_ServerSentEventHubConnection/when_subscribing/queues_until_connected.d.ts +2 -0
  373. package/dist/esm/queries/for_ServerSentEventHubConnection/when_subscribing/queues_until_connected.d.ts.map +1 -0
  374. package/dist/esm/queries/for_ServerSentEventHubConnection/when_subscribing/queues_until_connected.js +21 -0
  375. package/dist/esm/queries/for_ServerSentEventHubConnection/when_subscribing/queues_until_connected.js.map +1 -0
  376. package/dist/esm/queries/for_ServerSentEventHubConnection/when_subscribing/sends_subscribe_post.d.ts +2 -0
  377. package/dist/esm/queries/for_ServerSentEventHubConnection/when_subscribing/sends_subscribe_post.d.ts.map +1 -0
  378. package/dist/esm/queries/for_ServerSentEventHubConnection/when_subscribing/sends_subscribe_post.js +32 -0
  379. package/dist/esm/queries/for_ServerSentEventHubConnection/when_subscribing/sends_subscribe_post.js.map +1 -0
  380. package/dist/esm/queries/for_ServerSentEventHubConnection/when_unsubscribing/the_only_query.d.ts +2 -0
  381. package/dist/esm/queries/for_ServerSentEventHubConnection/when_unsubscribing/the_only_query.d.ts.map +1 -0
  382. package/dist/esm/queries/for_ServerSentEventHubConnection/when_unsubscribing/the_only_query.js +21 -0
  383. package/dist/esm/queries/for_ServerSentEventHubConnection/when_unsubscribing/the_only_query.js.map +1 -0
  384. package/dist/esm/queries/for_ServerSentEventQueryConnection/when_connecting/with_query_arguments.d.ts +2 -0
  385. package/dist/esm/queries/for_ServerSentEventQueryConnection/when_connecting/with_query_arguments.d.ts.map +1 -0
  386. package/dist/esm/queries/for_ServerSentEventQueryConnection/when_connecting/with_query_arguments.js +38 -0
  387. package/dist/esm/queries/for_ServerSentEventQueryConnection/when_connecting/with_query_arguments.js.map +1 -0
  388. package/dist/esm/queries/for_ServerSentEventQueryConnection/when_connecting/without_event_source_available.d.ts +2 -0
  389. package/dist/esm/queries/for_ServerSentEventQueryConnection/when_connecting/without_event_source_available.d.ts.map +1 -0
  390. package/dist/esm/queries/for_ServerSentEventQueryConnection/when_connecting/without_event_source_available.js +23 -0
  391. package/dist/esm/queries/for_ServerSentEventQueryConnection/when_connecting/without_event_source_available.js.map +1 -0
  392. package/dist/esm/queries/for_ServerSentEventQueryConnection/when_disconnecting/after_connecting.d.ts +2 -0
  393. package/dist/esm/queries/for_ServerSentEventQueryConnection/when_disconnecting/after_connecting.d.ts.map +1 -0
  394. package/dist/esm/queries/for_ServerSentEventQueryConnection/when_disconnecting/after_connecting.js +24 -0
  395. package/dist/esm/queries/for_ServerSentEventQueryConnection/when_disconnecting/after_connecting.js.map +1 -0
  396. package/dist/esm/queries/for_ServerSentEventQueryConnection/when_disconnecting/before_message_arrives.d.ts +2 -0
  397. package/dist/esm/queries/for_ServerSentEventQueryConnection/when_disconnecting/before_message_arrives.d.ts.map +1 -0
  398. package/dist/esm/queries/for_ServerSentEventQueryConnection/when_disconnecting/before_message_arrives.js +24 -0
  399. package/dist/esm/queries/for_ServerSentEventQueryConnection/when_disconnecting/before_message_arrives.js.map +1 -0
  400. package/dist/esm/queries/for_WebSocketHubConnection/given/a_web_socket_hub_connection.d.ts +23 -0
  401. package/dist/esm/queries/for_WebSocketHubConnection/given/a_web_socket_hub_connection.d.ts.map +1 -0
  402. package/dist/esm/queries/for_WebSocketHubConnection/given/a_web_socket_hub_connection.js +47 -0
  403. package/dist/esm/queries/for_WebSocketHubConnection/given/a_web_socket_hub_connection.js.map +1 -0
  404. package/dist/esm/queries/for_WebSocketHubConnection/when_disposing/cleans_up_resources.d.ts +2 -0
  405. package/dist/esm/queries/for_WebSocketHubConnection/when_disposing/cleans_up_resources.d.ts.map +1 -0
  406. package/dist/esm/queries/for_WebSocketHubConnection/when_disposing/cleans_up_resources.js +24 -0
  407. package/dist/esm/queries/for_WebSocketHubConnection/when_disposing/cleans_up_resources.js.map +1 -0
  408. package/dist/esm/queries/for_WebSocketHubConnection/when_keep_alive_is_idle/sends_a_ping.d.ts +2 -0
  409. package/dist/esm/queries/for_WebSocketHubConnection/when_keep_alive_is_idle/sends_a_ping.d.ts.map +1 -0
  410. package/dist/esm/queries/for_WebSocketHubConnection/when_keep_alive_is_idle/sends_a_ping.js +29 -0
  411. package/dist/esm/queries/for_WebSocketHubConnection/when_keep_alive_is_idle/sends_a_ping.js.map +1 -0
  412. package/dist/esm/queries/for_WebSocketHubConnection/when_receiving_a_message/resets_keep_alive_timer.d.ts +2 -0
  413. package/dist/esm/queries/for_WebSocketHubConnection/when_receiving_a_message/resets_keep_alive_timer.d.ts.map +1 -0
  414. package/dist/esm/queries/for_WebSocketHubConnection/when_receiving_a_message/resets_keep_alive_timer.js +31 -0
  415. package/dist/esm/queries/for_WebSocketHubConnection/when_receiving_a_message/resets_keep_alive_timer.js.map +1 -0
  416. package/dist/esm/queries/for_WebSocketHubConnection/when_reconnecting/after_unexpected_close.d.ts +2 -0
  417. package/dist/esm/queries/for_WebSocketHubConnection/when_reconnecting/after_unexpected_close.d.ts.map +1 -0
  418. package/dist/esm/queries/for_WebSocketHubConnection/when_reconnecting/after_unexpected_close.js +30 -0
  419. package/dist/esm/queries/for_WebSocketHubConnection/when_reconnecting/after_unexpected_close.js.map +1 -0
  420. package/dist/esm/queries/for_WebSocketHubConnection/when_reconnecting/resubscribes_all_queries.d.ts +2 -0
  421. package/dist/esm/queries/for_WebSocketHubConnection/when_reconnecting/resubscribes_all_queries.d.ts.map +1 -0
  422. package/dist/esm/queries/for_WebSocketHubConnection/when_reconnecting/resubscribes_all_queries.js +31 -0
  423. package/dist/esm/queries/for_WebSocketHubConnection/when_reconnecting/resubscribes_all_queries.js.map +1 -0
  424. package/dist/esm/queries/for_WebSocketHubConnection/when_subscribing/to_a_query.d.ts +2 -0
  425. package/dist/esm/queries/for_WebSocketHubConnection/when_subscribing/to_a_query.d.ts.map +1 -0
  426. package/dist/esm/queries/for_WebSocketHubConnection/when_subscribing/to_a_query.js +32 -0
  427. package/dist/esm/queries/for_WebSocketHubConnection/when_subscribing/to_a_query.js.map +1 -0
  428. package/dist/esm/queries/for_WebSocketHubConnection/when_unsubscribing/the_only_query.d.ts +2 -0
  429. package/dist/esm/queries/for_WebSocketHubConnection/when_unsubscribing/the_only_query.d.ts.map +1 -0
  430. package/dist/esm/queries/for_WebSocketHubConnection/when_unsubscribing/the_only_query.js +23 -0
  431. package/dist/esm/queries/for_WebSocketHubConnection/when_unsubscribing/the_only_query.js.map +1 -0
  432. package/dist/esm/queries/index.d.ts +12 -0
  433. package/dist/esm/queries/index.d.ts.map +1 -1
  434. package/dist/esm/queries/index.js +10 -0
  435. package/dist/esm/queries/index.js.map +1 -1
  436. package/dist/esm/tsconfig.tsbuildinfo +1 -1
  437. package/package.json +1 -1
  438. package/queries/HubConnectionKeepAlive.ts +61 -0
  439. package/queries/IObservableQueryHubConnection.ts +50 -0
  440. package/queries/IReconnectPolicy.ts +39 -0
  441. package/queries/ObservableQueryConnection.ts +8 -24
  442. package/queries/ObservableQueryConnectionFactory.ts +118 -0
  443. package/queries/ObservableQueryConnectionPool.ts +64 -0
  444. package/queries/ObservableQueryFor.ts +11 -5
  445. package/queries/ObservableQueryMultiplexer.ts +214 -0
  446. package/queries/QueryInstanceCache.ts +243 -0
  447. package/queries/QueryTransportMethod.ts +17 -0
  448. package/queries/ReconnectPolicy.ts +68 -0
  449. package/queries/ServerSentEventHubConnection.ts +309 -0
  450. package/queries/ServerSentEventQueryConnection.ts +84 -0
  451. package/queries/WebSocketHubConnection.ts +291 -0
  452. package/queries/for_HubConnectionKeepAlive/behavior.ts +73 -0
  453. package/queries/for_ObservableQueryConnection/given/an_observable_query_connection.ts +13 -9
  454. package/queries/for_ObservableQueryConnectionFactory/given/a_descriptor.ts +26 -0
  455. package/queries/for_ObservableQueryConnectionFactory/when_creating/with_direct_mode_and_sse_transport.ts +62 -0
  456. package/queries/for_ObservableQueryConnectionFactory/when_creating/with_direct_mode_and_websocket_transport.ts +59 -0
  457. package/queries/for_ObservableQueryConnectionFactory/when_creating/with_hub_mode_and_sse_transport.ts +69 -0
  458. package/queries/for_ObservableQueryConnectionFactory/when_creating/with_hub_mode_and_websocket_transport.ts +61 -0
  459. package/queries/for_ObservableQueryConnectionPool/when_acquiring/with_multiple_slots/and_least_loaded_slot_is_chosen.ts +47 -0
  460. package/queries/for_ObservableQueryConnectionPool/when_acquiring/with_multiple_slots/and_size_is_zero.ts +26 -0
  461. package/queries/for_ObservableQueryConnectionPool/when_acquiring/with_single_slot/and_one_subscriber.ts +44 -0
  462. package/queries/for_ObservableQueryFor/when_subscribing/with_direct_mode_and_sse_transport.ts +69 -0
  463. package/queries/for_ObservableQueryFor/when_subscribing/with_direct_mode_disabled_and_sse_transport.ts +70 -0
  464. package/queries/for_ObservableQueryFor/when_subscribing/with_direct_mode_enabled.ts +57 -0
  465. package/queries/for_ObservableQueryFor/when_subscribing/with_partially_missing_required_arguments.ts +19 -11
  466. package/queries/for_ObservableQueryFor/when_subscribing/with_route_and_query_args.ts +14 -7
  467. package/queries/for_QueryInstanceCache/when_building_key/with_arguments.ts +17 -0
  468. package/queries/for_QueryInstanceCache/when_building_key/with_empty_arguments_object.ts +16 -0
  469. package/queries/for_QueryInstanceCache/when_building_key/with_same_arguments_different_order.ts +18 -0
  470. package/queries/for_QueryInstanceCache/when_building_key/without_arguments.ts +16 -0
  471. package/queries/for_QueryInstanceCache/when_getting_last_result/with_no_result_stored.ts +17 -0
  472. package/queries/for_QueryInstanceCache/when_getting_last_result/with_stored_result.ts +23 -0
  473. package/queries/for_QueryInstanceCache/when_getting_or_creating/with_existing_entry.ts +29 -0
  474. package/queries/for_QueryInstanceCache/when_getting_or_creating/with_new_entry.ts +21 -0
  475. package/queries/for_QueryInstanceCache/when_releasing/a_key_that_does_not_exist.ts +21 -0
  476. package/queries/for_QueryInstanceCache/when_releasing/one_of_two_subscribers.ts +18 -0
  477. package/queries/for_QueryInstanceCache/when_releasing/the_only_subscriber.ts +23 -0
  478. package/queries/for_QueryInstanceCache/when_setting_last_result/with_a_result.ts +20 -0
  479. package/queries/for_ReconnectPolicy/when_canceling/with_pending_timer.ts +33 -0
  480. package/queries/for_ReconnectPolicy/when_cancelling/with_pending_timer.ts +33 -0
  481. package/queries/for_ReconnectPolicy/when_resetting/after_scheduling.ts +39 -0
  482. package/queries/for_ReconnectPolicy/when_scheduling/and_max_attempts_not_reached/delay_is_capped_at_max.ts +44 -0
  483. package/queries/for_ReconnectPolicy/when_scheduling/and_max_attempts_not_reached/first_attempt.ts +38 -0
  484. package/queries/for_ReconnectPolicy/when_scheduling/and_max_attempts_reached/abandons_reconnect.ts +39 -0
  485. package/queries/for_ServerSentEventHubConnection/given/a_server_sent_event_hub_connection.ts +85 -0
  486. package/queries/for_ServerSentEventHubConnection/when_connect_timeout_fires/triggers_reconnect.ts +46 -0
  487. package/queries/for_ServerSentEventHubConnection/when_disposing/cleans_up_resources.ts +34 -0
  488. package/queries/for_ServerSentEventHubConnection/when_keep_alive_is_idle/triggers_reconnect.ts +48 -0
  489. package/queries/for_ServerSentEventHubConnection/when_reconnecting/after_error.ts +62 -0
  490. package/queries/for_ServerSentEventHubConnection/when_subscribing/queues_until_connected.ts +31 -0
  491. package/queries/for_ServerSentEventHubConnection/when_subscribing/sends_subscribe_post.ts +42 -0
  492. package/queries/for_ServerSentEventHubConnection/when_unsubscribing/the_only_query.ts +32 -0
  493. package/queries/for_ServerSentEventQueryConnection/when_connecting/with_query_arguments.ts +63 -0
  494. package/queries/for_ServerSentEventQueryConnection/when_connecting/without_event_source_available.ts +31 -0
  495. package/queries/for_ServerSentEventQueryConnection/when_disconnecting/after_connecting.ts +36 -0
  496. package/queries/for_ServerSentEventQueryConnection/when_disconnecting/before_message_arrives.ts +38 -0
  497. package/queries/for_WebSocketHubConnection/given/a_web_socket_hub_connection.ts +81 -0
  498. package/queries/for_WebSocketHubConnection/when_disposing/cleans_up_resources.ts +31 -0
  499. package/queries/for_WebSocketHubConnection/when_keep_alive_is_idle/sends_a_ping.ts +47 -0
  500. package/queries/for_WebSocketHubConnection/when_receiving_a_message/resets_keep_alive_timer.ts +53 -0
  501. package/queries/for_WebSocketHubConnection/when_reconnecting/after_unexpected_close.ts +41 -0
  502. package/queries/for_WebSocketHubConnection/when_reconnecting/resubscribes_all_queries.ts +43 -0
  503. package/queries/for_WebSocketHubConnection/when_subscribing/to_a_query.ts +42 -0
  504. package/queries/for_WebSocketHubConnection/when_unsubscribing/the_only_query.ts +30 -0
  505. package/queries/index.ts +12 -0
@@ -0,0 +1,62 @@
1
+ // Copyright (c) Cratis. All rights reserved.
2
+ // Licensed under the MIT license. See LICENSE file in the project root for full license information.
3
+
4
+ import sinon from 'sinon';
5
+ import { a_server_sent_event_hub_connection } from '../given/a_server_sent_event_hub_connection';
6
+ import { given } from '../../../given';
7
+ import { HubMessageType } from '../../WebSocketHubConnection';
8
+ import { ReconnectCallback } from '../../IReconnectPolicy';
9
+
10
+ describe('when connection errors', given(a_server_sent_event_hub_connection, context => {
11
+ const queryId = 'q1';
12
+
13
+ beforeEach(() => {
14
+ context.setup();
15
+ context.connection.subscribe(queryId, { queryName: 'MyQuery' }, sinon.stub());
16
+ context.simulateOpen();
17
+ context.simulateMessage({ type: HubMessageType.Connected, payload: 'conn-1' });
18
+ context.simulateError();
19
+ });
20
+
21
+ afterEach(() => sinon.restore());
22
+
23
+ it('should close the EventSource', () => context.fakeEventSource.close.calledOnce.should.be.true);
24
+
25
+ it('should delegate to the reconnect policy', () => {
26
+ (context.policy.schedule as sinon.SinonStub).calledOnce.should.be.true;
27
+ });
28
+
29
+ describe('when the policy fires the reconnect callback', () => {
30
+ let newEventSourceCreated: boolean;
31
+
32
+ beforeEach(() => {
33
+ newEventSourceCreated = false;
34
+ // Replace the global EventSource with a stub that records construction
35
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
36
+ const FakeClass = function (this: any) {
37
+ newEventSourceCreated = true;
38
+ return context.fakeEventSource;
39
+ } as unknown as new (url: string) => EventSource;
40
+ (FakeClass as unknown as Record<string, unknown>)['CONNECTING'] = 0;
41
+ (FakeClass as unknown as Record<string, unknown>)['OPEN'] = 1;
42
+ (FakeClass as unknown as Record<string, unknown>)['CLOSED'] = 2;
43
+ (globalThis as Record<string, unknown>)['EventSource'] = FakeClass;
44
+
45
+ const reconnectCallback = (context.policy.schedule as sinon.SinonStub).getCall(0).args[0] as ReconnectCallback;
46
+ reconnectCallback();
47
+ });
48
+
49
+ it('should open a new EventSource', () => newEventSourceCreated.should.be.true);
50
+ });
51
+
52
+ describe('when Connected arrives after reconnect', () => {
53
+ beforeEach(() => {
54
+ const reconnectCallback = (context.policy.schedule as sinon.SinonStub).getCall(0).args[0] as ReconnectCallback;
55
+ reconnectCallback();
56
+ context.fetchStub.resetHistory();
57
+ context.simulateMessage({ type: HubMessageType.Connected, payload: 'conn-2' });
58
+ });
59
+
60
+ it('should re-subscribe all active queries', () => context.fetchStub.calledOnce.should.be.true);
61
+ });
62
+ }));
@@ -0,0 +1,31 @@
1
+ // Copyright (c) Cratis. All rights reserved.
2
+ // Licensed under the MIT license. See LICENSE file in the project root for full license information.
3
+
4
+ import sinon from 'sinon';
5
+ import { a_server_sent_event_hub_connection } from '../given/a_server_sent_event_hub_connection';
6
+ import { given } from '../../../given';
7
+ import { HubMessageType } from '../../WebSocketHubConnection';
8
+
9
+ describe('when subscribing before Connected arrives', given(a_server_sent_event_hub_connection, context => {
10
+ const queryId = 'q1';
11
+
12
+ beforeEach(() => {
13
+ // Subscribe before Connected message — no connectionId yet
14
+ context.setup();
15
+ context.connection.subscribe(queryId, { queryName: 'MyQuery' }, sinon.stub());
16
+ context.simulateOpen();
17
+ // No Connected message yet
18
+ });
19
+
20
+ afterEach(() => sinon.restore());
21
+
22
+ it('should not POST before the Connected message arrives', () => context.fetchStub.callCount.should.equal(0));
23
+
24
+ describe('when Connected message arrives', () => {
25
+ beforeEach(() => {
26
+ context.simulateMessage({ type: HubMessageType.Connected, payload: 'conn-1' });
27
+ });
28
+
29
+ it('should drain the pending subscription with a POST', () => context.fetchStub.calledOnce.should.be.true);
30
+ });
31
+ }));
@@ -0,0 +1,42 @@
1
+ // Copyright (c) Cratis. All rights reserved.
2
+ // Licensed under the MIT license. See LICENSE file in the project root for full license information.
3
+
4
+ import sinon from 'sinon';
5
+ import { a_server_sent_event_hub_connection } from '../given/a_server_sent_event_hub_connection';
6
+ import { given } from '../../../given';
7
+ import { HubMessageType } from '../../WebSocketHubConnection';
8
+
9
+ describe('when subscribing sends the subscribe POST after Connected', given(a_server_sent_event_hub_connection, context => {
10
+ const queryId = 'q1';
11
+ const connectionId = 'conn-abc';
12
+
13
+ beforeEach(() => {
14
+ context.setup();
15
+ context.connection.subscribe(queryId, { queryName: 'MyQuery' }, sinon.stub());
16
+ context.simulateOpen();
17
+ context.simulateMessage({ type: HubMessageType.Connected, payload: connectionId });
18
+ });
19
+
20
+ afterEach(() => sinon.restore());
21
+
22
+ it('should POST to the subscribe URL', () => context.fetchStub.calledOnce.should.be.true);
23
+ it('should pass the connection id in the request body', () => {
24
+ const body = JSON.parse(context.fetchStub.getCall(0).args[1].body);
25
+ body.connectionId.should.equal(connectionId);
26
+ });
27
+ it('should pass the query id in the request body', () => {
28
+ const body = JSON.parse(context.fetchStub.getCall(0).args[1].body);
29
+ body.queryId.should.equal(queryId);
30
+ });
31
+
32
+ describe('when a query result message arrives', () => {
33
+ const result = { isSuccess: true, data: ['x'] };
34
+
35
+ beforeEach(() => {
36
+ context.simulateMessage({ type: HubMessageType.QueryResult, queryId, payload: result });
37
+ });
38
+
39
+ // The callback passed to subscribe during beforeEach is a stub — re-verify via query count
40
+ it('should have one active subscription', () => context.connection.queryCount.should.equal(1));
41
+ });
42
+ }));
@@ -0,0 +1,32 @@
1
+ // Copyright (c) Cratis. All rights reserved.
2
+ // Licensed under the MIT license. See LICENSE file in the project root for full license information.
3
+
4
+ import sinon from 'sinon';
5
+ import { a_server_sent_event_hub_connection } from '../given/a_server_sent_event_hub_connection';
6
+ import { given } from '../../../given';
7
+ import { HubMessageType } from '../../WebSocketHubConnection';
8
+
9
+ describe('when unsubscribing the only query', given(a_server_sent_event_hub_connection, context => {
10
+ beforeEach(async () => {
11
+ context.setup();
12
+ context.connection.subscribe('q1', { queryName: 'MyQuery' }, sinon.stub());
13
+ context.simulateOpen();
14
+ context.simulateMessage({ type: HubMessageType.Connected, payload: 'conn-abc' });
15
+
16
+ context.connection.unsubscribe('q1');
17
+
18
+ // Allow the micro-task queue to drain so the async fetch completes.
19
+ await Promise.resolve();
20
+ });
21
+
22
+ afterEach(() => sinon.restore());
23
+
24
+ it('should close the event source', () => context.fakeEventSource.close.calledOnce.should.be.true);
25
+
26
+ it('should send an unsubscribe POST request', () => {
27
+ const unsubscribeCalls = context.fetchStub.args.filter(
28
+ (args: unknown[]) => typeof args[0] === 'string' && (args[0] as string).includes('unsubscribe')
29
+ );
30
+ unsubscribeCalls.length.should.equal(1);
31
+ });
32
+ }));
@@ -0,0 +1,63 @@
1
+ // Copyright (c) Cratis. All rights reserved.
2
+ // Licensed under the MIT license. See LICENSE file in the project root for full license information.
3
+
4
+ import sinon from 'sinon';
5
+ import { ServerSentEventQueryConnection } from '../../ServerSentEventQueryConnection';
6
+ import { QueryResult } from '../../QueryResult';
7
+
8
+ interface FakeEventSource {
9
+ url: string;
10
+ onmessage: ((event: MessageEvent) => void) | null;
11
+ onerror: (() => void) | null;
12
+ close: sinon.SinonStub;
13
+ }
14
+
15
+ describe('when connecting with query arguments', () => {
16
+ let fakeEventSource: FakeEventSource;
17
+ let connection: ServerSentEventQueryConnection<string[]>;
18
+ let receivedData: QueryResult<string[]>[];
19
+
20
+ beforeEach(() => {
21
+ fakeEventSource = {
22
+ url: '',
23
+ onmessage: null,
24
+ onerror: null,
25
+ close: sinon.stub(),
26
+ };
27
+
28
+ const FakeEventSourceClass = function (this: FakeEventSource, url: string) {
29
+ fakeEventSource.url = url;
30
+ Object.assign(fakeEventSource, { onmessage: null, onerror: null });
31
+ return fakeEventSource;
32
+ };
33
+
34
+ (globalThis as Record<string, unknown>)['EventSource'] = FakeEventSourceClass;
35
+
36
+ receivedData = [];
37
+ connection = new ServerSentEventQueryConnection<string[]>(
38
+ new URL('http://localhost/.cratis/queries/sse?query=Test')
39
+ );
40
+ connection.connect(
41
+ (result: QueryResult<string[]>) => receivedData.push(result),
42
+ { category: 'books' }
43
+ );
44
+ });
45
+
46
+ afterEach(() => {
47
+ delete (globalThis as Record<string, unknown>)['EventSource'];
48
+ sinon.restore();
49
+ });
50
+
51
+ it('should append query arguments to the URL', () => fakeEventSource.url.should.contain('category=books'));
52
+
53
+ describe('when a message arrives', () => {
54
+ const result = { data: ['a', 'b'], isSuccess: true, isAuthorized: true, isValid: true, hasExceptions: false, hasData: true, validationResults: [], exceptionMessages: [], exceptionStackTrace: '', paging: { page: 0, size: 0, totalItems: 0, totalPages: 0 } };
55
+
56
+ beforeEach(() => {
57
+ fakeEventSource.onmessage!({ data: JSON.stringify(result) } as MessageEvent);
58
+ });
59
+
60
+ it('should deliver the payload to the callback', () => receivedData.length.should.equal(1));
61
+ it('should pass through the raw QueryResult in direct mode', () => receivedData[0]!.isSuccess.should.be.true);
62
+ });
63
+ });
@@ -0,0 +1,31 @@
1
+ // Copyright (c) Cratis. All rights reserved.
2
+ // Licensed under the MIT license. See LICENSE file in the project root for full license information.
3
+
4
+ import sinon from 'sinon';
5
+ import { ServerSentEventQueryConnection } from '../../ServerSentEventQueryConnection';
6
+ import { QueryResult } from '../../QueryResult';
7
+
8
+ describe('when connecting in an environment where EventSource is not available', () => {
9
+ let originalEventSource: typeof EventSource;
10
+ let connection: ServerSentEventQueryConnection<string[]>;
11
+ let dataReceivedStub: sinon.SinonStub;
12
+
13
+ beforeEach(() => {
14
+ originalEventSource = (globalThis as Record<string, unknown>)['EventSource'] as typeof EventSource;
15
+ delete (globalThis as Record<string, unknown>)['EventSource'];
16
+
17
+ dataReceivedStub = sinon.stub();
18
+ connection = new ServerSentEventQueryConnection<string[]>(new URL('http://localhost/.cratis/queries/sse?query=Test'));
19
+ connection.connect(dataReceivedStub as unknown as (result: QueryResult<string[]>) => void);
20
+ });
21
+
22
+ afterEach(() => {
23
+ if (originalEventSource !== undefined) {
24
+ (globalThis as Record<string, unknown>)['EventSource'] = originalEventSource;
25
+ }
26
+ sinon.restore();
27
+ });
28
+
29
+ it('should not call data received', () => dataReceivedStub.called.should.be.false);
30
+ it('should not throw', () => true.should.be.true);
31
+ });
@@ -0,0 +1,36 @@
1
+ // Copyright (c) Cratis. All rights reserved.
2
+ // Licensed under the MIT license. See LICENSE file in the project root for full license information.
3
+
4
+ import sinon from 'sinon';
5
+ import { ServerSentEventQueryConnection } from '../../ServerSentEventQueryConnection';
6
+ import { QueryResult } from '../../QueryResult';
7
+
8
+ describe('when disconnecting closes the EventSource', () => {
9
+ let closeStub: sinon.SinonStub;
10
+ let connection: ServerSentEventQueryConnection<string[]>;
11
+
12
+ beforeEach(() => {
13
+ closeStub = sinon.stub();
14
+
15
+ const FakeEventSourceClass = function (this: Record<string, unknown>) {
16
+ this.onmessage = null;
17
+ this.onerror = null;
18
+ this.close = closeStub;
19
+ };
20
+
21
+ (globalThis as Record<string, unknown>)['EventSource'] = FakeEventSourceClass;
22
+
23
+ connection = new ServerSentEventQueryConnection<string[]>(
24
+ new URL('http://localhost/.cratis/queries/sse?query=Test')
25
+ );
26
+ connection.connect((_: QueryResult<string[]>) => _);
27
+ connection.disconnect();
28
+ });
29
+
30
+ afterEach(() => {
31
+ delete (globalThis as Record<string, unknown>)['EventSource'];
32
+ sinon.restore();
33
+ });
34
+
35
+ it('should call close on the EventSource', () => closeStub.calledOnce.should.be.true);
36
+ });
@@ -0,0 +1,38 @@
1
+ // Copyright (c) Cratis. All rights reserved.
2
+ // Licensed under the MIT license. See LICENSE file in the project root for full license information.
3
+
4
+ import sinon from 'sinon';
5
+ import { ServerSentEventQueryConnection } from '../../ServerSentEventQueryConnection';
6
+
7
+ describe('when disconnecting prevents further message delivery', () => {
8
+ let fakeEventSource: Record<string, unknown>;
9
+ let connection: ServerSentEventQueryConnection<string[]>;
10
+ let receivedCount: number;
11
+
12
+ beforeEach(() => {
13
+ fakeEventSource = { onmessage: null, onerror: null, close: sinon.stub() };
14
+
15
+ (globalThis as Record<string, unknown>)['EventSource'] = function () {
16
+ return fakeEventSource;
17
+ };
18
+
19
+ receivedCount = 0;
20
+ connection = new ServerSentEventQueryConnection<string[]>(
21
+ new URL('http://localhost/.cratis/queries/sse?query=Test')
22
+ );
23
+ connection.connect(() => { receivedCount++; });
24
+
25
+ // Disconnect first, then send a message
26
+ connection.disconnect();
27
+ (fakeEventSource['onmessage'] as ((event: MessageEvent) => void) | null)?.(
28
+ { data: JSON.stringify({ isSuccess: true }) } as MessageEvent
29
+ );
30
+ });
31
+
32
+ afterEach(() => {
33
+ delete (globalThis as Record<string, unknown>)['EventSource'];
34
+ sinon.restore();
35
+ });
36
+
37
+ it('should not deliver messages after disconnect', () => receivedCount.should.equal(0));
38
+ });
@@ -0,0 +1,81 @@
1
+ // Copyright (c) Cratis. All rights reserved.
2
+ // Licensed under the MIT license. See LICENSE file in the project root for full license information.
3
+
4
+ import sinon from 'sinon';
5
+ import { WebSocketHubConnection } from '../../WebSocketHubConnection';
6
+ import { IReconnectPolicy } from '../../IReconnectPolicy';
7
+ import { ReconnectCallback } from '../../IReconnectPolicy';
8
+
9
+ /* eslint-disable @typescript-eslint/no-explicit-any */
10
+
11
+ export class a_web_socket_hub_connection {
12
+ connection!: WebSocketHubConnection;
13
+ fakeSocket!: {
14
+ onopen: (() => void) | null;
15
+ onclose: (() => void) | null;
16
+ onerror: ((error: Event) => void) | null;
17
+ onmessage: ((ev: MessageEvent) => void) | null;
18
+ send: sinon.SinonStub;
19
+ close: sinon.SinonStub;
20
+ readyState: number;
21
+ };
22
+ policy!: sinon.SinonStubbedInstance<IReconnectPolicy>;
23
+ WebSocketStub!: sinon.SinonStub;
24
+
25
+ constructor() {
26
+ this.setup();
27
+ }
28
+
29
+ /**
30
+ * Re-initializes stubs and creates a fresh {@link WebSocketHubConnection}.
31
+ * Call this at the start of each {@code beforeEach} to prevent stub-call
32
+ * accumulation across tests sharing the same context instance.
33
+ */
34
+ setup(): void {
35
+ this.fakeSocket = {
36
+ onopen: null,
37
+ onclose: null,
38
+ onerror: null,
39
+ onmessage: null,
40
+ send: sinon.stub(),
41
+ close: sinon.stub(),
42
+ readyState: 0, // CONNECTING
43
+ };
44
+
45
+ this.WebSocketStub = sinon.stub().returns(this.fakeSocket);
46
+ (globalThis as any)['WebSocket'] = this.WebSocketStub;
47
+ // WebSocket ready-state constants (numeric values matching the spec)
48
+ (globalThis as any)['WebSocket'].CONNECTING = 0;
49
+ (globalThis as any)['WebSocket'].OPEN = 1;
50
+ (globalThis as any)['WebSocket'].CLOSING = 2;
51
+ (globalThis as any)['WebSocket'].CLOSED = 3;
52
+
53
+ this.policy = {
54
+ attempt: 0,
55
+ schedule: sinon.stub<[ReconnectCallback, string], boolean>().returns(true),
56
+ reset: sinon.stub(),
57
+ cancel: sinon.stub(),
58
+ };
59
+
60
+ this.connection = new WebSocketHubConnection(
61
+ 'ws://localhost/.cratis/queries/ws',
62
+ '',
63
+ undefined,
64
+ this.policy
65
+ );
66
+ }
67
+
68
+ simulateOpen(): void {
69
+ this.fakeSocket.readyState = 1; // OPEN
70
+ this.fakeSocket.onopen?.();
71
+ }
72
+
73
+ simulateClose(): void {
74
+ this.fakeSocket.readyState = 3; // CLOSED
75
+ this.fakeSocket.onclose?.();
76
+ }
77
+
78
+ simulateMessage(payload: object): void {
79
+ this.fakeSocket.onmessage?.({ data: JSON.stringify(payload) } as MessageEvent);
80
+ }
81
+ }
@@ -0,0 +1,31 @@
1
+ // Copyright (c) Cratis. All rights reserved.
2
+ // Licensed under the MIT license. See LICENSE file in the project root for full license information.
3
+
4
+ import sinon from 'sinon';
5
+ import { a_web_socket_hub_connection } from '../given/a_web_socket_hub_connection';
6
+ import { given } from '../../../given';
7
+
8
+ describe('when disposing the hub connection', given(a_web_socket_hub_connection, context => {
9
+ beforeEach(() => {
10
+ context.setup();
11
+ context.connection.subscribe('q1', { queryName: 'MyQuery' }, sinon.stub());
12
+ context.simulateOpen();
13
+ context.connection.dispose();
14
+ });
15
+
16
+ afterEach(() => sinon.restore());
17
+
18
+ it('should close the socket', () => context.fakeSocket.close.calledOnce.should.be.true);
19
+ it('should cancel the reconnect policy', () => (context.policy.cancel as sinon.SinonStub).calledOnce.should.be.true);
20
+
21
+ describe('when the socket fires onclose after dispose', () => {
22
+ beforeEach(() => {
23
+ (context.policy.schedule as sinon.SinonStub).reset();
24
+ context.simulateClose();
25
+ });
26
+
27
+ it('should not schedule a reconnect', () => {
28
+ (context.policy.schedule as sinon.SinonStub).callCount.should.equal(0);
29
+ });
30
+ });
31
+ }));
@@ -0,0 +1,47 @@
1
+ // Copyright (c) Cratis. All rights reserved.
2
+ // Licensed under the MIT license. See LICENSE file in the project root for full license information.
3
+
4
+ import sinon from 'sinon';
5
+ import { a_web_socket_hub_connection } from '../given/a_web_socket_hub_connection';
6
+ import { given } from '../../../given';
7
+ import { HubMessageType } from '../../WebSocketHubConnection';
8
+
9
+ const PING_INTERVAL_MS = 500;
10
+
11
+ describe('when keep-alive interval elapses without any message', given(a_web_socket_hub_connection, context => {
12
+ let clock: sinon.SinonFakeTimers;
13
+
14
+ beforeEach(() => {
15
+ clock = sinon.useFakeTimers();
16
+ context.setup();
17
+
18
+ // Construct a new connection with a short ping interval so tests are fast.
19
+ // eslint-disable-next-line @typescript-eslint/no-require-imports, @typescript-eslint/no-var-requires
20
+ const { WebSocketHubConnection } = require('../../WebSocketHubConnection');
21
+ context.connection = new WebSocketHubConnection(
22
+ 'ws://localhost/.cratis/queries/ws',
23
+ '',
24
+ PING_INTERVAL_MS,
25
+ context.policy
26
+ );
27
+
28
+ context.connection.subscribe('q1', { queryName: 'MyQuery' }, sinon.stub());
29
+ context.simulateOpen();
30
+
31
+ // Advance past the ping interval without sending any messages.
32
+ clock.tick(PING_INTERVAL_MS + 1);
33
+ });
34
+
35
+ afterEach(() => {
36
+ clock.restore();
37
+ sinon.restore();
38
+ });
39
+
40
+ it('should send a ping message', () => {
41
+ const sentMessages: string[] = context.fakeSocket.send.args.map((a: string[]) => a[0]);
42
+ const pingMessages = sentMessages
43
+ .map((m: string) => JSON.parse(m))
44
+ .filter((m: { type: HubMessageType }) => m.type === HubMessageType.Ping);
45
+ pingMessages.length.should.be.greaterThan(0);
46
+ });
47
+ }));
@@ -0,0 +1,53 @@
1
+ // Copyright (c) Cratis. All rights reserved.
2
+ // Licensed under the MIT license. See LICENSE file in the project root for full license information.
3
+
4
+ import sinon from 'sinon';
5
+ import { a_web_socket_hub_connection } from '../given/a_web_socket_hub_connection';
6
+ import { given } from '../../../given';
7
+ import { HubMessageType } from '../../WebSocketHubConnection';
8
+
9
+ const PING_INTERVAL_MS = 500;
10
+
11
+ describe('when a message is received and then keep-alive interval elapses', given(a_web_socket_hub_connection, context => {
12
+ let clock: sinon.SinonFakeTimers;
13
+
14
+ beforeEach(() => {
15
+ clock = sinon.useFakeTimers();
16
+ context.setup();
17
+
18
+ // eslint-disable-next-line @typescript-eslint/no-require-imports, @typescript-eslint/no-var-requires
19
+ const { WebSocketHubConnection } = require('../../WebSocketHubConnection');
20
+ context.connection = new WebSocketHubConnection(
21
+ 'ws://localhost/.cratis/queries/ws',
22
+ '',
23
+ PING_INTERVAL_MS,
24
+ context.policy
25
+ );
26
+
27
+ context.connection.subscribe('q1', { queryName: 'MyQuery' }, sinon.stub());
28
+ context.simulateOpen();
29
+
30
+ // Advance to just before the ping interval.
31
+ clock.tick(PING_INTERVAL_MS - 50);
32
+
33
+ // A message arrives — this resets the inactivity timer.
34
+ context.simulateMessage({ type: HubMessageType.QueryResult, queryId: 'q1', payload: { items: [], totalItems: 0 } });
35
+
36
+ // Advance another half interval — total elapsed is PING_INTERVAL_MS + PING_INTERVAL_MS/2 - 50,
37
+ // but only PING_INTERVAL_MS/2 has passed since the last activity.
38
+ clock.tick(PING_INTERVAL_MS / 2);
39
+ });
40
+
41
+ afterEach(() => {
42
+ clock.restore();
43
+ sinon.restore();
44
+ });
45
+
46
+ it('should not send a ping', () => {
47
+ const sentMessages: string[] = context.fakeSocket.send.args.map((a: string[]) => a[0]);
48
+ const pingMessages = sentMessages
49
+ .map((m: string) => JSON.parse(m))
50
+ .filter((m: { type: HubMessageType }) => m.type === HubMessageType.Ping);
51
+ pingMessages.length.should.equal(0);
52
+ });
53
+ }));
@@ -0,0 +1,41 @@
1
+ // Copyright (c) Cratis. All rights reserved.
2
+ // Licensed under the MIT license. See LICENSE file in the project root for full license information.
3
+
4
+ import sinon from 'sinon';
5
+ import { a_web_socket_hub_connection } from '../given/a_web_socket_hub_connection';
6
+ import { given } from '../../../given';
7
+ import { ReconnectCallback } from '../../IReconnectPolicy';
8
+
9
+ describe('when the connection closes unexpectedly', given(a_web_socket_hub_connection, context => {
10
+ beforeEach(() => {
11
+ context.setup();
12
+ context.connection.subscribe('q1', { queryName: 'MyQuery' }, sinon.stub());
13
+ context.simulateOpen();
14
+ context.simulateClose();
15
+ });
16
+
17
+ afterEach(() => sinon.restore());
18
+
19
+ it('should delegate to the reconnect policy', () => {
20
+ (context.policy.schedule as sinon.SinonStub).calledOnce.should.be.true;
21
+ });
22
+
23
+ describe('when the policy fires the reconnect callback', () => {
24
+ let secondSocketCreated: boolean;
25
+
26
+ beforeEach(() => {
27
+ secondSocketCreated = false;
28
+ context.WebSocketStub.callsFake(() => {
29
+ secondSocketCreated = true;
30
+ return context.fakeSocket;
31
+ });
32
+
33
+ // Simulate the policy invoking the callback immediately
34
+ const scheduleCall = (context.policy.schedule as sinon.SinonStub).getCall(0);
35
+ const reconnectCallback = scheduleCall.args[0] as ReconnectCallback;
36
+ reconnectCallback();
37
+ });
38
+
39
+ it('should open a new WebSocket', () => secondSocketCreated.should.be.true);
40
+ });
41
+ }));
@@ -0,0 +1,43 @@
1
+ // Copyright (c) Cratis. All rights reserved.
2
+ // Licensed under the MIT license. See LICENSE file in the project root for full license information.
3
+
4
+ import sinon from 'sinon';
5
+ import { a_web_socket_hub_connection } from '../given/a_web_socket_hub_connection';
6
+ import { given } from '../../../given';
7
+ import { HubMessageType } from '../../WebSocketHubConnection';
8
+ import { ReconnectCallback } from '../../IReconnectPolicy';
9
+
10
+ describe('when reconnecting after a drop', given(a_web_socket_hub_connection, context => {
11
+ const queryId = 'q1';
12
+ let callbackStub: sinon.SinonStub;
13
+
14
+ beforeEach(() => {
15
+ callbackStub = sinon.stub();
16
+ context.setup();
17
+ context.connection.subscribe(queryId, { queryName: 'MyQuery' }, callbackStub);
18
+ context.simulateOpen();
19
+
20
+ // Simulate drop and policy-driven reconnect
21
+ context.simulateClose();
22
+ const reconnectCallback = (context.policy.schedule as sinon.SinonStub).getCall(0).args[0] as ReconnectCallback;
23
+ context.fakeSocket.send.reset();
24
+ (context.policy.reset as sinon.SinonStub).reset();
25
+ reconnectCallback();
26
+
27
+ // The new socket opens
28
+ context.simulateOpen();
29
+ });
30
+
31
+ afterEach(() => sinon.restore());
32
+
33
+ it('should re-send all active subscriptions', () => {
34
+ context.fakeSocket.send.calledOnce.should.be.true;
35
+ const msg = JSON.parse(context.fakeSocket.send.getCall(0).args[0]);
36
+ msg.type.should.equal(HubMessageType.Subscribe);
37
+ msg.queryId.should.equal(queryId);
38
+ });
39
+
40
+ it('should reset the reconnect policy on successful open', () => {
41
+ (context.policy.reset as sinon.SinonStub).calledOnce.should.be.true;
42
+ });
43
+ }));