mediasoup 3.19.21 → 3.20.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 (649) hide show
  1. package/node/lib/ActiveSpeakerObserver.js +34 -1
  2. package/node/lib/AudioLevelObserver.js +35 -2
  3. package/node/lib/Channel.d.ts.map +1 -1
  4. package/node/lib/Channel.js +37 -5
  5. package/node/lib/Consumer.js +39 -6
  6. package/node/lib/DataConsumer.d.ts.map +1 -1
  7. package/node/lib/DataConsumer.js +39 -5
  8. package/node/lib/DataConsumerTypes.d.ts +1 -0
  9. package/node/lib/DataConsumerTypes.d.ts.map +1 -1
  10. package/node/lib/DataProducer.js +37 -4
  11. package/node/lib/DirectTransport.js +37 -4
  12. package/node/lib/DirectTransportTypes.d.ts +7 -2
  13. package/node/lib/DirectTransportTypes.d.ts.map +1 -1
  14. package/node/lib/Logger.js +4 -1
  15. package/node/lib/PipeTransport.d.ts +3 -1
  16. package/node/lib/PipeTransport.d.ts.map +1 -1
  17. package/node/lib/PipeTransport.js +56 -5
  18. package/node/lib/PipeTransportTypes.d.ts +28 -8
  19. package/node/lib/PipeTransportTypes.d.ts.map +1 -1
  20. package/node/lib/PlainTransport.d.ts +3 -1
  21. package/node/lib/PlainTransport.d.ts.map +1 -1
  22. package/node/lib/PlainTransport.js +54 -3
  23. package/node/lib/PlainTransportTypes.d.ts +27 -7
  24. package/node/lib/PlainTransportTypes.d.ts.map +1 -1
  25. package/node/lib/Producer.js +40 -7
  26. package/node/lib/Router.d.ts +5 -5
  27. package/node/lib/Router.d.ts.map +1 -1
  28. package/node/lib/Router.js +81 -36
  29. package/node/lib/RouterTypes.d.ts +25 -3
  30. package/node/lib/RouterTypes.d.ts.map +1 -1
  31. package/node/lib/RtpObserver.js +36 -3
  32. package/node/lib/Transport.d.ts +3 -1
  33. package/node/lib/Transport.d.ts.map +1 -1
  34. package/node/lib/Transport.js +74 -22
  35. package/node/lib/TransportTypes.d.ts +2 -1
  36. package/node/lib/TransportTypes.d.ts.map +1 -1
  37. package/node/lib/WebRtcServer.js +36 -3
  38. package/node/lib/WebRtcTransport.d.ts +3 -1
  39. package/node/lib/WebRtcTransport.d.ts.map +1 -1
  40. package/node/lib/WebRtcTransport.js +55 -4
  41. package/node/lib/WebRtcTransportTypes.d.ts +27 -7
  42. package/node/lib/WebRtcTransportTypes.d.ts.map +1 -1
  43. package/node/lib/Worker.d.ts +2 -1
  44. package/node/lib/Worker.d.ts.map +1 -1
  45. package/node/lib/Worker.js +71 -25
  46. package/node/lib/WorkerTypes.d.ts +0 -4
  47. package/node/lib/WorkerTypes.d.ts.map +1 -1
  48. package/node/lib/enhancedEvents.d.ts +2 -2
  49. package/node/lib/enhancedEvents.d.ts.map +1 -1
  50. package/node/lib/enhancedEvents.js +0 -2
  51. package/node/lib/fbs/active-speaker-observer/active-speaker-observer-options.js +34 -1
  52. package/node/lib/fbs/active-speaker-observer/dominant-speaker-notification.js +34 -1
  53. package/node/lib/fbs/audio-level-observer/audio-level-observer-options.js +34 -1
  54. package/node/lib/fbs/audio-level-observer/volume.js +34 -1
  55. package/node/lib/fbs/audio-level-observer/volumes-notification.js +34 -1
  56. package/node/lib/fbs/common/string-string-array.js +34 -1
  57. package/node/lib/fbs/common/string-string.js +34 -1
  58. package/node/lib/fbs/common/string-uint8.js +34 -1
  59. package/node/lib/fbs/common/uint16-string.js +34 -1
  60. package/node/lib/fbs/common/uint32-string.js +34 -1
  61. package/node/lib/fbs/consumer/base-consumer-dump.js +34 -1
  62. package/node/lib/fbs/consumer/consumer-dump.js +34 -1
  63. package/node/lib/fbs/consumer/consumer-layers.js +34 -1
  64. package/node/lib/fbs/consumer/consumer-score.js +34 -1
  65. package/node/lib/fbs/consumer/dump-response.js +34 -1
  66. package/node/lib/fbs/consumer/enable-trace-event-request.js +34 -1
  67. package/node/lib/fbs/consumer/fir-trace-info.js +34 -1
  68. package/node/lib/fbs/consumer/get-stats-response.js +34 -1
  69. package/node/lib/fbs/consumer/key-frame-trace-info.js +34 -1
  70. package/node/lib/fbs/consumer/layers-change-notification.js +34 -1
  71. package/node/lib/fbs/consumer/pli-trace-info.js +34 -1
  72. package/node/lib/fbs/consumer/rtp-notification.js +34 -1
  73. package/node/lib/fbs/consumer/rtp-trace-info.js +34 -1
  74. package/node/lib/fbs/consumer/score-notification.js +34 -1
  75. package/node/lib/fbs/consumer/set-preferred-layers-request.js +34 -1
  76. package/node/lib/fbs/consumer/set-preferred-layers-response.js +34 -1
  77. package/node/lib/fbs/consumer/set-priority-request.js +34 -1
  78. package/node/lib/fbs/consumer/set-priority-response.js +34 -1
  79. package/node/lib/fbs/consumer/trace-notification.js +34 -1
  80. package/node/lib/fbs/data-consumer/add-subchannel-request.js +34 -1
  81. package/node/lib/fbs/data-consumer/add-subchannel-response.js +34 -1
  82. package/node/lib/fbs/data-consumer/buffered-amount-low-notification.js +34 -1
  83. package/node/lib/fbs/data-consumer/dump-response.d.ts +5 -2
  84. package/node/lib/fbs/data-consumer/dump-response.d.ts.map +1 -1
  85. package/node/lib/fbs/data-consumer/dump-response.js +60 -16
  86. package/node/lib/fbs/data-consumer/get-buffered-amount-response.js +34 -1
  87. package/node/lib/fbs/data-consumer/get-stats-response.js +34 -1
  88. package/node/lib/fbs/data-consumer/message-notification.js +34 -1
  89. package/node/lib/fbs/data-consumer/remove-subchannel-request.js +34 -1
  90. package/node/lib/fbs/data-consumer/remove-subchannel-response.js +34 -1
  91. package/node/lib/fbs/data-consumer/send-request.js +34 -1
  92. package/node/lib/fbs/data-consumer/set-buffered-amount-low-threshold-request.js +34 -1
  93. package/node/lib/fbs/data-consumer/set-subchannels-request.js +34 -1
  94. package/node/lib/fbs/data-consumer/set-subchannels-response.js +34 -1
  95. package/node/lib/fbs/data-consumer/type.d.ts +5 -0
  96. package/node/lib/fbs/data-consumer/type.d.ts.map +1 -0
  97. package/node/lib/fbs/data-consumer/type.js +10 -0
  98. package/node/lib/fbs/data-consumer.d.ts +1 -0
  99. package/node/lib/fbs/data-consumer.d.ts.map +1 -1
  100. package/node/lib/fbs/data-consumer.js +3 -1
  101. package/node/lib/fbs/data-producer/dump-response.js +34 -1
  102. package/node/lib/fbs/data-producer/get-stats-response.js +34 -1
  103. package/node/lib/fbs/data-producer/send-notification.js +34 -1
  104. package/node/lib/fbs/direct-transport/direct-transport-options.js +34 -1
  105. package/node/lib/fbs/direct-transport/dump-response.js +34 -1
  106. package/node/lib/fbs/direct-transport/get-stats-response.js +34 -1
  107. package/node/lib/fbs/direct-transport/rtcp-notification.js +34 -1
  108. package/node/lib/fbs/lib-uring/dump.js +34 -1
  109. package/node/lib/fbs/log/log.js +34 -1
  110. package/node/lib/fbs/message/message.js +34 -1
  111. package/node/lib/fbs/notification/body.d.ts +24 -22
  112. package/node/lib/fbs/notification/body.d.ts.map +1 -1
  113. package/node/lib/fbs/notification/body.js +24 -20
  114. package/node/lib/fbs/notification/event.d.ts +27 -26
  115. package/node/lib/fbs/notification/event.d.ts.map +1 -1
  116. package/node/lib/fbs/notification/event.js +27 -26
  117. package/node/lib/fbs/notification/notification.d.ts +3 -2
  118. package/node/lib/fbs/notification/notification.d.ts.map +1 -1
  119. package/node/lib/fbs/notification/notification.js +34 -1
  120. package/node/lib/fbs/pipe-transport/connect-request.js +34 -1
  121. package/node/lib/fbs/pipe-transport/connect-response.js +34 -1
  122. package/node/lib/fbs/pipe-transport/dump-response.js +34 -1
  123. package/node/lib/fbs/pipe-transport/get-stats-response.js +34 -1
  124. package/node/lib/fbs/pipe-transport/pipe-transport-options.js +34 -1
  125. package/node/lib/fbs/plain-transport/connect-request.js +34 -1
  126. package/node/lib/fbs/plain-transport/connect-response.js +34 -1
  127. package/node/lib/fbs/plain-transport/dump-response.js +34 -1
  128. package/node/lib/fbs/plain-transport/get-stats-response.js +34 -1
  129. package/node/lib/fbs/plain-transport/plain-transport-options.js +34 -1
  130. package/node/lib/fbs/plain-transport/rtcp-tuple-notification.js +34 -1
  131. package/node/lib/fbs/plain-transport/tuple-notification.js +34 -1
  132. package/node/lib/fbs/producer/dump-response.js +34 -1
  133. package/node/lib/fbs/producer/enable-trace-event-request.js +34 -1
  134. package/node/lib/fbs/producer/fir-trace-info.js +34 -1
  135. package/node/lib/fbs/producer/get-stats-response.js +34 -1
  136. package/node/lib/fbs/producer/key-frame-trace-info.js +34 -1
  137. package/node/lib/fbs/producer/pli-trace-info.js +34 -1
  138. package/node/lib/fbs/producer/rtp-trace-info.js +34 -1
  139. package/node/lib/fbs/producer/score-notification.js +34 -1
  140. package/node/lib/fbs/producer/score.js +34 -1
  141. package/node/lib/fbs/producer/send-notification.js +34 -1
  142. package/node/lib/fbs/producer/sr-trace-info.js +34 -1
  143. package/node/lib/fbs/producer/trace-notification.js +34 -1
  144. package/node/lib/fbs/producer/video-orientation-change-notification.js +34 -1
  145. package/node/lib/fbs/request/request.js +34 -1
  146. package/node/lib/fbs/response/response.js +34 -1
  147. package/node/lib/fbs/router/close-rtp-observer-request.js +34 -1
  148. package/node/lib/fbs/router/close-transport-request.js +34 -1
  149. package/node/lib/fbs/router/create-active-speaker-observer-request.js +34 -1
  150. package/node/lib/fbs/router/create-audio-level-observer-request.js +34 -1
  151. package/node/lib/fbs/router/create-direct-transport-request.js +34 -1
  152. package/node/lib/fbs/router/create-pipe-transport-request.js +34 -1
  153. package/node/lib/fbs/router/create-plain-transport-request.js +34 -1
  154. package/node/lib/fbs/router/create-web-rtc-transport-request.js +34 -1
  155. package/node/lib/fbs/router/dump-response.js +34 -1
  156. package/node/lib/fbs/rtp-observer/add-producer-request.js +34 -1
  157. package/node/lib/fbs/rtp-observer/remove-producer-request.js +34 -1
  158. package/node/lib/fbs/rtp-packet/dump.js +34 -1
  159. package/node/lib/fbs/rtp-parameters/boolean.js +34 -1
  160. package/node/lib/fbs/rtp-parameters/codec-mapping.js +34 -1
  161. package/node/lib/fbs/rtp-parameters/double.js +34 -1
  162. package/node/lib/fbs/rtp-parameters/encoding-mapping.js +34 -1
  163. package/node/lib/fbs/rtp-parameters/integer32-array.js +34 -1
  164. package/node/lib/fbs/rtp-parameters/integer32.js +34 -1
  165. package/node/lib/fbs/rtp-parameters/parameter.js +34 -1
  166. package/node/lib/fbs/rtp-parameters/rtcp-feedback.js +34 -1
  167. package/node/lib/fbs/rtp-parameters/rtcp-parameters.js +34 -1
  168. package/node/lib/fbs/rtp-parameters/rtp-codec-parameters.js +34 -1
  169. package/node/lib/fbs/rtp-parameters/rtp-encoding-parameters.js +34 -1
  170. package/node/lib/fbs/rtp-parameters/rtp-header-extension-parameters.js +34 -1
  171. package/node/lib/fbs/rtp-parameters/rtp-mapping.js +34 -1
  172. package/node/lib/fbs/rtp-parameters/rtp-parameters.js +34 -1
  173. package/node/lib/fbs/rtp-parameters/rtx.js +34 -1
  174. package/node/lib/fbs/rtp-parameters/string.js +34 -1
  175. package/node/lib/fbs/rtp-stream/base-stats.js +34 -1
  176. package/node/lib/fbs/rtp-stream/bitrate-by-layer.js +34 -1
  177. package/node/lib/fbs/rtp-stream/dump.js +34 -1
  178. package/node/lib/fbs/rtp-stream/params.js +34 -1
  179. package/node/lib/fbs/rtp-stream/recv-stats.js +34 -1
  180. package/node/lib/fbs/rtp-stream/send-stats.js +34 -1
  181. package/node/lib/fbs/rtp-stream/stats.js +34 -1
  182. package/node/lib/fbs/rtx-stream/params.js +34 -1
  183. package/node/lib/fbs/rtx-stream/rtx-dump.js +34 -1
  184. package/node/lib/fbs/sctp-association/sctp-negotiated-capabilities.d.ts +24 -0
  185. package/node/lib/fbs/sctp-association/sctp-negotiated-capabilities.d.ts.map +1 -0
  186. package/node/lib/fbs/sctp-association/sctp-negotiated-capabilities.js +102 -0
  187. package/node/lib/fbs/sctp-association.d.ts +1 -0
  188. package/node/lib/fbs/sctp-association.d.ts.map +1 -1
  189. package/node/lib/fbs/sctp-association.js +4 -1
  190. package/node/lib/fbs/sctp-parameters/num-sctp-streams.js +34 -1
  191. package/node/lib/fbs/sctp-parameters/sctp-parameters.d.ts +14 -14
  192. package/node/lib/fbs/sctp-parameters/sctp-parameters.d.ts.map +1 -1
  193. package/node/lib/fbs/sctp-parameters/sctp-parameters.js +73 -40
  194. package/node/lib/fbs/sctp-parameters/sctp-stream-parameters.js +34 -1
  195. package/node/lib/fbs/sctp-parameters.d.ts +0 -1
  196. package/node/lib/fbs/sctp-parameters.d.ts.map +1 -1
  197. package/node/lib/fbs/sctp-parameters.js +1 -4
  198. package/node/lib/fbs/srtp-parameters/srtp-parameters.js +34 -1
  199. package/node/lib/fbs/transport/bwe-trace-info.js +34 -1
  200. package/node/lib/fbs/transport/close-consumer-request.js +34 -1
  201. package/node/lib/fbs/transport/close-data-consumer-request.js +34 -1
  202. package/node/lib/fbs/transport/close-data-producer-request.js +34 -1
  203. package/node/lib/fbs/transport/close-producer-request.js +34 -1
  204. package/node/lib/fbs/transport/consume-data-request.d.ts +1 -1
  205. package/node/lib/fbs/transport/consume-data-request.js +35 -2
  206. package/node/lib/fbs/transport/consume-request.js +34 -1
  207. package/node/lib/fbs/transport/consume-response.js +34 -1
  208. package/node/lib/fbs/transport/dump.d.ts +7 -4
  209. package/node/lib/fbs/transport/dump.d.ts.map +1 -1
  210. package/node/lib/fbs/transport/dump.js +66 -22
  211. package/node/lib/fbs/transport/enable-trace-event-request.js +34 -1
  212. package/node/lib/fbs/transport/listen-info.js +34 -1
  213. package/node/lib/fbs/transport/options.d.ts +14 -14
  214. package/node/lib/fbs/transport/options.d.ts.map +1 -1
  215. package/node/lib/fbs/transport/options.js +92 -51
  216. package/node/lib/fbs/transport/port-range.js +34 -1
  217. package/node/lib/fbs/transport/produce-data-request.js +34 -1
  218. package/node/lib/fbs/transport/produce-request.js +34 -1
  219. package/node/lib/fbs/transport/produce-response.js +34 -1
  220. package/node/lib/fbs/transport/recv-rtp-header-extensions.js +34 -1
  221. package/node/lib/fbs/transport/restart-ice-response.js +34 -1
  222. package/node/lib/fbs/transport/rtp-listener.js +34 -1
  223. package/node/lib/fbs/transport/sctp-listener.js +34 -1
  224. package/node/lib/fbs/transport/sctp-negotiated-capabilities-notification.d.ts +22 -0
  225. package/node/lib/fbs/transport/sctp-negotiated-capabilities-notification.d.ts.map +1 -0
  226. package/node/lib/fbs/transport/sctp-negotiated-capabilities-notification.js +93 -0
  227. package/node/lib/fbs/transport/sctp-state-change-notification.js +34 -1
  228. package/node/lib/fbs/transport/send-rtcp-notification.js +34 -1
  229. package/node/lib/fbs/transport/set-max-incoming-bitrate-request.js +34 -1
  230. package/node/lib/fbs/transport/set-max-outgoing-bitrate-request.js +34 -1
  231. package/node/lib/fbs/transport/set-min-outgoing-bitrate-request.js +34 -1
  232. package/node/lib/fbs/transport/socket-flags.js +34 -1
  233. package/node/lib/fbs/transport/stats.js +34 -1
  234. package/node/lib/fbs/transport/trace-notification.js +34 -1
  235. package/node/lib/fbs/transport/tuple.js +34 -1
  236. package/node/lib/fbs/transport.d.ts +1 -0
  237. package/node/lib/fbs/transport.d.ts.map +1 -1
  238. package/node/lib/fbs/transport.js +5 -2
  239. package/node/lib/fbs/web-rtc-server/dump-response.js +34 -1
  240. package/node/lib/fbs/web-rtc-server/ice-user-name-fragment.js +34 -1
  241. package/node/lib/fbs/web-rtc-server/ip-port.js +34 -1
  242. package/node/lib/fbs/web-rtc-server/tuple-hash.js +34 -1
  243. package/node/lib/fbs/web-rtc-transport/connect-request.js +34 -1
  244. package/node/lib/fbs/web-rtc-transport/connect-response.js +34 -1
  245. package/node/lib/fbs/web-rtc-transport/dtls-parameters.js +34 -1
  246. package/node/lib/fbs/web-rtc-transport/dtls-state-change-notification.js +34 -1
  247. package/node/lib/fbs/web-rtc-transport/dump-response.js +34 -1
  248. package/node/lib/fbs/web-rtc-transport/fingerprint.js +34 -1
  249. package/node/lib/fbs/web-rtc-transport/get-stats-response.js +34 -1
  250. package/node/lib/fbs/web-rtc-transport/ice-candidate.js +34 -1
  251. package/node/lib/fbs/web-rtc-transport/ice-parameters.js +34 -1
  252. package/node/lib/fbs/web-rtc-transport/ice-selected-tuple-change-notification.js +34 -1
  253. package/node/lib/fbs/web-rtc-transport/ice-state-change-notification.js +34 -1
  254. package/node/lib/fbs/web-rtc-transport/listen-individual.js +34 -1
  255. package/node/lib/fbs/web-rtc-transport/listen-server.js +34 -1
  256. package/node/lib/fbs/web-rtc-transport/web-rtc-transport-options.js +34 -1
  257. package/node/lib/fbs/worker/channel-message-handlers.js +34 -1
  258. package/node/lib/fbs/worker/close-router-request.js +34 -1
  259. package/node/lib/fbs/worker/close-web-rtc-server-request.js +34 -1
  260. package/node/lib/fbs/worker/create-router-request.js +34 -1
  261. package/node/lib/fbs/worker/create-web-rtc-server-request.js +34 -1
  262. package/node/lib/fbs/worker/dump-response.js +34 -1
  263. package/node/lib/fbs/worker/resource-usage-response.js +34 -1
  264. package/node/lib/fbs/worker/update-settings-request.js +34 -1
  265. package/node/lib/index.d.ts +1 -1
  266. package/node/lib/index.d.ts.map +1 -1
  267. package/node/lib/index.js +37 -5
  268. package/node/lib/ortc.js +36 -3
  269. package/node/lib/rtpParametersFbsUtils.js +34 -1
  270. package/node/lib/rtpStreamStatsFbsUtils.js +35 -2
  271. package/node/lib/sctpParametersFbsUtils.d.ts +2 -2
  272. package/node/lib/sctpParametersFbsUtils.d.ts.map +1 -1
  273. package/node/lib/sctpParametersFbsUtils.js +44 -7
  274. package/node/lib/sctpParametersTypes.d.ts +10 -46
  275. package/node/lib/sctpParametersTypes.d.ts.map +1 -1
  276. package/node/lib/srtpParametersFbsUtils.js +34 -1
  277. package/node/lib/test/test-ActiveSpeakerObserver.js +35 -2
  278. package/node/lib/test/test-AudioLevelObserver.js +35 -2
  279. package/node/lib/test/test-Consumer.js +37 -4
  280. package/node/lib/test/test-DataConsumer.js +35 -2
  281. package/node/lib/test/test-DataProducer.js +35 -2
  282. package/node/lib/test/test-DirectTransport.js +36 -8
  283. package/node/lib/test/test-PipeTransport.js +35 -2
  284. package/node/lib/test/test-PlainTransport.js +45 -12
  285. package/node/lib/test/test-Producer.js +37 -4
  286. package/node/lib/test/test-Router.js +35 -2
  287. package/node/lib/test/test-WebRtcServer.js +34 -1
  288. package/node/lib/test/test-WebRtcTransport.js +51 -22
  289. package/node/lib/test/test-Worker.js +37 -4
  290. package/node/lib/test/test-mediasoup.js +36 -3
  291. package/node/lib/test/test-multiopus.js +35 -2
  292. package/node/lib/test/test-ortc.js +34 -1
  293. package/node/lib/test/test-werift-sctp.js +39 -5
  294. package/npm-scripts.mjs +2 -2
  295. package/package.json +13 -11
  296. package/worker/deps/libwebrtc/LICENSE +5 -0
  297. package/worker/deps/libwebrtc/README.md +3 -3
  298. package/worker/deps/libwebrtc/libwebrtc/mediasoup_helpers.h +13 -10
  299. package/worker/fbs/dataConsumer.fbs +7 -2
  300. package/worker/fbs/dataProducer.fbs +1 -0
  301. package/worker/fbs/notification.fbs +2 -0
  302. package/worker/fbs/sctpAssociation.fbs +4 -0
  303. package/worker/fbs/sctpParameters.fbs +5 -12
  304. package/worker/fbs/transport.fbs +12 -8
  305. package/worker/fuzzer/src/RTC/FuzzerDtlsTransport.cpp +13 -3
  306. package/worker/fuzzer/src/RTC/FuzzerRateCalculator.cpp +2 -2
  307. package/worker/fuzzer/src/RTC/FuzzerSeqManager.cpp +1 -1
  308. package/worker/fuzzer/src/RTC/FuzzerTrendCalculator.cpp +5 -5
  309. package/worker/fuzzer/src/RTC/ICE/FuzzerStunPacket.cpp +9 -6
  310. package/worker/fuzzer/src/RTC/RTP/FuzzerRetransmissionBuffer.cpp +1 -1
  311. package/worker/fuzzer/src/RTC/RTP/FuzzerRtpStreamSend.cpp +14 -2
  312. package/worker/fuzzer/src/RTC/SCTP/association/FuzzerStateCookie.cpp +1 -1
  313. package/worker/fuzzer/src/RTC/SCTP/packet/FuzzerPacket.cpp +5 -2
  314. package/worker/fuzzer/src/fuzzer.cpp +3 -10
  315. package/worker/include/Channel/ChannelMessageRegistrator.hpp +39 -0
  316. package/worker/include/Channel/ChannelMessageRegistratorInterface.hpp +32 -0
  317. package/worker/include/Channel/ChannelRequest.hpp +1 -1
  318. package/worker/include/Channel/ChannelSocket.hpp +1 -1
  319. package/worker/include/DepLibUV.hpp +1 -1
  320. package/worker/include/DepLibUring.hpp +3 -3
  321. package/worker/include/Logger.hpp +4 -4
  322. package/worker/include/MediaSoupErrors.hpp +1 -1
  323. package/worker/include/RTC/ActiveSpeakerObserver.hpp +11 -9
  324. package/worker/include/RTC/AudioLevelObserver.hpp +7 -7
  325. package/worker/include/RTC/Consumer.hpp +3 -3
  326. package/worker/include/RTC/DataConsumer.hpp +13 -17
  327. package/worker/include/RTC/DataProducer.hpp +6 -9
  328. package/worker/include/RTC/DirectTransport.hpp +4 -6
  329. package/worker/include/RTC/DtlsTransport.hpp +13 -11
  330. package/worker/include/RTC/ICE/IceServer.hpp +8 -5
  331. package/worker/include/RTC/ICE/StunPacket.hpp +1 -1
  332. package/worker/include/RTC/KeyFrameRequestManager.hpp +15 -12
  333. package/worker/include/RTC/NackGenerator.hpp +8 -6
  334. package/worker/include/RTC/PipeConsumer.hpp +1 -2
  335. package/worker/include/RTC/PipeTransport.hpp +4 -6
  336. package/worker/include/RTC/PlainTransport.hpp +4 -6
  337. package/worker/include/RTC/PortManager.hpp +1 -1
  338. package/worker/include/RTC/Producer.hpp +3 -3
  339. package/worker/include/RTC/RTCP/FeedbackPs.hpp +1 -1
  340. package/worker/include/RTC/RTCP/FeedbackRtp.hpp +1 -1
  341. package/worker/include/RTC/RTCP/FeedbackRtpNack.hpp +1 -1
  342. package/worker/include/RTC/RTCP/ReceiverReport.hpp +1 -1
  343. package/worker/include/RTC/RTP/Packet.hpp +2 -2
  344. package/worker/include/RTC/RTP/RtpStream.hpp +17 -12
  345. package/worker/include/RTC/RTP/RtpStreamRecv.hpp +8 -6
  346. package/worker/include/RTC/RTP/RtpStreamSend.hpp +4 -1
  347. package/worker/include/RTC/RTP/RtxStream.hpp +3 -1
  348. package/worker/include/RTC/RTP/SharedPacket.hpp +1 -1
  349. package/worker/include/RTC/RateCalculator.hpp +5 -2
  350. package/worker/include/RTC/Router.hpp +7 -8
  351. package/worker/include/RTC/RtpObserver.hpp +3 -3
  352. package/worker/include/RTC/SCTP/association/Association.hpp +53 -19
  353. package/worker/include/RTC/SCTP/association/AssociationListenerDeferrer.hpp +14 -6
  354. package/worker/include/RTC/SCTP/association/HeartbeatHandler.hpp +18 -14
  355. package/worker/include/RTC/SCTP/association/PacketSender.hpp +3 -3
  356. package/worker/include/RTC/SCTP/association/StateCookie.hpp +1 -1
  357. package/worker/include/RTC/SCTP/association/StreamResetHandler.hpp +49 -35
  358. package/worker/include/RTC/SCTP/association/TransmissionControlBlock.hpp +114 -31
  359. package/worker/include/RTC/SCTP/association/{TCBContext.hpp → TransmissionControlBlockContextInterface.hpp} +14 -8
  360. package/worker/include/RTC/SCTP/packet/Chunk.hpp +3 -3
  361. package/worker/include/RTC/SCTP/packet/TLV.hpp +1 -1
  362. package/worker/include/RTC/SCTP/packet/UserData.hpp +61 -17
  363. package/worker/include/RTC/SCTP/packet/chunks/AnyDataChunk.hpp +1 -1
  364. package/worker/include/RTC/SCTP/packet/chunks/AnyForwardTsnChunk.hpp +9 -9
  365. package/worker/include/RTC/SCTP/packet/chunks/AnyInitChunk.hpp +1 -1
  366. package/worker/include/RTC/SCTP/packet/chunks/DataChunk.hpp +4 -2
  367. package/worker/include/RTC/SCTP/packet/chunks/ForwardTsnChunk.hpp +3 -3
  368. package/worker/include/RTC/SCTP/packet/chunks/IDataChunk.hpp +4 -2
  369. package/worker/include/RTC/SCTP/packet/chunks/IForwardTsnChunk.hpp +3 -3
  370. package/worker/include/RTC/SCTP/packet/chunks/InitAckChunk.hpp +1 -1
  371. package/worker/include/RTC/SCTP/packet/chunks/InitChunk.hpp +1 -1
  372. package/worker/include/RTC/SCTP/packet/chunks/SackChunk.hpp +10 -3
  373. package/worker/include/RTC/SCTP/packet/chunks/ShutdownChunk.hpp +1 -1
  374. package/worker/include/RTC/SCTP/packet/errorCauses/InvalidStreamIdentifierErrorCause.hpp +1 -1
  375. package/worker/include/RTC/SCTP/packet/errorCauses/MissingMandatoryParameterErrorCause.hpp +1 -1
  376. package/worker/include/RTC/SCTP/packet/errorCauses/NoUserDataErrorCause.hpp +1 -1
  377. package/worker/include/RTC/SCTP/packet/errorCauses/StaleCookieErrorCause.hpp +1 -1
  378. package/worker/include/RTC/SCTP/packet/parameters/AddIncomingStreamsRequestParameter.hpp +1 -1
  379. package/worker/include/RTC/SCTP/packet/parameters/AddOutgoingStreamsRequestParameter.hpp +1 -1
  380. package/worker/include/RTC/SCTP/packet/parameters/CookiePreservativeParameter.hpp +1 -1
  381. package/worker/include/RTC/SCTP/packet/parameters/IncomingSsnResetRequestParameter.hpp +1 -1
  382. package/worker/include/RTC/SCTP/packet/parameters/OutgoingSsnResetRequestParameter.hpp +1 -1
  383. package/worker/include/RTC/SCTP/packet/parameters/ReconfigurationResponseParameter.hpp +1 -1
  384. package/worker/include/RTC/SCTP/packet/parameters/SsnTsnResetRequestParameter.hpp +1 -1
  385. package/worker/include/RTC/SCTP/packet/parameters/SupportedAddressTypesParameter.hpp +1 -1
  386. package/worker/include/RTC/SCTP/packet/parameters/SupportedExtensionsParameter.hpp +1 -1
  387. package/worker/include/RTC/SCTP/packet/parameters/ZeroChecksumAcceptableParameter.hpp +1 -1
  388. package/worker/include/RTC/SCTP/public/AssociationInterface.hpp +22 -2
  389. package/worker/include/RTC/SCTP/public/{AssociationListener.hpp → AssociationListenerInterface.hpp} +5 -5
  390. package/worker/include/RTC/SCTP/public/Message.hpp +26 -10
  391. package/worker/include/RTC/SCTP/public/SctpOptions.hpp +28 -19
  392. package/worker/include/RTC/SCTP/public/SctpTypes.hpp +21 -0
  393. package/worker/include/RTC/SCTP/rx/DataTracker.hpp +277 -0
  394. package/worker/include/RTC/SCTP/rx/InterleavedReassemblyStreams.hpp +116 -0
  395. package/worker/include/RTC/SCTP/rx/ReassemblyQueue.hpp +202 -0
  396. package/worker/include/RTC/SCTP/rx/ReassemblyStreamsInterface.hpp +83 -0
  397. package/worker/include/RTC/SCTP/rx/TraditionalReassemblyStreams.hpp +183 -0
  398. package/worker/include/RTC/SCTP/tx/OutstandingData.hpp +595 -0
  399. package/worker/include/RTC/SCTP/tx/RetransmissionErrorCounter.hpp +3 -3
  400. package/worker/include/RTC/SCTP/tx/RetransmissionQueue.hpp +329 -0
  401. package/worker/include/RTC/SCTP/tx/RetransmissionTimeout.hpp +11 -10
  402. package/worker/include/RTC/SCTP/tx/RoundRobinSendQueue.hpp +356 -0
  403. package/worker/include/RTC/SCTP/tx/SendQueueInterface.hpp +180 -0
  404. package/worker/include/RTC/SCTP/tx/StreamScheduler.hpp +235 -0
  405. package/worker/include/RTC/SenderBandwidthEstimator.hpp +5 -1
  406. package/worker/include/RTC/Serializable.hpp +11 -3
  407. package/worker/include/RTC/SimpleConsumer.hpp +1 -2
  408. package/worker/include/RTC/SimulcastConsumer.hpp +1 -2
  409. package/worker/include/RTC/SvcConsumer.hpp +1 -2
  410. package/worker/include/RTC/TcpServer.hpp +2 -2
  411. package/worker/include/RTC/Transport.hpp +65 -86
  412. package/worker/include/RTC/TransportCongestionControlClient.hpp +8 -5
  413. package/worker/include/RTC/TransportCongestionControlServer.hpp +8 -5
  414. package/worker/include/RTC/TransportTuple.hpp +1 -1
  415. package/worker/include/RTC/UdpSocket.hpp +1 -1
  416. package/worker/include/RTC/WebRtcServer.hpp +3 -3
  417. package/worker/include/RTC/WebRtcTransport.hpp +5 -7
  418. package/worker/include/Settings.hpp +2 -3
  419. package/worker/include/Shared.hpp +64 -0
  420. package/worker/include/SharedInterface.hpp +77 -0
  421. package/worker/include/Utils/UnwrappedSequenceNumber.hpp +270 -0
  422. package/worker/include/Utils.hpp +10 -4
  423. package/worker/include/Worker.hpp +6 -6
  424. package/worker/include/common.hpp +12 -12
  425. package/worker/include/handles/BackoffTimerHandle.hpp +28 -67
  426. package/worker/include/handles/BackoffTimerHandleInterface.hpp +123 -0
  427. package/worker/include/handles/TimerHandle.hpp +29 -20
  428. package/worker/include/handles/TimerHandleInterface.hpp +43 -0
  429. package/worker/meson.build +45 -29
  430. package/worker/meson_options.txt +2 -1
  431. package/worker/mocks/include/Channel/MockChannelMessageRegistrator.hpp +45 -0
  432. package/worker/mocks/include/MockShared.hpp +90 -0
  433. package/worker/mocks/include/RTC/SCTP/association/MockAssociationListener.hpp +308 -0
  434. package/worker/mocks/include/RTC/SCTP/association/MockTransmissionControlBlockContext.hpp +183 -0
  435. package/worker/mocks/include/RTC/SCTP/tx/MockSendQueue.hpp +262 -0
  436. package/worker/mocks/include/handles/MockBackoffTimerHandle.hpp +153 -0
  437. package/worker/mocks/include/handles/MockTimerHandle.hpp +74 -0
  438. package/worker/mocks/include/mockTypes.hpp +15 -0
  439. package/worker/mocks/src/Channel/MockChannelMessageRegistrator.cpp +128 -0
  440. package/worker/mocks/src/MockShared.cpp +46 -0
  441. package/worker/mocks/src/RTC/SCTP/association/MockTransmissionControlBlockContext.cpp +39 -0
  442. package/worker/mocks/src/handles/MockBackoffTimerHandle.cpp +127 -0
  443. package/worker/scripts/clang-scripts.mjs +5 -1
  444. package/worker/scripts/package-lock.json +6 -7
  445. package/worker/src/Channel/ChannelMessageRegistrator.cpp +125 -0
  446. package/worker/src/Channel/ChannelSocket.cpp +3 -4
  447. package/worker/src/DepLibUV.cpp +1 -1
  448. package/worker/src/DepLibUring.cpp +3 -1
  449. package/worker/src/Logger.cpp +1 -1
  450. package/worker/src/MediaSoupErrors.cpp +2 -0
  451. package/worker/src/RTC/ActiveSpeakerObserver.cpp +14 -14
  452. package/worker/src/RTC/AudioLevelObserver.cpp +12 -10
  453. package/worker/src/RTC/Consumer.cpp +28 -26
  454. package/worker/src/RTC/DataConsumer.cpp +61 -71
  455. package/worker/src/RTC/DataProducer.cpp +16 -11
  456. package/worker/src/RTC/DirectTransport.cpp +21 -20
  457. package/worker/src/RTC/DtlsTransport.cpp +4 -4
  458. package/worker/src/RTC/ICE/IceServer.cpp +6 -5
  459. package/worker/src/RTC/ICE/StunPacket.cpp +1 -1
  460. package/worker/src/RTC/KeyFrameRequestManager.cpp +15 -15
  461. package/worker/src/RTC/NackGenerator.cpp +6 -6
  462. package/worker/src/RTC/PipeConsumer.cpp +6 -5
  463. package/worker/src/RTC/PipeTransport.cpp +9 -22
  464. package/worker/src/RTC/PlainTransport.cpp +16 -28
  465. package/worker/src/RTC/Producer.cpp +40 -39
  466. package/worker/src/RTC/RTCP/FeedbackPsAfb.cpp +1 -1
  467. package/worker/src/RTC/RTCP/FeedbackPsRpsi.cpp +1 -2
  468. package/worker/src/RTC/RTCP/FeedbackRtpTransport.cpp +1 -1
  469. package/worker/src/RTC/RTCP/XR.cpp +1 -1
  470. package/worker/src/RTC/RTP/Packet.cpp +3 -1
  471. package/worker/src/RTC/RTP/ProbationGenerator.cpp +4 -4
  472. package/worker/src/RTC/RTP/RetransmissionBuffer.cpp +1 -1
  473. package/worker/src/RTC/RTP/RtpStream.cpp +17 -10
  474. package/worker/src/RTC/RTP/RtpStreamRecv.cpp +16 -14
  475. package/worker/src/RTC/RTP/RtpStreamSend.cpp +12 -9
  476. package/worker/src/RTC/RTP/RtxStream.cpp +7 -7
  477. package/worker/src/RTC/RTP/SharedPacket.cpp +3 -3
  478. package/worker/src/RTC/RateCalculator.cpp +1 -2
  479. package/worker/src/RTC/Router.cpp +61 -38
  480. package/worker/src/RTC/RtpDictionaries/RtpCodecMimeType.cpp +1 -1
  481. package/worker/src/RTC/RtpObserver.cpp +2 -1
  482. package/worker/src/RTC/SCTP/LICENSE +44 -0
  483. package/worker/src/RTC/SCTP/association/Association.cpp +417 -411
  484. package/worker/src/RTC/SCTP/association/AssociationListenerDeferrer.cpp +46 -13
  485. package/worker/src/RTC/SCTP/association/HeartbeatHandler.cpp +47 -43
  486. package/worker/src/RTC/SCTP/association/PacketSender.cpp +8 -8
  487. package/worker/src/RTC/SCTP/association/StreamResetHandler.cpp +113 -101
  488. package/worker/src/RTC/SCTP/association/TransmissionControlBlock.cpp +291 -62
  489. package/worker/src/RTC/SCTP/packet/Chunk.cpp +5 -1
  490. package/worker/src/RTC/SCTP/packet/Packet.cpp +8 -1
  491. package/worker/src/RTC/SCTP/packet/chunks/DataChunk.cpp +17 -0
  492. package/worker/src/RTC/SCTP/packet/chunks/ForwardTsnChunk.cpp +4 -4
  493. package/worker/src/RTC/SCTP/packet/chunks/IDataChunk.cpp +25 -0
  494. package/worker/src/RTC/SCTP/packet/chunks/IForwardTsnChunk.cpp +10 -7
  495. package/worker/src/RTC/SCTP/packet/chunks/SackChunk.cpp +21 -4
  496. package/worker/src/RTC/SCTP/packet/chunks/ShutdownCompleteChunk.cpp +1 -1
  497. package/worker/src/RTC/SCTP/packet/errorCauses/NoUserDataErrorCause.cpp +1 -1
  498. package/worker/src/RTC/SCTP/packet/errorCauses/ProtocolViolationErrorCause.cpp +2 -2
  499. package/worker/src/RTC/SCTP/packet/errorCauses/UserInitiatedAbortErrorCause.cpp +1 -1
  500. package/worker/src/RTC/SCTP/public/Message.cpp +8 -0
  501. package/worker/src/RTC/SCTP/public/SctpOptions.cpp +90 -0
  502. package/worker/src/RTC/SCTP/rx/DataTracker.cpp +471 -0
  503. package/worker/src/RTC/SCTP/rx/InterleavedReassemblyStreams.cpp +327 -0
  504. package/worker/src/RTC/SCTP/rx/ReassemblyQueue.cpp +288 -0
  505. package/worker/src/RTC/SCTP/rx/TraditionalReassemblyStreams.cpp +453 -0
  506. package/worker/src/RTC/SCTP/tx/OutstandingData.cpp +912 -0
  507. package/worker/src/RTC/SCTP/tx/RetransmissionQueue.cpp +786 -0
  508. package/worker/src/RTC/SCTP/tx/RetransmissionTimeout.cpp +2 -2
  509. package/worker/src/RTC/SCTP/tx/RoundRobinSendQueue.cpp +752 -0
  510. package/worker/src/RTC/SCTP/tx/StreamScheduler.cpp +257 -0
  511. package/worker/src/RTC/SenderBandwidthEstimator.cpp +7 -5
  512. package/worker/src/RTC/SimpleConsumer.cpp +11 -11
  513. package/worker/src/RTC/SimulcastConsumer.cpp +16 -16
  514. package/worker/src/RTC/SrtpSession.cpp +1 -1
  515. package/worker/src/RTC/SvcConsumer.cpp +16 -16
  516. package/worker/src/RTC/TcpConnection.cpp +1 -1
  517. package/worker/src/RTC/Transport.cpp +497 -563
  518. package/worker/src/RTC/TransportCongestionControlClient.cpp +9 -8
  519. package/worker/src/RTC/TransportCongestionControlServer.cpp +5 -5
  520. package/worker/src/RTC/WebRtcServer.cpp +5 -4
  521. package/worker/src/RTC/WebRtcTransport.cpp +44 -39
  522. package/worker/src/Settings.cpp +9 -28
  523. package/worker/src/Shared.cpp +35 -0
  524. package/worker/src/Utils/Crypto.cpp +1 -1
  525. package/worker/src/Utils/String.cpp +1 -1
  526. package/worker/src/Worker.cpp +19 -48
  527. package/worker/src/handles/BackoffTimerHandle.cpp +34 -21
  528. package/worker/src/handles/TimerHandle.cpp +5 -4
  529. package/worker/src/handles/UdpSocketHandle.cpp +1 -1
  530. package/worker/src/lib.cpp +17 -16
  531. package/worker/subprojects/catch2.wrap +6 -6
  532. package/worker/tasks.py +1 -1
  533. package/worker/test/include/RTC/ICE/iceCommon.hpp +8 -7
  534. package/worker/test/include/RTC/RTP/rtpCommon.hpp +7 -6
  535. package/worker/test/include/RTC/SCTP/sctpCommon.hpp +16 -10
  536. package/worker/test/include/catch2Macros.hpp +31 -0
  537. package/worker/test/src/RTC/ICE/TestStunPacket.cpp +3 -3
  538. package/worker/test/src/RTC/ICE/iceCommon.cpp +2 -2
  539. package/worker/test/src/RTC/RTP/Codecs/TestVP8.cpp +1 -1
  540. package/worker/test/src/RTC/RTP/Codecs/TestVP9.cpp +1 -1
  541. package/worker/test/src/RTC/RTP/TestPacket.cpp +3 -3
  542. package/worker/test/src/RTC/RTP/TestRtpStreamRecv.cpp +16 -9
  543. package/worker/test/src/RTC/RTP/TestRtpStreamSend.cpp +38 -23
  544. package/worker/test/src/RTC/RTP/TestSharedPacket.cpp +1 -1
  545. package/worker/test/src/RTC/RTP/rtpCommon.cpp +2 -2
  546. package/worker/test/src/RTC/SCTP/association/TestHeartbeatHandler.cpp +292 -0
  547. package/worker/test/src/RTC/SCTP/association/TestNegotiatedCapabilities.cpp +1 -1
  548. package/worker/test/src/RTC/SCTP/association/TestStateCookie.cpp +1 -1
  549. package/worker/test/src/RTC/SCTP/association/TestTransmissionControlBlock.cpp +99 -0
  550. package/worker/test/src/RTC/SCTP/packet/TestChunk.cpp +1 -1
  551. package/worker/test/src/RTC/SCTP/packet/TestPacket.cpp +1 -1
  552. package/worker/test/src/RTC/SCTP/packet/chunks/TestAbortAssociationChunk.cpp +1 -1
  553. package/worker/test/src/RTC/SCTP/packet/chunks/TestCookieAckChunk.cpp +1 -1
  554. package/worker/test/src/RTC/SCTP/packet/chunks/TestCookieEchoChunk.cpp +1 -1
  555. package/worker/test/src/RTC/SCTP/packet/chunks/TestDataChunk.cpp +77 -7
  556. package/worker/test/src/RTC/SCTP/packet/chunks/TestForwardTsnChunk.cpp +35 -26
  557. package/worker/test/src/RTC/SCTP/packet/chunks/TestHeartbeatAckChunk.cpp +1 -1
  558. package/worker/test/src/RTC/SCTP/packet/chunks/TestHeartbeatRequestChunk.cpp +1 -1
  559. package/worker/test/src/RTC/SCTP/packet/chunks/TestIDataChunk.cpp +77 -7
  560. package/worker/test/src/RTC/SCTP/packet/chunks/TestIForwardTsnChunk.cpp +59 -27
  561. package/worker/test/src/RTC/SCTP/packet/chunks/TestInitAckChunk.cpp +1 -1
  562. package/worker/test/src/RTC/SCTP/packet/chunks/TestInitChunk.cpp +1 -1
  563. package/worker/test/src/RTC/SCTP/packet/chunks/TestOperationErrorChunk.cpp +1 -1
  564. package/worker/test/src/RTC/SCTP/packet/chunks/TestReConfigChunk.cpp +1 -1
  565. package/worker/test/src/RTC/SCTP/packet/chunks/TestSackChunk.cpp +73 -35
  566. package/worker/test/src/RTC/SCTP/packet/chunks/TestShutdownAckChunk.cpp +1 -1
  567. package/worker/test/src/RTC/SCTP/packet/chunks/TestShutdownChunk.cpp +1 -1
  568. package/worker/test/src/RTC/SCTP/packet/chunks/TestShutdownCompleteChunk.cpp +1 -1
  569. package/worker/test/src/RTC/SCTP/packet/chunks/TestUnknownChunk.cpp +1 -1
  570. package/worker/test/src/RTC/SCTP/packet/errorCauses/TestCookieReceivedWhileShuttingDownErrorCause.cpp +1 -1
  571. package/worker/test/src/RTC/SCTP/packet/errorCauses/TestInvalidMandatoryParameterErrorCause.cpp +1 -1
  572. package/worker/test/src/RTC/SCTP/packet/errorCauses/TestInvalidStreamIdentifierErrorCause.cpp +1 -1
  573. package/worker/test/src/RTC/SCTP/packet/errorCauses/TestMissingMandatoryParameterErrorCause.cpp +1 -1
  574. package/worker/test/src/RTC/SCTP/packet/errorCauses/TestNoUserDataErrorCause.cpp +1 -1
  575. package/worker/test/src/RTC/SCTP/packet/errorCauses/TestOutOfResourceErrorCause.cpp +1 -1
  576. package/worker/test/src/RTC/SCTP/packet/errorCauses/TestProtocolViolationErrorCause.cpp +1 -1
  577. package/worker/test/src/RTC/SCTP/packet/errorCauses/TestRestartOfAnAssociationWithNewAddressesErrorCause.cpp +1 -1
  578. package/worker/test/src/RTC/SCTP/packet/errorCauses/TestStaleCookieErrorCause.cpp +1 -1
  579. package/worker/test/src/RTC/SCTP/packet/errorCauses/TestUnknownErrorCause.cpp +1 -1
  580. package/worker/test/src/RTC/SCTP/packet/errorCauses/TestUnrecognizedChunkTypeErrorCause.cpp +1 -1
  581. package/worker/test/src/RTC/SCTP/packet/errorCauses/TestUnrecognizedParametersErrorCause.cpp +1 -1
  582. package/worker/test/src/RTC/SCTP/packet/errorCauses/TestUnresolvableAddressErrorCause.cpp +1 -1
  583. package/worker/test/src/RTC/SCTP/packet/errorCauses/TestUserInitiatedAbortErrorCause.cpp +1 -1
  584. package/worker/test/src/RTC/SCTP/packet/parameters/TestAddIncomingStreamsRequestParameter.cpp +1 -1
  585. package/worker/test/src/RTC/SCTP/packet/parameters/TestAddOutgoingStreamsRequestParameter.cpp +1 -1
  586. package/worker/test/src/RTC/SCTP/packet/parameters/TestCookiePreservativeParameter.cpp +1 -1
  587. package/worker/test/src/RTC/SCTP/packet/parameters/TestForwardTsnSupportedParameter.cpp +1 -1
  588. package/worker/test/src/RTC/SCTP/packet/parameters/TestHeartbeatInfoParameter.cpp +1 -1
  589. package/worker/test/src/RTC/SCTP/packet/parameters/TestIPv4AddressParameter.cpp +1 -1
  590. package/worker/test/src/RTC/SCTP/packet/parameters/TestIPv6AddressParameter.cpp +1 -1
  591. package/worker/test/src/RTC/SCTP/packet/parameters/TestIncomingSsnResetRequestParameter.cpp +1 -1
  592. package/worker/test/src/RTC/SCTP/packet/parameters/TestOutgoingSsnResetRequestParameter.cpp +1 -1
  593. package/worker/test/src/RTC/SCTP/packet/parameters/TestReconfigurationResponseParameter.cpp +1 -1
  594. package/worker/test/src/RTC/SCTP/packet/parameters/TestSsnTsnResetRequestParameter.cpp +1 -1
  595. package/worker/test/src/RTC/SCTP/packet/parameters/TestStateCookieParameter.cpp +1 -1
  596. package/worker/test/src/RTC/SCTP/packet/parameters/TestSupportedAddressTypesParameter.cpp +1 -1
  597. package/worker/test/src/RTC/SCTP/packet/parameters/TestSupportedExtensionsParameter.cpp +1 -1
  598. package/worker/test/src/RTC/SCTP/packet/parameters/TestUnknownParameter.cpp +1 -1
  599. package/worker/test/src/RTC/SCTP/packet/parameters/TestUnrecognizedParameterParameter.cpp +1 -1
  600. package/worker/test/src/RTC/SCTP/packet/parameters/TestZeroChecksumAcceptableParameter.cpp +1 -1
  601. package/worker/test/src/RTC/SCTP/rx/TestDataTracker.cpp +1117 -0
  602. package/worker/test/src/RTC/SCTP/rx/TestInterleavedReassemblyStreams.cpp +565 -0
  603. package/worker/test/src/RTC/SCTP/rx/TestReassemblyQueue.cpp +557 -0
  604. package/worker/test/src/RTC/SCTP/rx/TestTraditionalReassemblyStreams.cpp +555 -0
  605. package/worker/test/src/RTC/SCTP/sctpCommon.cpp +2 -2
  606. package/worker/test/src/RTC/SCTP/tx/TestOutstandingData.cpp +1248 -0
  607. package/worker/test/src/RTC/SCTP/tx/TestRetransmissionErrorCounter.cpp +4 -0
  608. package/worker/test/src/RTC/SCTP/tx/TestRetransmissionQueue.cpp +2218 -0
  609. package/worker/test/src/RTC/SCTP/tx/TestRetransmissionTimeout.cpp +33 -33
  610. package/worker/test/src/RTC/SCTP/tx/TestRoundRobinSendQueue.cpp +1130 -0
  611. package/worker/test/src/RTC/SCTP/tx/TestStreamScheduler.cpp +721 -0
  612. package/worker/test/src/RTC/TestKeyFrameRequestManager.cpp +20 -30
  613. package/worker/test/src/RTC/TestNackGenerator.cpp +11 -8
  614. package/worker/test/src/RTC/TestRateCalculator.cpp +6 -7
  615. package/worker/test/src/RTC/TestSimpleConsumer.cpp +11 -11
  616. package/worker/test/src/RTC/TestTransportCongestionControlServer.cpp +15 -3
  617. package/worker/test/src/Utils/TestByte.cpp +98 -0
  618. package/worker/test/src/{RTC/SCTP/common → Utils}/TestUnwrappedSequenceNumber.cpp +2 -2
  619. package/worker/test/src/testHelpers.cpp +1 -1
  620. package/worker/test/src/tests.cpp +0 -12
  621. package/node/lib/fbs/consumer/degrade-request.d.ts +0 -30
  622. package/node/lib/fbs/consumer/degrade-request.d.ts.map +0 -1
  623. package/node/lib/fbs/consumer/degrade-request.js +0 -91
  624. package/node/lib/fbs/consumer/enable-delay-and-loss-request.d.ts +0 -24
  625. package/node/lib/fbs/consumer/enable-delay-and-loss-request.d.ts.map +0 -1
  626. package/node/lib/fbs/consumer/enable-delay-and-loss-request.js +0 -69
  627. package/node/lib/fbs/producer/degrade-request.d.ts +0 -30
  628. package/node/lib/fbs/producer/degrade-request.d.ts.map +0 -1
  629. package/node/lib/fbs/producer/degrade-request.js +0 -91
  630. package/node/lib/fbs/worker/close-notification.d.ts +0 -18
  631. package/node/lib/fbs/worker/close-notification.d.ts.map +0 -1
  632. package/node/lib/fbs/worker/close-notification.js +0 -45
  633. package/node/lib/fbs/worker/close-request.d.ts +0 -18
  634. package/node/lib/fbs/worker/close-request.d.ts.map +0 -1
  635. package/node/lib/fbs/worker/close-request.js +0 -45
  636. package/node/lib/fbs/worker/close-worker-notification.d.ts +0 -18
  637. package/node/lib/fbs/worker/close-worker-notification.d.ts.map +0 -1
  638. package/node/lib/fbs/worker/close-worker-notification.js +0 -45
  639. package/worker/include/ChannelMessageRegistrator.hpp +0 -30
  640. package/worker/include/DepUsrSCTP.hpp +0 -48
  641. package/worker/include/RTC/SCTP/TODO_SCTP.md +0 -43
  642. package/worker/include/RTC/SCTP/common/UnwrappedSequenceNumber.hpp +0 -274
  643. package/worker/include/RTC/SctpAssociation.hpp +0 -147
  644. package/worker/include/RTC/Shared.hpp +0 -23
  645. package/worker/src/ChannelMessageRegistrator.cpp +0 -119
  646. package/worker/src/DepUsrSCTP.cpp +0 -277
  647. package/worker/src/RTC/SctpAssociation.cpp +0 -1175
  648. package/worker/src/RTC/Shared.cpp +0 -23
  649. package/worker/subprojects/usrsctp.wrap +0 -8
@@ -0,0 +1,721 @@
1
+ #include "common.hpp"
2
+ #include "RTC/SCTP/packet/UserData.hpp"
3
+ #include "RTC/SCTP/tx/SendQueueInterface.hpp"
4
+ #include "RTC/SCTP/tx/StreamScheduler.hpp"
5
+ #include <catch2/catch_test_macros.hpp>
6
+ #include <deque>
7
+ #include <map>
8
+ #include <vector>
9
+
10
+ namespace
11
+ {
12
+ constexpr uint64_t Mtu{ 1000 };
13
+ constexpr size_t PayloadLength{ 4 };
14
+ constexpr uint64_t NowMs{ 0 };
15
+
16
+ bool checkDataToSendHasMid(
17
+ std::optional<RTC::SCTP::SendQueueInterface::DataToSend> dataToSend, uint32_t mid)
18
+ {
19
+ if (!dataToSend.has_value())
20
+ {
21
+ return false;
22
+ }
23
+
24
+ if (dataToSend->data.GetMessageId() != mid)
25
+ {
26
+ return false;
27
+ }
28
+
29
+ return true;
30
+ }
31
+
32
+ std::function<std::optional<RTC::SCTP::SendQueueInterface::DataToSend>(uint64_t, size_t)> createChunk(
33
+ uint32_t outgoingMessageId, uint16_t streamId, uint32_t mid, size_t payloadLength = PayloadLength)
34
+ {
35
+ return
36
+ [streamId, mid, payloadLength, outgoingMessageId](uint64_t /*nowMs*/, size_t /*maxLength*/)
37
+ {
38
+ return RTC::SCTP::SendQueueInterface::DataToSend(
39
+ outgoingMessageId,
40
+ RTC::SCTP::UserData(
41
+ streamId,
42
+ /*ssn*/ 0,
43
+ mid,
44
+ /*fsn*/ 0,
45
+ /*ppid*/ 42,
46
+ std::vector<uint8_t>(payloadLength),
47
+ /*isBeginning*/ true,
48
+ /*isEnd*/ true,
49
+ /*unoreded*/ true));
50
+ };
51
+ }
52
+
53
+ std::map<uint16_t, size_t> getPacketCounts(
54
+ RTC::SCTP::StreamScheduler& scheduler, size_t packetsToGenerate)
55
+ {
56
+ std::map</*streamId*/ uint16_t, size_t> packetCounts;
57
+
58
+ for (size_t i{ 0 }; i < packetsToGenerate; ++i)
59
+ {
60
+ const std::optional<RTC::SCTP::SendQueueInterface::DataToSend> dataToSend =
61
+ scheduler.Produce(NowMs, Mtu);
62
+
63
+ if (dataToSend.has_value())
64
+ {
65
+ ++packetCounts[dataToSend->data.GetStreamId()];
66
+ }
67
+ }
68
+
69
+ return packetCounts;
70
+ }
71
+
72
+ class MockStreamProducer : public RTC::SCTP::StreamScheduler::StreamProducer
73
+ {
74
+ public:
75
+ /**
76
+ * Equivalent to EXPECT_CALL(producer, Produce).WillOnce(...).WillOnce(...)
77
+ * in dcsctp.
78
+ */
79
+ void PushProduce(
80
+ std::function<std::optional<RTC::SCTP::SendQueueInterface::DataToSend>(uint64_t, size_t)> fn)
81
+ {
82
+ this->produceQueue.push_back(std::move(fn));
83
+ }
84
+
85
+ /**
86
+ * Equivalent to EXPECT_CALL(producer, bytes_to_send_in_next_message)
87
+ * .WillOnce(Return(n)) in dcsctp.
88
+ */
89
+ void PushBytesToSend(size_t bytes)
90
+ {
91
+ this->bytesQueue.push_back(bytes);
92
+ }
93
+
94
+ std::optional<RTC::SCTP::SendQueueInterface::DataToSend> Produce(uint64_t nowMs, size_t maxLength) override
95
+ {
96
+ REQUIRE(!this->produceQueue.empty());
97
+
98
+ const auto fn = std::move(this->produceQueue.front());
99
+
100
+ this->produceQueue.pop_front();
101
+
102
+ return fn(nowMs, maxLength);
103
+ }
104
+
105
+ size_t GetBytesToSendInNextMessage() const override
106
+ {
107
+ REQUIRE(!this->bytesQueue.empty());
108
+
109
+ const size_t bytes = this->bytesQueue.front();
110
+
111
+ this->bytesQueue.pop_front();
112
+
113
+ return bytes;
114
+ }
115
+
116
+ private:
117
+ std::deque<std::function<std::optional<RTC::SCTP::SendQueueInterface::DataToSend>(uint64_t, size_t)>>
118
+ produceQueue;
119
+ mutable std::deque<size_t> bytesQueue;
120
+ };
121
+
122
+ class TestStream
123
+ {
124
+ public:
125
+ TestStream(
126
+ RTC::SCTP::StreamScheduler& scheduler,
127
+ uint16_t streamId,
128
+ uint16_t priority,
129
+ size_t packetLength = PayloadLength)
130
+ {
131
+ this->producer.PushBytesToSend(packetLength); // MayMakeActive().
132
+
133
+ // Equivalent to WillRepeatedly() in dcsctp.
134
+ for (int i{ 0 }; i < 100; ++i)
135
+ {
136
+ this->producer.PushProduce(createChunk(i, streamId, i, packetLength));
137
+ this->producer.PushBytesToSend(packetLength);
138
+ }
139
+
140
+ this->stream = scheduler.CreateStream(std::addressof(producer), streamId, priority);
141
+ this->stream->MayMakeActive();
142
+ }
143
+
144
+ RTC::SCTP::StreamScheduler::Stream& GetStream()
145
+ {
146
+ return *stream;
147
+ }
148
+
149
+ private:
150
+ MockStreamProducer producer;
151
+ std::unique_ptr<RTC::SCTP::StreamScheduler::Stream> stream;
152
+ };
153
+ } // namespace
154
+
155
+ SCENARIO("SCTP StreamScheduler", "[sctp][streamscheduler]")
156
+ {
157
+ // A scheduler without active streams doesn't produce data.
158
+ SECTION("has no active streams")
159
+ {
160
+ RTC::SCTP::StreamScheduler scheduler(Mtu);
161
+
162
+ REQUIRE(!scheduler.Produce(NowMs, Mtu).has_value());
163
+ }
164
+
165
+ // Stream properties can be set and retrieved.
166
+ SECTION("can set and get stream properties")
167
+ {
168
+ RTC::SCTP::StreamScheduler scheduler(Mtu);
169
+ MockStreamProducer producer;
170
+ auto stream = scheduler.CreateStream(std::addressof(producer), 1, 2);
171
+
172
+ REQUIRE(stream->GetStreamId() == 1);
173
+ REQUIRE(stream->GetPriority() == 2);
174
+
175
+ stream->SetPriority(0);
176
+
177
+ REQUIRE(stream->GetPriority() == 0);
178
+ }
179
+
180
+ SECTION("can produce from a single stream")
181
+ {
182
+ RTC::SCTP::StreamScheduler scheduler(Mtu);
183
+ MockStreamProducer producer;
184
+
185
+ producer.PushBytesToSend(PayloadLength);
186
+ producer.PushProduce(createChunk(0, 1, 0));
187
+ producer.PushBytesToSend(0);
188
+
189
+ auto stream = scheduler.CreateStream(std::addressof(producer), 1, 2);
190
+
191
+ stream->MayMakeActive();
192
+
193
+ REQUIRE(checkDataToSendHasMid(scheduler.Produce(NowMs, Mtu), 0));
194
+ REQUIRE(!scheduler.Produce(NowMs, Mtu).has_value());
195
+ }
196
+
197
+ // A scheduler with a single stream produced packets from it.
198
+ SECTION("will round-robin between streams")
199
+ {
200
+ RTC::SCTP::StreamScheduler scheduler(Mtu);
201
+ MockStreamProducer producer1;
202
+
203
+ producer1.PushBytesToSend(PayloadLength);
204
+ producer1.PushProduce(createChunk(0, 1, 100));
205
+ producer1.PushBytesToSend(PayloadLength);
206
+ producer1.PushProduce(createChunk(1, 1, 101));
207
+ producer1.PushBytesToSend(PayloadLength);
208
+ producer1.PushProduce(createChunk(2, 1, 102));
209
+ producer1.PushBytesToSend(0);
210
+
211
+ auto stream1 = scheduler.CreateStream(std::addressof(producer1), 1, 2);
212
+
213
+ stream1->MayMakeActive();
214
+
215
+ MockStreamProducer producer2;
216
+
217
+ producer2.PushBytesToSend(PayloadLength);
218
+ producer2.PushProduce(createChunk(3, 2, 200));
219
+ producer2.PushBytesToSend(PayloadLength);
220
+ producer2.PushProduce(createChunk(4, 2, 201));
221
+ producer2.PushBytesToSend(PayloadLength);
222
+ producer2.PushProduce(createChunk(5, 2, 202));
223
+ producer2.PushBytesToSend(0);
224
+
225
+ auto stream2 = scheduler.CreateStream(std::addressof(producer2), 2, 2);
226
+
227
+ stream2->MayMakeActive();
228
+
229
+ REQUIRE(checkDataToSendHasMid(scheduler.Produce(NowMs, Mtu), 100));
230
+ REQUIRE(checkDataToSendHasMid(scheduler.Produce(NowMs, Mtu), 200));
231
+ REQUIRE(checkDataToSendHasMid(scheduler.Produce(NowMs, Mtu), 101));
232
+ REQUIRE(checkDataToSendHasMid(scheduler.Produce(NowMs, Mtu), 201));
233
+ REQUIRE(checkDataToSendHasMid(scheduler.Produce(NowMs, Mtu), 102));
234
+ REQUIRE(checkDataToSendHasMid(scheduler.Produce(NowMs, Mtu), 202));
235
+ REQUIRE(!scheduler.Produce(NowMs, Mtu).has_value());
236
+ }
237
+
238
+ // Switches between two streams after every packet.
239
+ SECTION("will round-robin between streams")
240
+ {
241
+ RTC::SCTP::StreamScheduler scheduler(Mtu);
242
+ MockStreamProducer producer1;
243
+
244
+ producer1.PushBytesToSend(PayloadLength);
245
+ producer1.PushProduce(createChunk(0, 1, 100));
246
+ producer1.PushBytesToSend(PayloadLength);
247
+ producer1.PushProduce(createChunk(1, 1, 101));
248
+ producer1.PushBytesToSend(PayloadLength);
249
+ producer1.PushProduce(createChunk(2, 1, 102));
250
+ producer1.PushBytesToSend(0);
251
+
252
+ auto stream1 = scheduler.CreateStream(std::addressof(producer1), 1, 2);
253
+
254
+ stream1->MayMakeActive();
255
+
256
+ MockStreamProducer producer2;
257
+
258
+ producer2.PushBytesToSend(PayloadLength);
259
+ producer2.PushProduce(createChunk(3, 2, 200));
260
+ producer2.PushBytesToSend(PayloadLength);
261
+ producer2.PushProduce(createChunk(4, 2, 201));
262
+ producer2.PushBytesToSend(PayloadLength);
263
+ producer2.PushProduce(createChunk(5, 2, 202));
264
+ producer2.PushBytesToSend(0);
265
+
266
+ auto stream2 = scheduler.CreateStream(std::addressof(producer2), 2, 2);
267
+
268
+ stream2->MayMakeActive();
269
+
270
+ REQUIRE(checkDataToSendHasMid(scheduler.Produce(NowMs, Mtu), 100));
271
+ REQUIRE(checkDataToSendHasMid(scheduler.Produce(NowMs, Mtu), 200));
272
+ REQUIRE(checkDataToSendHasMid(scheduler.Produce(NowMs, Mtu), 101));
273
+ REQUIRE(checkDataToSendHasMid(scheduler.Produce(NowMs, Mtu), 201));
274
+ REQUIRE(checkDataToSendHasMid(scheduler.Produce(NowMs, Mtu), 102));
275
+ REQUIRE(checkDataToSendHasMid(scheduler.Produce(NowMs, Mtu), 202));
276
+ REQUIRE(!scheduler.Produce(NowMs, Mtu).has_value());
277
+ }
278
+
279
+ // Switches between two streams after every packet, but keeps producing from
280
+ // the same stream when a packet contains of multiple fragments.
281
+ SECTION("will round-robin only when finished producing chunk")
282
+ {
283
+ RTC::SCTP::StreamScheduler scheduler(Mtu);
284
+ MockStreamProducer producer1;
285
+
286
+ producer1.PushBytesToSend(PayloadLength); // MayMakeActive
287
+ producer1.PushProduce(createChunk(0, 1, 100));
288
+ producer1.PushBytesToSend(PayloadLength);
289
+ // MID(101) fragmented in 3 chunks:
290
+ // 1. beginning:true, end:false
291
+ // 2. beginning:false, end:false
292
+ // 3. beginning:false, end:true
293
+ producer1.PushProduce(
294
+ [](uint64_t, size_t)
295
+ {
296
+ return RTC::SCTP::SendQueueInterface::DataToSend(
297
+ 1, RTC::SCTP::UserData(1, 0, 101, 0, 42, std::vector<uint8_t>(4), true, false, true));
298
+ });
299
+ producer1.PushBytesToSend(PayloadLength);
300
+ producer1.PushProduce(
301
+ [](uint64_t, size_t)
302
+ {
303
+ return RTC::SCTP::SendQueueInterface::DataToSend(
304
+ 1, RTC::SCTP::UserData(1, 0, 101, 0, 42, std::vector<uint8_t>(4), false, false, true));
305
+ });
306
+ producer1.PushBytesToSend(PayloadLength);
307
+ producer1.PushProduce(
308
+ [](uint64_t, size_t)
309
+ {
310
+ return RTC::SCTP::SendQueueInterface::DataToSend(
311
+ 1, RTC::SCTP::UserData(1, 0, 101, 0, 42, std::vector<uint8_t>(4), false, true, true));
312
+ });
313
+ producer1.PushBytesToSend(PayloadLength);
314
+ producer1.PushProduce(createChunk(2, 1, 102));
315
+ producer1.PushBytesToSend(0);
316
+
317
+ auto stream1 = scheduler.CreateStream(std::addressof(producer1), 1, 2);
318
+
319
+ stream1->MayMakeActive();
320
+
321
+ MockStreamProducer producer2;
322
+
323
+ producer2.PushBytesToSend(PayloadLength); // MayMakeActive().
324
+ producer2.PushProduce(createChunk(3, 2, 200));
325
+ producer2.PushBytesToSend(PayloadLength);
326
+ producer2.PushProduce(createChunk(4, 2, 201));
327
+ producer2.PushBytesToSend(PayloadLength);
328
+ producer2.PushProduce(createChunk(5, 2, 202));
329
+ producer2.PushBytesToSend(0);
330
+
331
+ auto stream2 = scheduler.CreateStream(std::addressof(producer2), 2, 2);
332
+
333
+ stream2->MayMakeActive();
334
+
335
+ REQUIRE(checkDataToSendHasMid(scheduler.Produce(NowMs, Mtu), 100));
336
+ REQUIRE(checkDataToSendHasMid(scheduler.Produce(NowMs, Mtu), 200));
337
+ // MID(101) is fully produced before giving up on stream2.
338
+ REQUIRE(checkDataToSendHasMid(scheduler.Produce(NowMs, Mtu), 101));
339
+ REQUIRE(checkDataToSendHasMid(scheduler.Produce(NowMs, Mtu), 101));
340
+ REQUIRE(checkDataToSendHasMid(scheduler.Produce(NowMs, Mtu), 101));
341
+ REQUIRE(checkDataToSendHasMid(scheduler.Produce(NowMs, Mtu), 201));
342
+ REQUIRE(checkDataToSendHasMid(scheduler.Produce(NowMs, Mtu), 102));
343
+ REQUIRE(checkDataToSendHasMid(scheduler.Produce(NowMs, Mtu), 202));
344
+ REQUIRE(!scheduler.Produce(NowMs, Mtu).has_value());
345
+ }
346
+
347
+ // Resumes a paused stream - makes a stream active after inactivating it.
348
+ SECTION("single stream can be resumed")
349
+ {
350
+ RTC::SCTP::StreamScheduler scheduler(Mtu);
351
+ MockStreamProducer producer1;
352
+
353
+ producer1.PushBytesToSend(PayloadLength);
354
+ producer1.PushProduce(createChunk(0, 1, 100));
355
+ producer1.PushBytesToSend(PayloadLength);
356
+ producer1.PushProduce(createChunk(1, 1, 101));
357
+ producer1.PushBytesToSend(PayloadLength);
358
+ producer1.PushProduce(createChunk(2, 1, 102));
359
+ producer1.PushBytesToSend(PayloadLength); // When making active again.
360
+ producer1.PushBytesToSend(0);
361
+
362
+ auto stream1 = scheduler.CreateStream(std::addressof(producer1), 1, 2);
363
+
364
+ stream1->MayMakeActive();
365
+
366
+ REQUIRE(checkDataToSendHasMid(scheduler.Produce(NowMs, Mtu), 100));
367
+ REQUIRE(checkDataToSendHasMid(scheduler.Produce(NowMs, Mtu), 101));
368
+
369
+ stream1->MakeInactive();
370
+
371
+ REQUIRE(!scheduler.Produce(NowMs, Mtu).has_value());
372
+
373
+ stream1->MayMakeActive();
374
+
375
+ REQUIRE(checkDataToSendHasMid(scheduler.Produce(NowMs, Mtu), 102));
376
+ REQUIRE(!scheduler.Produce(NowMs, Mtu).has_value());
377
+ }
378
+
379
+ // Iterates between streams, where one is suddenly paused and later resumed.
380
+ SECTION("will round-robin with paused stream")
381
+ {
382
+ RTC::SCTP::StreamScheduler scheduler(Mtu);
383
+ MockStreamProducer producer1;
384
+
385
+ producer1.PushBytesToSend(PayloadLength);
386
+ producer1.PushProduce(createChunk(0, 1, 100));
387
+ producer1.PushBytesToSend(PayloadLength);
388
+ producer1.PushProduce(createChunk(1, 1, 101));
389
+ producer1.PushBytesToSend(PayloadLength);
390
+ producer1.PushProduce(createChunk(2, 1, 102));
391
+ producer1.PushBytesToSend(PayloadLength); // When making active again.
392
+ producer1.PushBytesToSend(0);
393
+
394
+ auto stream1 = scheduler.CreateStream(std::addressof(producer1), 1, 2);
395
+
396
+ stream1->MayMakeActive();
397
+
398
+ MockStreamProducer producer2;
399
+
400
+ producer2.PushBytesToSend(PayloadLength); // MayMakeActive().
401
+ producer2.PushProduce(createChunk(3, 2, 200));
402
+ producer2.PushBytesToSend(PayloadLength);
403
+ producer2.PushProduce(createChunk(4, 2, 201));
404
+ producer2.PushBytesToSend(PayloadLength);
405
+ producer2.PushProduce(createChunk(5, 2, 202));
406
+ producer2.PushBytesToSend(0);
407
+
408
+ auto stream2 = scheduler.CreateStream(std::addressof(producer2), 2, 2);
409
+
410
+ stream2->MayMakeActive();
411
+
412
+ REQUIRE(checkDataToSendHasMid(scheduler.Produce(NowMs, Mtu), 100));
413
+ REQUIRE(checkDataToSendHasMid(scheduler.Produce(NowMs, Mtu), 200));
414
+
415
+ stream1->MakeInactive();
416
+
417
+ REQUIRE(checkDataToSendHasMid(scheduler.Produce(NowMs, Mtu), 201));
418
+ REQUIRE(checkDataToSendHasMid(scheduler.Produce(NowMs, Mtu), 202));
419
+
420
+ stream1->MayMakeActive();
421
+ REQUIRE(checkDataToSendHasMid(scheduler.Produce(NowMs, Mtu), 101));
422
+ REQUIRE(checkDataToSendHasMid(scheduler.Produce(NowMs, Mtu), 102));
423
+ REQUIRE(!scheduler.Produce(NowMs, Mtu).has_value());
424
+ }
425
+
426
+ // Verifies that packet counts are evenly distributed in round robin
427
+ // scheduling.
428
+ SECTION("will distribute round-robin packets evenly between two streams")
429
+ {
430
+ RTC::SCTP::StreamScheduler scheduler(Mtu);
431
+
432
+ const TestStream stream1(scheduler, 1, 1);
433
+ const TestStream stream2(scheduler, 2, 1);
434
+
435
+ const auto packetCounts = getPacketCounts(scheduler, 10);
436
+
437
+ REQUIRE(packetCounts.at(1) == 5);
438
+ REQUIRE(packetCounts.at(2) == 5);
439
+ }
440
+
441
+ // Verifies that packet counts are evenly distributed among active streams,
442
+ // where a stream is suddenly made inactive, two are added, and then the
443
+ // paused stream is resumed.
444
+ SECTION("will distribute evenly with paused and added streams")
445
+ {
446
+ RTC::SCTP::StreamScheduler scheduler(Mtu);
447
+
448
+ const TestStream stream1(scheduler, 1, 1);
449
+ TestStream stream2(scheduler, 2, 1);
450
+
451
+ const auto counts1 = getPacketCounts(scheduler, 10);
452
+
453
+ REQUIRE(counts1.at(1) == 5);
454
+ REQUIRE(counts1.at(2) == 5);
455
+
456
+ stream2.GetStream().MakeInactive();
457
+
458
+ const TestStream stream3(scheduler, 3, 1);
459
+ const TestStream stream4(scheduler, 4, 1);
460
+
461
+ const auto counts2 = getPacketCounts(scheduler, 15);
462
+
463
+ REQUIRE(counts2.at(1) == 5);
464
+ // stream2 is inative, it is not in the map.
465
+ REQUIRE(!counts2.contains(2));
466
+ REQUIRE(counts2.at(3) == 5);
467
+ REQUIRE(counts2.at(4) == 5);
468
+
469
+ stream2.GetStream().MayMakeActive();
470
+
471
+ const auto counts3 = getPacketCounts(scheduler, 20);
472
+
473
+ REQUIRE(counts3.at(1) == 5);
474
+ REQUIRE(counts3.at(2) == 5);
475
+ REQUIRE(counts3.at(3) == 5);
476
+ REQUIRE(counts3.at(4) == 5);
477
+ }
478
+
479
+ // Degrades to fair queuing with streams having identical priority.
480
+ SECTION("will do fair queuing with same priority")
481
+ {
482
+ RTC::SCTP::StreamScheduler scheduler(Mtu);
483
+
484
+ scheduler.EnableMessageInterleaving(true);
485
+
486
+ constexpr size_t SmallPacket{ 30 };
487
+ constexpr size_t LargePacket{ 70 };
488
+
489
+ MockStreamProducer producer1;
490
+
491
+ producer1.PushBytesToSend(SmallPacket); // MayMakeActive().
492
+ producer1.PushProduce(createChunk(0, 1, 100, SmallPacket));
493
+ producer1.PushBytesToSend(SmallPacket);
494
+ producer1.PushProduce(createChunk(1, 1, 101, SmallPacket));
495
+ producer1.PushBytesToSend(SmallPacket);
496
+ producer1.PushProduce(createChunk(2, 1, 102, SmallPacket));
497
+ producer1.PushBytesToSend(0);
498
+
499
+ auto stream1 = scheduler.CreateStream(std::addressof(producer1), 1, 2);
500
+
501
+ stream1->MayMakeActive();
502
+
503
+ MockStreamProducer producer2;
504
+
505
+ producer2.PushBytesToSend(LargePacket); // MayMakeActive().
506
+ producer2.PushProduce(createChunk(3, 2, 200, LargePacket));
507
+ producer2.PushBytesToSend(LargePacket);
508
+ producer2.PushProduce(createChunk(4, 2, 201, LargePacket));
509
+ producer2.PushBytesToSend(LargePacket);
510
+ producer2.PushProduce(createChunk(5, 2, 202, LargePacket));
511
+ producer2.PushBytesToSend(0);
512
+
513
+ auto stream2 = scheduler.CreateStream(std::addressof(producer2), 2, 2);
514
+
515
+ stream2->MayMakeActive();
516
+
517
+ REQUIRE(checkDataToSendHasMid(scheduler.Produce(NowMs, Mtu), 100)); // t = 30
518
+ REQUIRE(checkDataToSendHasMid(scheduler.Produce(NowMs, Mtu), 101)); // t = 60
519
+ REQUIRE(checkDataToSendHasMid(scheduler.Produce(NowMs, Mtu), 200)); // t = 70
520
+ REQUIRE(checkDataToSendHasMid(scheduler.Produce(NowMs, Mtu), 102)); // t = 90
521
+ REQUIRE(checkDataToSendHasMid(scheduler.Produce(NowMs, Mtu), 201)); // t = 140
522
+ REQUIRE(checkDataToSendHasMid(scheduler.Produce(NowMs, Mtu), 202)); // t = 210
523
+ REQUIRE(!scheduler.Produce(NowMs, Mtu).has_value());
524
+ }
525
+
526
+ // Will do weighted fair queuing with three streams having different priority.
527
+ SECTION("will do weighted fair queuing with same size and different priority")
528
+ {
529
+ RTC::SCTP::StreamScheduler scheduler(Mtu);
530
+
531
+ scheduler.EnableMessageInterleaving(true);
532
+
533
+ MockStreamProducer producer1;
534
+
535
+ // Priority 125 -> allowed to produce every 1000/125 ~= 80 time units.
536
+ producer1.PushBytesToSend(PayloadLength); // MayMakeActive().
537
+ producer1.PushProduce(createChunk(0, 1, 100));
538
+ producer1.PushBytesToSend(PayloadLength);
539
+ producer1.PushProduce(createChunk(1, 1, 101));
540
+ producer1.PushBytesToSend(PayloadLength);
541
+ producer1.PushProduce(createChunk(2, 1, 102));
542
+ producer1.PushBytesToSend(0);
543
+
544
+ auto stream1 = scheduler.CreateStream(std::addressof(producer1), 1, 125);
545
+
546
+ stream1->MayMakeActive();
547
+
548
+ MockStreamProducer producer2;
549
+
550
+ // Priority 200 -> allowed to produce every 1000/200 ~= 50 time units.
551
+ producer2.PushBytesToSend(PayloadLength); // MayMakeActive().
552
+ producer2.PushProduce(createChunk(3, 2, 200));
553
+ producer2.PushBytesToSend(PayloadLength);
554
+ producer2.PushProduce(createChunk(4, 2, 201));
555
+ producer2.PushBytesToSend(PayloadLength);
556
+ producer2.PushProduce(createChunk(5, 2, 202));
557
+ producer2.PushBytesToSend(0);
558
+
559
+ auto stream2 = scheduler.CreateStream(std::addressof(producer2), 2, 200);
560
+
561
+ stream2->MayMakeActive();
562
+
563
+ MockStreamProducer producer3;
564
+
565
+ // Priority 500 -> allowed to produce every 1000/500 ~= 20 time units.
566
+ producer3.PushBytesToSend(PayloadLength); // MayMakeActive().
567
+ producer3.PushProduce(createChunk(6, 3, 300));
568
+ producer3.PushBytesToSend(PayloadLength);
569
+ producer3.PushProduce(createChunk(7, 3, 301));
570
+ producer3.PushBytesToSend(PayloadLength);
571
+ producer3.PushProduce(createChunk(8, 3, 302));
572
+ producer3.PushBytesToSend(0);
573
+
574
+ auto stream3 = scheduler.CreateStream(std::addressof(producer3), 3, 500);
575
+
576
+ stream3->MayMakeActive();
577
+
578
+ REQUIRE(checkDataToSendHasMid(scheduler.Produce(NowMs, Mtu), 300)); // t ~= 20
579
+ REQUIRE(checkDataToSendHasMid(scheduler.Produce(NowMs, Mtu), 301)); // t ~= 40
580
+ REQUIRE(checkDataToSendHasMid(scheduler.Produce(NowMs, Mtu), 200)); // t ~= 50
581
+ REQUIRE(checkDataToSendHasMid(scheduler.Produce(NowMs, Mtu), 302)); // t ~= 60
582
+ REQUIRE(checkDataToSendHasMid(scheduler.Produce(NowMs, Mtu), 100)); // t ~= 80
583
+ REQUIRE(checkDataToSendHasMid(scheduler.Produce(NowMs, Mtu), 201)); // t ~= 100
584
+ REQUIRE(checkDataToSendHasMid(scheduler.Produce(NowMs, Mtu), 202)); // t ~= 150
585
+ REQUIRE(checkDataToSendHasMid(scheduler.Produce(NowMs, Mtu), 101)); // t ~= 160
586
+ REQUIRE(checkDataToSendHasMid(scheduler.Produce(NowMs, Mtu), 102)); // t ~= 240
587
+ REQUIRE(!scheduler.Produce(NowMs, Mtu).has_value());
588
+ }
589
+
590
+ // Will do weighted fair queuing with three streams having different priority
591
+ // and sending different payload sizes.
592
+ SECTION("will do weighted fair queuing with different size and priority")
593
+ {
594
+ RTC::SCTP::StreamScheduler scheduler(Mtu);
595
+
596
+ scheduler.EnableMessageInterleaving(true);
597
+
598
+ constexpr size_t SmallPacket{ 20 };
599
+ constexpr size_t MediumPacket{ 50 };
600
+ constexpr size_t LargePacket{ 70 };
601
+
602
+ MockStreamProducer producer1;
603
+
604
+ // Stream with priority = 125 -> inverse weight ~= 80.
605
+ producer1.PushBytesToSend(MediumPacket); // MayMakeActive(); vft ~ 0 + 50*80 = 4000
606
+ producer1.PushProduce(createChunk(0, 1, 100, MediumPacket));
607
+ producer1.PushBytesToSend(SmallPacket); // vft ~ 4000 + 20*80 = 5600
608
+ producer1.PushProduce(createChunk(1, 1, 101, SmallPacket));
609
+ producer1.PushBytesToSend(LargePacket); // vft ~ 5600 + 70*80 = 11200
610
+ producer1.PushProduce(createChunk(2, 1, 102, LargePacket));
611
+ producer1.PushBytesToSend(0);
612
+
613
+ auto stream1 = scheduler.CreateStream(std::addressof(producer1), 1, 125);
614
+
615
+ stream1->MayMakeActive();
616
+
617
+ MockStreamProducer producer2;
618
+
619
+ // Stream with priority = 200 -> inverse weight ~= 50.
620
+ producer2.PushBytesToSend(MediumPacket); // MayMakeActive(); vft ~ 0 + 50*50 = 2500
621
+ producer2.PushProduce(createChunk(3, 2, 200, MediumPacket));
622
+ producer2.PushBytesToSend(LargePacket); // vft ~ 2500 + 70*50 = 6000
623
+ producer2.PushProduce(createChunk(4, 2, 201, LargePacket));
624
+ producer2.PushBytesToSend(SmallPacket); // vft ~ 6000 + 20*50 = 7000
625
+ producer2.PushProduce(createChunk(5, 2, 202, SmallPacket));
626
+ producer2.PushBytesToSend(0);
627
+
628
+ auto stream2 = scheduler.CreateStream(std::addressof(producer2), 2, 200);
629
+
630
+ stream2->MayMakeActive();
631
+
632
+ MockStreamProducer producer3;
633
+
634
+ // Stream with priority = 500 -> inverse weight ~= 20
635
+ producer3.PushBytesToSend(SmallPacket); // MayMakeActive; vft ~ 0 + 20*20 = 400
636
+ producer3.PushProduce(createChunk(6, 3, 300, SmallPacket));
637
+ producer3.PushBytesToSend(MediumPacket); // vft ~ 400 + 50*20 = 1400
638
+ producer3.PushProduce(createChunk(7, 3, 301, MediumPacket));
639
+ producer3.PushBytesToSend(LargePacket); // vft ~ 1400 + 70*20 = 2800
640
+ producer3.PushProduce(createChunk(8, 3, 302, LargePacket));
641
+ producer3.PushBytesToSend(0);
642
+
643
+ auto stream3 = scheduler.CreateStream(std::addressof(producer3), 3, 500);
644
+
645
+ stream3->MayMakeActive();
646
+
647
+ REQUIRE(checkDataToSendHasMid(scheduler.Produce(NowMs, Mtu), 300)); // t ~= 400
648
+ REQUIRE(checkDataToSendHasMid(scheduler.Produce(NowMs, Mtu), 301)); // t ~= 1400
649
+ REQUIRE(checkDataToSendHasMid(scheduler.Produce(NowMs, Mtu), 200)); // t ~= 2500
650
+ REQUIRE(checkDataToSendHasMid(scheduler.Produce(NowMs, Mtu), 302)); // t ~= 2800
651
+ REQUIRE(checkDataToSendHasMid(scheduler.Produce(NowMs, Mtu), 100)); // t ~= 4000
652
+ REQUIRE(checkDataToSendHasMid(scheduler.Produce(NowMs, Mtu), 101)); // t ~= 5600
653
+ REQUIRE(checkDataToSendHasMid(scheduler.Produce(NowMs, Mtu), 201)); // t ~= 6000
654
+ REQUIRE(checkDataToSendHasMid(scheduler.Produce(NowMs, Mtu), 202)); // t ~= 7000
655
+ REQUIRE(checkDataToSendHasMid(scheduler.Produce(NowMs, Mtu), 102)); // t ~= 11200
656
+ REQUIRE(!scheduler.Produce(NowMs, Mtu).has_value());
657
+ }
658
+
659
+ // Two streams of different priority, identical packet size: ratio of packets
660
+ // must match ratio of priorities.
661
+ SECTION("will distribute WFQ packets in two streams by priority")
662
+ {
663
+ RTC::SCTP::StreamScheduler scheduler(Mtu);
664
+
665
+ scheduler.EnableMessageInterleaving(true);
666
+
667
+ const TestStream stream1(scheduler, 1, 100);
668
+ const TestStream stream2(scheduler, 2, 200);
669
+
670
+ const auto packetCounts = getPacketCounts(scheduler, 15);
671
+
672
+ REQUIRE(packetCounts.at(1) == 5);
673
+ REQUIRE(packetCounts.at(2) == 10);
674
+ }
675
+
676
+ SECTION("will distribute WFQ packets in four streams by priority")
677
+ {
678
+ RTC::SCTP::StreamScheduler scheduler(Mtu);
679
+
680
+ scheduler.EnableMessageInterleaving(true);
681
+
682
+ const TestStream stream1(scheduler, 1, 100);
683
+ const TestStream stream2(scheduler, 2, 200);
684
+ const TestStream stream3(scheduler, 3, 300);
685
+ const TestStream stream4(scheduler, 4, 400);
686
+
687
+ const auto packetCounts = getPacketCounts(scheduler, 50);
688
+
689
+ REQUIRE(packetCounts.at(1) == 5);
690
+ REQUIRE(packetCounts.at(2) == 10);
691
+ REQUIRE(packetCounts.at(3) == 15);
692
+ REQUIRE(packetCounts.at(4) == 20);
693
+ }
694
+
695
+ // A simple test with two streams of different priority, but sending packets
696
+ // of different size. Verifies that the ratio of total packet payload
697
+ // represents their priority.
698
+ //
699
+ // In this example,
700
+ // - stream1 has priority 100 and sends packets of size 8.
701
+ // -stream2 has priority 400 and sends packets of size 4.
702
+ //
703
+ // With round robin, stream1 would get twice as many payload bytes on the wire
704
+ // as stream2, but with WFQ and a 4x priority increase, stream2 should 4x as
705
+ // many payload bytes on the wire. That translates to stream2 getting 8x as
706
+ // many packets on the wire as they are half as large.
707
+ SECTION("will distribute from two streams fairly")
708
+ {
709
+ RTC::SCTP::StreamScheduler scheduler(Mtu);
710
+
711
+ scheduler.EnableMessageInterleaving(true);
712
+
713
+ const TestStream stream1(scheduler, 1, 100, /*packetLength*/ 8);
714
+ const TestStream stream2(scheduler, 2, 400, /*packetLength*/ 4);
715
+
716
+ const auto packetCounts = getPacketCounts(scheduler, 90);
717
+
718
+ REQUIRE(packetCounts.at(1) == 10);
719
+ REQUIRE(packetCounts.at(2) == 80);
720
+ }
721
+ }