Create a simulated time benchmark (with packet loss) for DtlsInStun and PQC

The submitted version is *not* run automatically, only when specifying
--bench_iterations=100.

It is to be considered a development/debugging tool.

It currently tests these configurations,
which could be a tentative release plan.

a) DTLS1.2
b) DTLS1.3
c) DTLS1.3 + PQC + DTLS-IN-STUN

The test runs each of this configuration in a set of different
environments, e.g packet loss, server candidates etc and numbers
look great, if rolled out like above, i.e. launch dtls-in-stun
and the same time as PQC.

sh> out/Release/rtc_p2p_unittests --gtest_filter='*Bench*/*' --bench_iterations=25 --bench_server_candidates=1  2>&1 | grep RES
(dtls_ice_integrationtest.cc:942): loss: 0 server_interface_count: 1 [ client: [ dtls: client/1.2 ice: controlling pqc: 0 dtls_in_stun: 0  ][ server: [ dtls: server/1.2 ice: controlled pqc: 0 dtls_in_stun: 0  ]] RESULT: p10: 850 p50: 850 avg: 850 p95: 850
(dtls_ice_integrationtest.cc:942): loss: 0 server_interface_count: 1 [ client: [ dtls: client/1.3 ice: controlling pqc: 0 dtls_in_stun: 0  ][ server: [ dtls: server/1.3 ice: controlled pqc: 0 dtls_in_stun: 0  ]] RESULT: p10: 750 p50: 750 avg: 750 p95: 750
(dtls_ice_integrationtest.cc:942): loss: 0 server_interface_count: 1 [ client: [ dtls: client/1.3 ice: controlling pqc: 1 dtls_in_stun: 1  ][ server: [ dtls: server/1.3 ice: controlled pqc: 1 dtls_in_stun: 1  ]] RESULT: p10: 650 p50: 650 avg: 650 p95: 650

(dtls_ice_integrationtest.cc:942): loss: 5 server_interface_count: 1 [ client: [ dtls: client/1.2 ice: controlling pqc: 0 dtls_in_stun: 0  ][ server: [ dtls: server/1.2 ice: controlled pqc: 0 dtls_in_stun: 0  ]] RESULT: p10: 850 p50: 850 avg: 940 p95: 1300
(dtls_ice_integrationtest.cc:942): loss: 5 server_interface_count: 1 [ client: [ dtls: client/1.3 ice: controlling pqc: 0 dtls_in_stun: 0  ][ server: [ dtls: server/1.3 ice: controlled pqc: 0 dtls_in_stun: 0  ]] RESULT: p10: 750 p50: 750 avg: 838 p95: 1150
(dtls_ice_integrationtest.cc:942): loss: 5 server_interface_count: 1 [ client: [ dtls: client/1.3 ice: controlling pqc: 1 dtls_in_stun: 1  ][ server: [ dtls: server/1.3 ice: controlled pqc: 1 dtls_in_stun: 1  ]] RESULT: p10: 650 p50: 650 avg: 666 p95: 700

(dtls_ice_integrationtest.cc:942): loss: 10 server_interface_count: 1 [ client: [ dtls: client/1.2 ice: controlling pqc: 0 dtls_in_stun: 0  ][ server: [ dtls: server/1.2 ice: controlled pqc: 0 dtls_in_stun: 0  ]] RESULT: p10: 850 p50: 900 avg: 1106 p95: 2060
(dtls_ice_integrationtest.cc:942): loss: 10 server_interface_count: 1 [ client: [ dtls: client/1.3 ice: controlling pqc: 0 dtls_in_stun: 0  ][ server: [ dtls: server/1.3 ice: controlled pqc: 0 dtls_in_stun: 0  ]] RESULT: p10: 750 p50: 800 avg: 910 p95: 1200
(dtls_ice_integrationtest.cc:942): loss: 10 server_interface_count: 1 [ client: [ dtls: client/1.3 ice: controlling pqc: 1 dtls_in_stun: 1  ][ server: [ dtls: server/1.3 ice: controlled pqc: 1 dtls_in_stun: 1  ]] RESULT: p10: 650 p50: 650 avg: 702 p95: 840

(dtls_ice_integrationtest.cc:942): loss: 25 server_interface_count: 1 [ client: [ dtls: client/1.2 ice: controlling pqc: 0 dtls_in_stun: 0  ][ server: [ dtls: server/1.2 ice: controlled pqc: 0 dtls_in_stun: 0  ]] RESULT: p10: 870 p50: 1300 avg: 6208 p95: 11820
(dtls_ice_integrationtest.cc:942): loss: 25 server_interface_count: 1 [ client: [ dtls: client/1.3 ice: controlling pqc: 0 dtls_in_stun: 0  ][ server: [ dtls: server/1.3 ice: controlled pqc: 0 dtls_in_stun: 0  ]] RESULT: p10: 750 p50: 1300 avg: 1358 p95: 2420
(dtls_ice_integrationtest.cc:942): loss: 25 server_interface_count: 1 [ client: [ dtls: client/1.3 ice: controlling pqc: 1 dtls_in_stun: 1  ][ server: [ dtls: server/1.3 ice: controlled pqc: 1 dtls_in_stun: 1  ]] RESULT: p10: 650 p50: 750 avg: 942 p95: 1800

I.e. dtls-in-stun+pqc is faster then the other combinations even with
packet loss.

However, the test also shows that we still have bugs in the code!
sh> out/Release/rtc_p2p_unittests --gtest_filter='*Bench*/*' --bench_iterations=25 --bench_pct_loss=25 --bench_server_candidates=2  2>&1 | grep RES
(dtls_ice_integrationtest.cc:942): loss: 25 server_interface_count: 2 [ client: [ dtls: client/1.2 ice: controlling pqc: 0 dtls_in_stun: 0  ][ server: [ dtls: server/1.2 ice: controlled pqc: 0 dtls_in_stun: 0  ]] RESULT: p10: 870 p50: 1300 avg: 2488 p95: 8480
(dtls_ice_integrationtest.cc:942): loss: 25 server_interface_count: 2 [ client: [ dtls: client/1.3 ice: controlling pqc: 0 dtls_in_stun: 0  ][ server: [ dtls: server/1.3 ice: controlled pqc: 0 dtls_in_stun: 0  ]] RESULT: p10: 750 p50: 1200 avg: 1858 p95: 7600
(dtls_ice_integrationtest.cc:942): loss: 25 server_interface_count: 2 [ client: [ dtls: client/1.3 ice: controlling pqc: 1 dtls_in_stun: 1  ][ server: [ dtls: server/1.3 ice: controlled pqc: 1 dtls_in_stun: 1  ]] RESULT: p10: 650 p50: 950 avg: 6.91307e+06 p95: 6.91213e+07

Notice outlier!

BUG=webrtc:367395350

Change-Id: I44c0e1df33108d0078f1bf88804f48e1ce469b88
Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/432180
Commit-Queue: Jonas Oreland <jonaso@webrtc.org>
Reviewed-by: Harald Alvestrand <hta@webrtc.org>
Cr-Commit-Position: refs/heads/main@{#46439}
4 files changed
tree: e7f76f6bfa8f916633ff511b57d44a9883455cdd
  1. agents/
  2. api/
  3. audio/
  4. build_overrides/
  5. call/
  6. common_audio/
  7. common_video/
  8. data/
  9. docs/
  10. examples/
  11. experiments/
  12. g3doc/
  13. infra/
  14. logging/
  15. media/
  16. modules/
  17. net/
  18. p2p/
  19. pc/
  20. resources/
  21. rtc_base/
  22. rtc_tools/
  23. sdk/
  24. stats/
  25. system_wrappers/
  26. test/
  27. tools_webrtc/
  28. video/
  29. .clang-format
  30. .clang-tidy
  31. .git-blame-ignore-revs
  32. .gitignore
  33. .gn
  34. .mailmap
  35. .rustfmt.toml
  36. .style.yapf
  37. .vpython3
  38. AUTHORS
  39. BUILD.gn
  40. CODE_OF_CONDUCT.md
  41. codereview.settings
  42. DEPS
  43. DIR_METADATA
  44. ENG_REVIEW_OWNERS
  45. GEMINI.md
  46. LICENSE
  47. license_template.txt
  48. native-api.md
  49. OWNERS
  50. OWNERS_INFRA
  51. PATENTS
  52. PRESUBMIT.py
  53. presubmit_test.py
  54. presubmit_test_mocks.py
  55. pylintrc
  56. pylintrc_old_style
  57. README.chromium
  58. README.md
  59. WATCHLISTS
  60. webrtc.gni
  61. webrtc_lib_link_test.cc
  62. whitespace.txt
README.md

WebRTC is a free, open software project that provides browsers and mobile applications with Real-Time Communications (RTC) capabilities via simple APIs. The WebRTC components have been optimized to best serve this purpose.

Our mission: To enable rich, high-quality RTC applications to be developed for the browser, mobile platforms, and IoT devices, and allow them all to communicate via a common set of protocols.

The WebRTC initiative is a project supported by Google, Mozilla and Opera, amongst others.

Development

See here for instructions on how to get started developing with the native code.

Authoritative list of directories that contain the native API header files.

More info