@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,23 @@
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 { QueryInstanceCache } from '../../QueryInstanceCache';
5
+ import { QueryResultWithState } from '../../QueryResultWithState';
6
+
7
+ describe('when getting the last result for a key that has a stored result', () => {
8
+ let cache: QueryInstanceCache;
9
+ let stored: QueryResultWithState<string[]>;
10
+ let retrieved: QueryResultWithState<string[]> | undefined;
11
+
12
+ beforeEach(() => {
13
+ cache = new QueryInstanceCache();
14
+ cache.getOrCreate('MyQuery::', () => ({}));
15
+
16
+ stored = QueryResultWithState.empty<string[]>([]);
17
+ cache.setLastResult('MyQuery::', stored);
18
+
19
+ retrieved = cache.getLastResult<string[]>('MyQuery::');
20
+ });
21
+
22
+ it('should return the stored result', () => retrieved!.should.equal(stored));
23
+ });
@@ -0,0 +1,29 @@
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 { QueryInstanceCache } from '../../QueryInstanceCache';
5
+
6
+ describe('when getting or creating an entry that already exists', () => {
7
+ let cache: QueryInstanceCache;
8
+ const factoryResult = { id: 42 };
9
+ let firstInstance: object;
10
+ let secondInstance: object;
11
+ let isNewFirst: boolean;
12
+ let isNewSecond: boolean;
13
+
14
+ beforeEach(() => {
15
+ cache = new QueryInstanceCache();
16
+ const first = cache.getOrCreate('MyQuery::', () => factoryResult);
17
+ firstInstance = first.instance;
18
+ isNewFirst = first.isNew;
19
+
20
+ const second = cache.getOrCreate('MyQuery::', () => ({ id: 99 }));
21
+ secondInstance = second.instance;
22
+ isNewSecond = second.isNew;
23
+ });
24
+
25
+ it('should return the same instance', () => secondInstance.should.equal(firstInstance));
26
+ it('should not call factory a second time', () => secondInstance.should.not.deep.equal({ id: 99 }));
27
+ it('should report the first entry as new', () => isNewFirst.should.be.true);
28
+ it('should report the second entry as not new', () => isNewSecond.should.be.false);
29
+ });
@@ -0,0 +1,21 @@
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 { QueryInstanceCache } from '../../QueryInstanceCache';
5
+
6
+ describe('when getting or creating an entry that does not exist yet', () => {
7
+ let cache: QueryInstanceCache;
8
+ let instance: object;
9
+ let isNew: boolean;
10
+
11
+ beforeEach(() => {
12
+ cache = new QueryInstanceCache();
13
+ const result = cache.getOrCreate('MyQuery::', () => ({ id: 1 }));
14
+ instance = result.instance;
15
+ isNew = result.isNew;
16
+ });
17
+
18
+ it('should create a new instance', () => instance.should.deep.equal({ id: 1 }));
19
+ it('should report the entry as new', () => isNew.should.be.true);
20
+ it('should record the entry in the cache', () => cache.has('MyQuery::').should.be.true);
21
+ });
@@ -0,0 +1,21 @@
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 { QueryInstanceCache } from '../../QueryInstanceCache';
5
+
6
+ describe('when releasing a key that does not exist', () => {
7
+ let cache: QueryInstanceCache;
8
+ let threwError: boolean;
9
+
10
+ beforeEach(() => {
11
+ cache = new QueryInstanceCache();
12
+ threwError = false;
13
+ try {
14
+ cache.release('NonExistentKey::');
15
+ } catch {
16
+ threwError = true;
17
+ }
18
+ });
19
+
20
+ it('should not throw', () => threwError.should.be.false);
21
+ });
@@ -0,0 +1,18 @@
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 { QueryInstanceCache } from '../../QueryInstanceCache';
5
+
6
+ describe('when releasing one of two subscribers', () => {
7
+ let cache: QueryInstanceCache;
8
+
9
+ beforeEach(() => {
10
+ cache = new QueryInstanceCache();
11
+ cache.getOrCreate('MyQuery::', () => ({}));
12
+ cache.acquire('MyQuery::');
13
+ cache.acquire('MyQuery::'); // second subscriber
14
+ cache.release('MyQuery::');
15
+ });
16
+
17
+ it('should keep the entry because one subscriber remains', () => cache.has('MyQuery::').should.be.true);
18
+ });
@@ -0,0 +1,23 @@
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 { QueryInstanceCache } from '../../QueryInstanceCache';
5
+
6
+ describe('when releasing the only subscriber', () => {
7
+ let cache: QueryInstanceCache;
8
+
9
+ beforeEach(() => {
10
+ vi.useFakeTimers();
11
+ cache = new QueryInstanceCache();
12
+ cache.getOrCreate('MyQuery::', () => ({}));
13
+ cache.acquire('MyQuery::');
14
+ cache.release('MyQuery::');
15
+ vi.advanceTimersByTime(0);
16
+ });
17
+
18
+ afterEach(() => {
19
+ vi.useRealTimers();
20
+ });
21
+
22
+ it('should evict the entry', () => cache.has('MyQuery::').should.be.false);
23
+ });
@@ -0,0 +1,20 @@
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 { QueryInstanceCache } from '../../QueryInstanceCache';
5
+ import { QueryResultWithState } from '../../QueryResultWithState';
6
+
7
+ describe('when setting the last result', () => {
8
+ let cache: QueryInstanceCache;
9
+ let retrieved: QueryResultWithState<number> | undefined;
10
+ const stored = QueryResultWithState.empty<number>(0);
11
+
12
+ beforeEach(() => {
13
+ cache = new QueryInstanceCache();
14
+ cache.getOrCreate('MyQuery::', () => ({}));
15
+ cache.setLastResult('MyQuery::', stored);
16
+ retrieved = cache.getLastResult<number>('MyQuery::');
17
+ });
18
+
19
+ it('should persist the result so subsequent getLastResult returns it', () => retrieved!.should.equal(stored));
20
+ });
@@ -0,0 +1,33 @@
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 { ReconnectPolicy } from '../../ReconnectPolicy';
6
+
7
+ describe('when canceling a pending reconnect', () => {
8
+ let policy: ReconnectPolicy;
9
+ let clock: sinon.SinonFakeTimers;
10
+ let callbackStub: sinon.SinonStub;
11
+
12
+ beforeEach(() => {
13
+ clock = sinon.useFakeTimers();
14
+ policy = new ReconnectPolicy(100, 500, 500, 10_000);
15
+ callbackStub = sinon.stub();
16
+
17
+ // Schedule a reconnect, then cancel before the timer fires
18
+ policy.schedule(callbackStub, 'url');
19
+ policy.cancel();
20
+ });
21
+
22
+ afterEach(() => {
23
+ clock.restore();
24
+ sinon.restore();
25
+ });
26
+
27
+ it('should not invoke the callback after the timer would have fired', () => {
28
+ clock.tick(60_000);
29
+ callbackStub.callCount.should.equal(0);
30
+ });
31
+
32
+ it('should preserve the attempt counter', () => policy.attempt.should.equal(1));
33
+ });
@@ -0,0 +1,33 @@
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 { ReconnectPolicy } from '../../ReconnectPolicy';
6
+
7
+ describe('when canceling a pending reconnect', () => {
8
+ let policy: ReconnectPolicy;
9
+ let clock: sinon.SinonFakeTimers;
10
+ let callbackStub: sinon.SinonStub;
11
+
12
+ beforeEach(() => {
13
+ clock = sinon.useFakeTimers();
14
+ policy = new ReconnectPolicy(100, 500, 500, 10_000);
15
+ callbackStub = sinon.stub();
16
+
17
+ // Schedule a reconnect, then cancel before the timer fires
18
+ policy.schedule(callbackStub, 'url');
19
+ policy.cancel();
20
+ });
21
+
22
+ afterEach(() => {
23
+ clock.restore();
24
+ sinon.restore();
25
+ });
26
+
27
+ it('should not invoke the callback after the timer would have fired', () => {
28
+ clock.tick(60_000);
29
+ callbackStub.callCount.should.equal(0);
30
+ });
31
+
32
+ it('should preserve the attempt counter', () => policy.attempt.should.equal(1));
33
+ });
@@ -0,0 +1,39 @@
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 { ReconnectPolicy } from '../../ReconnectPolicy';
6
+
7
+ describe('when resetting the reconnect policy', () => {
8
+ let policy: ReconnectPolicy;
9
+ let clock: sinon.SinonFakeTimers;
10
+ let callbackStub: sinon.SinonStub;
11
+
12
+ beforeEach(() => {
13
+ clock = sinon.useFakeTimers();
14
+ policy = new ReconnectPolicy(100, 500, 500, 10_000);
15
+ callbackStub = sinon.stub();
16
+
17
+ // Schedule a reconnect, then reset before the timer fires
18
+ policy.schedule(callbackStub, 'url');
19
+ policy.reset();
20
+ });
21
+
22
+ afterEach(() => {
23
+ clock.restore();
24
+ sinon.restore();
25
+ });
26
+
27
+ it('should reset the attempt counter to 0', () => policy.attempt.should.equal(0));
28
+
29
+ it('should cancel the pending timer so the callback is never invoked', () => {
30
+ clock.tick(60_000);
31
+ callbackStub.callCount.should.equal(0);
32
+ });
33
+
34
+ it('should allow rescheduling from attempt 1 again', () => {
35
+ const rescheduled = policy.schedule(callbackStub, 'url');
36
+ rescheduled.should.be.true;
37
+ policy.attempt.should.equal(1);
38
+ });
39
+ });
@@ -0,0 +1,44 @@
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 { ReconnectPolicy } from '../../../ReconnectPolicy';
6
+
7
+ describe('when scheduling and delay is capped at max', () => {
8
+ let policy: ReconnectPolicy;
9
+ let clock: sinon.SinonFakeTimers;
10
+ let callbackStub: sinon.SinonStub;
11
+
12
+ beforeEach(() => {
13
+ clock = sinon.useFakeTimers();
14
+ // Set maxDelayMs to a low value to make the cap observable
15
+ policy = new ReconnectPolicy(100, 500, 500, 2_000);
16
+ callbackStub = sinon.stub();
17
+
18
+ // Exhaust enough attempts to hit the cap: min(500 + 500*n, 2000) hits cap at n=3
19
+ policy.schedule(callbackStub, 'url'); // attempt 1, delay=1000
20
+ clock.tick(1000);
21
+ policy.schedule(callbackStub, 'url'); // attempt 2, delay=1500
22
+ clock.tick(1500);
23
+ policy.schedule(callbackStub, 'url'); // attempt 3, delay=2000 (at cap)
24
+ clock.tick(2000);
25
+ callbackStub.reset();
26
+
27
+ policy.schedule(callbackStub, 'url'); // attempt 4, delay should still be capped at 2000
28
+ });
29
+
30
+ afterEach(() => {
31
+ clock.restore();
32
+ sinon.restore();
33
+ });
34
+
35
+ it('should not fire before the cap delay', () => {
36
+ clock.tick(1999);
37
+ callbackStub.callCount.should.equal(0);
38
+ });
39
+
40
+ it('should fire exactly at the cap delay', () => {
41
+ clock.tick(2000);
42
+ callbackStub.calledOnce.should.be.true;
43
+ });
44
+ });
@@ -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 { ReconnectPolicy } from '../../../ReconnectPolicy';
6
+
7
+ describe('when scheduling and max attempts not reached', () => {
8
+ let policy: ReconnectPolicy;
9
+ let clock: sinon.SinonFakeTimers;
10
+ let callbackStub: sinon.SinonStub;
11
+ let scheduled: boolean;
12
+
13
+ beforeEach(() => {
14
+ clock = sinon.useFakeTimers();
15
+ policy = new ReconnectPolicy(100, 500, 500, 10_000);
16
+ callbackStub = sinon.stub();
17
+
18
+ scheduled = policy.schedule(callbackStub, 'test-label');
19
+ });
20
+
21
+ afterEach(() => {
22
+ clock.restore();
23
+ sinon.restore();
24
+ });
25
+
26
+ it('should return true', () => scheduled.should.be.true);
27
+ it('should increment the attempt counter to 1', () => policy.attempt.should.equal(1));
28
+ it('should not invoke the callback immediately', () => callbackStub.callCount.should.equal(0));
29
+
30
+ describe('when the delay elapses', () => {
31
+ beforeEach(() => {
32
+ // Attempt 1: delay = min(500 + 500*1, 10_000) = 1000ms
33
+ clock.tick(1000);
34
+ });
35
+
36
+ it('should invoke the callback once', () => callbackStub.calledOnce.should.be.true);
37
+ });
38
+ });
@@ -0,0 +1,39 @@
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 { ReconnectPolicy } from '../../../ReconnectPolicy';
6
+
7
+ describe('when scheduling and max attempts reached', () => {
8
+ let policy: ReconnectPolicy;
9
+ let clock: sinon.SinonFakeTimers;
10
+ let callbackStub: sinon.SinonStub;
11
+ let scheduled: boolean;
12
+
13
+ beforeEach(() => {
14
+ clock = sinon.useFakeTimers();
15
+ // Use maxAttempts=2 so we can exhaust quickly
16
+ policy = new ReconnectPolicy(2, 500, 500, 10_000);
17
+ callbackStub = sinon.stub();
18
+
19
+ policy.schedule(callbackStub, 'url'); // attempt 1
20
+ clock.tick(1000);
21
+ policy.schedule(callbackStub, 'url'); // attempt 2
22
+ clock.tick(1500);
23
+ callbackStub.reset();
24
+
25
+ // This is the 3rd call — attempt >= maxAttempts (2), should not schedule
26
+ scheduled = policy.schedule(callbackStub, 'url');
27
+ });
28
+
29
+ afterEach(() => {
30
+ clock.restore();
31
+ sinon.restore();
32
+ });
33
+
34
+ it('should return false', () => scheduled.should.be.false);
35
+ it('should not invoke the callback', () => {
36
+ clock.tick(60_000);
37
+ callbackStub.callCount.should.equal(0);
38
+ });
39
+ });
@@ -0,0 +1,85 @@
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 { ServerSentEventHubConnection } from '../../ServerSentEventHubConnection';
6
+ import { IReconnectPolicy, ReconnectCallback } from '../../IReconnectPolicy';
7
+
8
+ /* eslint-disable @typescript-eslint/no-explicit-any */
9
+
10
+ export class a_server_sent_event_hub_connection {
11
+ connection!: ServerSentEventHubConnection;
12
+ fakeEventSource!: {
13
+ onopen: (() => void) | null;
14
+ onmessage: ((event: MessageEvent) => void) | null;
15
+ onerror: (() => void) | null;
16
+ close: sinon.SinonStub;
17
+ readyState: number;
18
+ };
19
+ policy!: sinon.SinonStubbedInstance<IReconnectPolicy>;
20
+ fetchStub!: sinon.SinonStub;
21
+
22
+ constructor() {
23
+ this.setup();
24
+ }
25
+
26
+ /**
27
+ * Re-initializes stubs and creates a fresh {@link ServerSentEventHubConnection}.
28
+ * Call this at the start of each {@code beforeEach} to prevent stub-call
29
+ * accumulation across tests sharing the same context instance.
30
+ */
31
+ setup(): void {
32
+ this.fakeEventSource = {
33
+ onopen: null,
34
+ onmessage: null,
35
+ onerror: null,
36
+ close: sinon.stub(),
37
+ readyState: 0, // CONNECTING
38
+ };
39
+
40
+ // eslint-disable-next-line @typescript-eslint/no-this-alias
41
+ const self = this;
42
+ const FakeEventSourceClass = function (this: any) {
43
+ Object.assign(self.fakeEventSource, { onopen: null, onmessage: null, onerror: null });
44
+ self.fakeEventSource.readyState = 0; // CONNECTING
45
+ return self.fakeEventSource;
46
+ };
47
+ (globalThis as any)['EventSource'] = FakeEventSourceClass;
48
+ (globalThis as any)['EventSource'].CONNECTING = 0;
49
+ (globalThis as any)['EventSource'].OPEN = 1;
50
+ (globalThis as any)['EventSource'].CLOSED = 2;
51
+
52
+ this.fetchStub = sinon.stub().resolves({ ok: true });
53
+ (globalThis as any)['fetch'] = this.fetchStub;
54
+
55
+ this.policy = {
56
+ attempt: 0,
57
+ schedule: sinon.stub<[ReconnectCallback, string], boolean>().returns(true),
58
+ reset: sinon.stub(),
59
+ cancel: sinon.stub(),
60
+ };
61
+
62
+ this.connection = new ServerSentEventHubConnection(
63
+ 'http://localhost/.cratis/queries/sse',
64
+ 'http://localhost/.cratis/queries/sse/subscribe',
65
+ 'http://localhost/.cratis/queries/sse/unsubscribe',
66
+ '',
67
+ undefined,
68
+ undefined,
69
+ this.policy
70
+ );
71
+ }
72
+
73
+ simulateOpen(): void {
74
+ this.fakeEventSource.readyState = 1; // OPEN
75
+ this.fakeEventSource.onopen?.();
76
+ }
77
+
78
+ simulateMessage(payload: object): void {
79
+ this.fakeEventSource.onmessage?.({ data: JSON.stringify(payload) } as MessageEvent);
80
+ }
81
+
82
+ simulateError(): void {
83
+ this.fakeEventSource.onerror?.();
84
+ }
85
+ }
@@ -0,0 +1,46 @@
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
+
8
+ const CONNECT_TIMEOUT_MS = 500;
9
+
10
+ describe('when the connect timeout elapses before a Connected message arrives', given(a_server_sent_event_hub_connection, context => {
11
+ let clock: sinon.SinonFakeTimers;
12
+
13
+ beforeEach(() => {
14
+ clock = sinon.useFakeTimers();
15
+ context.setup();
16
+
17
+ // eslint-disable-next-line @typescript-eslint/no-require-imports, @typescript-eslint/no-var-requires
18
+ const { ServerSentEventHubConnection } = require('../../ServerSentEventHubConnection');
19
+ context.connection = new ServerSentEventHubConnection(
20
+ 'http://localhost/.cratis/queries/sse',
21
+ 'http://localhost/.cratis/queries/sse/subscribe',
22
+ 'http://localhost/.cratis/queries/sse/unsubscribe',
23
+ '',
24
+ 30000,
25
+ CONNECT_TIMEOUT_MS,
26
+ context.policy
27
+ );
28
+
29
+ context.connection.subscribe('q1', { queryName: 'MyQuery' }, sinon.stub());
30
+
31
+ // Open the EventSource but never deliver a Connected message.
32
+ context.simulateOpen();
33
+
34
+ // Advance past the connect timeout.
35
+ clock.tick(CONNECT_TIMEOUT_MS + 1);
36
+ });
37
+
38
+ afterEach(() => {
39
+ clock.restore();
40
+ sinon.restore();
41
+ });
42
+
43
+ it('should schedule a reconnect via the policy', () => {
44
+ (context.policy.schedule as sinon.SinonStub).calledOnce.should.be.true;
45
+ });
46
+ }));
@@ -0,0 +1,34 @@
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 disposing the hub connection', given(a_server_sent_event_hub_connection, context => {
10
+ beforeEach(() => {
11
+ context.setup();
12
+ context.connection.subscribe('q1', { queryName: 'MyQuery' }, sinon.stub());
13
+ context.simulateOpen();
14
+ context.simulateMessage({ type: HubMessageType.Connected, payload: 'conn-1' });
15
+ context.connection.dispose();
16
+ });
17
+
18
+ afterEach(() => sinon.restore());
19
+
20
+ it('should close the EventSource', () => context.fakeEventSource.close.calledOnce.should.be.true);
21
+ it('should cancel the reconnect policy', () => (context.policy.cancel as sinon.SinonStub).calledOnce.should.be.true);
22
+ it('should report zero active subscriptions', () => context.connection.queryCount.should.equal(0));
23
+
24
+ describe('when an error event fires after dispose', () => {
25
+ beforeEach(() => {
26
+ (context.policy.schedule as sinon.SinonStub).reset();
27
+ context.simulateError();
28
+ });
29
+
30
+ it('should not schedule a reconnect', () => {
31
+ (context.policy.schedule as sinon.SinonStub).callCount.should.equal(0);
32
+ });
33
+ });
34
+ }));
@@ -0,0 +1,48 @@
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
+ const KEEP_ALIVE_MS = 500;
10
+
11
+ describe('when keep-alive interval elapses without any server message', given(a_server_sent_event_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 { ServerSentEventHubConnection } = require('../../ServerSentEventHubConnection');
20
+ context.connection = new ServerSentEventHubConnection(
21
+ 'http://localhost/.cratis/queries/sse',
22
+ 'http://localhost/.cratis/queries/sse/subscribe',
23
+ 'http://localhost/.cratis/queries/sse/unsubscribe',
24
+ '',
25
+ KEEP_ALIVE_MS,
26
+ 15000,
27
+ context.policy
28
+ );
29
+
30
+ context.connection.subscribe('q1', { queryName: 'MyQuery' }, sinon.stub());
31
+ context.simulateOpen();
32
+
33
+ // Deliver Connected so the connection is fully established.
34
+ context.simulateMessage({ type: HubMessageType.Connected, payload: 'conn-123' });
35
+
36
+ // Advance past the keep-alive interval without any further messages.
37
+ clock.tick(KEEP_ALIVE_MS + 1);
38
+ });
39
+
40
+ afterEach(() => {
41
+ clock.restore();
42
+ sinon.restore();
43
+ });
44
+
45
+ it('should schedule a reconnect via the policy', () => {
46
+ (context.policy.schedule as sinon.SinonStub).calledOnce.should.be.true;
47
+ });
48
+ }));