blob: aec300caa2b3e4fd8eb6eb29569b52cf81ec6574 [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>
16#include <deque>
17#include <queue>
18#include <vector>
19
Danil Chapovalov065a52a2018-07-09 10:58:54 +020020#include "absl/types/optional.h"
Patrik Höglundb6b29e02018-06-21 16:58:01 +020021#include "rtc_base/criticalsection.h"
22#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 Titov24ee1672018-10-04 13:48:48 +020045// DefaultNetworkSimulationConfig is a default network behavior configuration
46// for default network behavior that will be used by WebRTC if no custom
47// NetworkBehaviorInterface is provided.
Artem Titove9721f22018-08-16 11:41:44 +020048struct DefaultNetworkSimulationConfig {
49 DefaultNetworkSimulationConfig() {}
50 // Queue length in number of packets.
51 size_t queue_length_packets = 0;
52 // Delay in addition to capacity induced delay.
53 int queue_delay_ms = 0;
54 // Standard deviation of the extra delay.
55 int delay_standard_deviation_ms = 0;
56 // Link capacity in kbps.
57 int link_capacity_kbps = 0;
58 // Random packet loss.
59 int loss_percent = 0;
60 // If packets are allowed to be reordered.
61 bool allow_reordering = false;
62 // The average length of a burst of lost packets.
63 int avg_burst_loss_length = -1;
64};
65
Artem Titov24ee1672018-10-04 13:48:48 +020066class NetworkBehaviorInterface {
Patrik Höglundb6b29e02018-06-21 16:58:01 +020067 public:
Patrik Höglundb6b29e02018-06-21 16:58:01 +020068 virtual bool EnqueuePacket(PacketInFlightInfo packet_info) = 0;
69 // Retrieves all packets that should be delivered by the given receive time.
70 virtual std::vector<PacketDeliveryInfo> DequeueDeliverablePackets(
71 int64_t receive_time_us) = 0;
Artem Titovc8e202f2018-08-27 14:59:29 +020072 // Returns time in microseconds when caller should call
73 // DequeueDeliverablePackets to get next set of packets to deliver.
Patrik Höglundb6b29e02018-06-21 16:58:01 +020074 virtual absl::optional<int64_t> NextDeliveryTimeUs() const = 0;
Artem Titov24ee1672018-10-04 13:48:48 +020075 virtual ~NetworkBehaviorInterface() = default;
Patrik Höglundb6b29e02018-06-21 16:58:01 +020076};
77
Artem Titov24ee1672018-10-04 13:48:48 +020078// Deprecated. DO NOT USE. Use NetworkBehaviorInterface instead.
79using NetworkSimulationInterface = NetworkBehaviorInterface;
80
Patrik Höglundb6b29e02018-06-21 16:58:01 +020081} // namespace webrtc
82
83#endif // API_TEST_SIMULATED_NETWORK_H_