blob: fcac51f4ea9024fc9e1906c6ff68e007ef98810d [file] [log] [blame]
Patrik Höglundb6b29e02018-06-21 16:58:01 +02001/*
2 * Copyright (c) 2018 The WebRTC project authors. All Rights Reserved.
3 *
4 * Use of this source code is governed by a BSD-style license
5 * that can be found in the LICENSE file in the root of the source
6 * tree. An additional intellectual property rights grant can be found
7 * in the file PATENTS. All contributing project authors may
8 * be found in the AUTHORS file in the root of the source tree.
9 */
10
11#ifndef API_TEST_SIMULATED_NETWORK_H_
12#define API_TEST_SIMULATED_NETWORK_H_
13
14#include <stddef.h>
15#include <stdint.h>
Jonas Olssona4d87372019-07-05 19:08:33 +020016
Patrik Höglundb6b29e02018-06-21 16:58:01 +020017#include <deque>
18#include <queue>
19#include <vector>
20
Danil Chapovalov065a52a2018-07-09 10:58:54 +020021#include "absl/types/optional.h"
Patrik Höglundb6b29e02018-06-21 16:58:01 +020022#include "rtc_base/random.h"
23#include "rtc_base/thread_annotations.h"
24
25namespace webrtc {
26
27struct PacketInFlightInfo {
28 PacketInFlightInfo(size_t size, int64_t send_time_us, uint64_t packet_id)
29 : size(size), send_time_us(send_time_us), packet_id(packet_id) {}
30
31 size_t size;
32 int64_t send_time_us;
33 // Unique identifier for the packet in relation to other packets in flight.
34 uint64_t packet_id;
35};
36
37struct PacketDeliveryInfo {
38 static constexpr int kNotReceived = -1;
39 PacketDeliveryInfo(PacketInFlightInfo source, int64_t receive_time_us)
40 : receive_time_us(receive_time_us), packet_id(source.packet_id) {}
41 int64_t receive_time_us;
42 uint64_t packet_id;
43};
44
Artem Titov666fb322018-10-08 11:31:09 +020045// BuiltInNetworkBehaviorConfig is a built-in network behavior configuration
46// for built-in network behavior that will be used by WebRTC if no custom
Artem Titov24ee1672018-10-04 13:48:48 +020047// NetworkBehaviorInterface is provided.
Artem Titov666fb322018-10-08 11:31:09 +020048struct BuiltInNetworkBehaviorConfig {
Per Kjellander8623c752021-02-15 11:34:10 +010049 // Queue length in number of packets.
Artem Titove9721f22018-08-16 11:41:44 +020050 size_t queue_length_packets = 0;
51 // Delay in addition to capacity induced delay.
52 int queue_delay_ms = 0;
53 // Standard deviation of the extra delay.
54 int delay_standard_deviation_ms = 0;
55 // Link capacity in kbps.
56 int link_capacity_kbps = 0;
57 // Random packet loss.
58 int loss_percent = 0;
59 // If packets are allowed to be reordered.
60 bool allow_reordering = false;
61 // The average length of a burst of lost packets.
62 int avg_burst_loss_length = -1;
Sebastian Jansson8c8feb92019-01-29 15:59:17 +010063 // Additional bytes to add to packet size.
64 int packet_overhead = 0;
Sebastian Jansson2b08e312019-02-25 10:24:46 +010065 // Enable CoDel active queue management.
66 bool codel_active_queue_management = false;
Artem Titove9721f22018-08-16 11:41:44 +020067};
68
Artem Titov24ee1672018-10-04 13:48:48 +020069class NetworkBehaviorInterface {
Patrik Höglundb6b29e02018-06-21 16:58:01 +020070 public:
Patrik Höglundb6b29e02018-06-21 16:58:01 +020071 virtual bool EnqueuePacket(PacketInFlightInfo packet_info) = 0;
72 // Retrieves all packets that should be delivered by the given receive time.
73 virtual std::vector<PacketDeliveryInfo> DequeueDeliverablePackets(
74 int64_t receive_time_us) = 0;
Artem Titovc8e202f2018-08-27 14:59:29 +020075 // Returns time in microseconds when caller should call
76 // DequeueDeliverablePackets to get next set of packets to deliver.
Patrik Höglundb6b29e02018-06-21 16:58:01 +020077 virtual absl::optional<int64_t> NextDeliveryTimeUs() const = 0;
Artem Titov24ee1672018-10-04 13:48:48 +020078 virtual ~NetworkBehaviorInterface() = default;
Patrik Höglundb6b29e02018-06-21 16:58:01 +020079};
80
Sebastian Janssoncec24332019-12-04 14:26:50 +010081// Class simulating a network link. This is a simple and naive solution just
82// faking capacity and adding an extra transport delay in addition to the
83// capacity introduced delay.
84class SimulatedNetworkInterface : public NetworkBehaviorInterface {
85 public:
86 // Sets a new configuration. This won't affect packets already in the pipe.
87 virtual void SetConfig(const BuiltInNetworkBehaviorConfig& config) = 0;
Sebastian Jansson89eb0bb2020-03-13 17:47:38 +010088 virtual void UpdateConfig(
89 std::function<void(BuiltInNetworkBehaviorConfig*)> config_modifier) = 0;
Sebastian Janssoncec24332019-12-04 14:26:50 +010090 virtual void PauseTransmissionUntil(int64_t until_us) = 0;
91};
92
Patrik Höglundb6b29e02018-06-21 16:58:01 +020093} // namespace webrtc
94
95#endif // API_TEST_SIMULATED_NETWORK_H_