123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596 |
- /*
- * Copyright (c) 2018 The WebRTC project authors. All Rights Reserved.
- *
- * Use of this source code is governed by a BSD-style license
- * that can be found in the LICENSE file in the root of the source
- * tree. An additional intellectual property rights grant can be found
- * in the file PATENTS. All contributing project authors may
- * be found in the AUTHORS file in the root of the source tree.
- */
- #ifndef API_TEST_SIMULATED_NETWORK_H_
- #define API_TEST_SIMULATED_NETWORK_H_
- #include <stddef.h>
- #include <stdint.h>
- #include <deque>
- #include <queue>
- #include <vector>
- #include "absl/types/optional.h"
- #include "rtc_base/random.h"
- #include "rtc_base/thread_annotations.h"
- namespace webrtc {
- struct PacketInFlightInfo {
- PacketInFlightInfo(size_t size, int64_t send_time_us, uint64_t packet_id)
- : size(size), send_time_us(send_time_us), packet_id(packet_id) {}
- size_t size;
- int64_t send_time_us;
- // Unique identifier for the packet in relation to other packets in flight.
- uint64_t packet_id;
- };
- struct PacketDeliveryInfo {
- static constexpr int kNotReceived = -1;
- PacketDeliveryInfo(PacketInFlightInfo source, int64_t receive_time_us)
- : receive_time_us(receive_time_us), packet_id(source.packet_id) {}
- int64_t receive_time_us;
- uint64_t packet_id;
- };
- // BuiltInNetworkBehaviorConfig is a built-in network behavior configuration
- // for built-in network behavior that will be used by WebRTC if no custom
- // NetworkBehaviorInterface is provided.
- struct BuiltInNetworkBehaviorConfig {
- BuiltInNetworkBehaviorConfig() {}
- // Queue length in number of packets.
- size_t queue_length_packets = 0;
- // Delay in addition to capacity induced delay.
- int queue_delay_ms = 0;
- // Standard deviation of the extra delay.
- int delay_standard_deviation_ms = 0;
- // Link capacity in kbps.
- int link_capacity_kbps = 0;
- // Random packet loss.
- int loss_percent = 0;
- // If packets are allowed to be reordered.
- bool allow_reordering = false;
- // The average length of a burst of lost packets.
- int avg_burst_loss_length = -1;
- // Additional bytes to add to packet size.
- int packet_overhead = 0;
- // Enable CoDel active queue management.
- bool codel_active_queue_management = false;
- };
- class NetworkBehaviorInterface {
- public:
- virtual bool EnqueuePacket(PacketInFlightInfo packet_info) = 0;
- // Retrieves all packets that should be delivered by the given receive time.
- virtual std::vector<PacketDeliveryInfo> DequeueDeliverablePackets(
- int64_t receive_time_us) = 0;
- // Returns time in microseconds when caller should call
- // DequeueDeliverablePackets to get next set of packets to deliver.
- virtual absl::optional<int64_t> NextDeliveryTimeUs() const = 0;
- virtual ~NetworkBehaviorInterface() = default;
- };
- // Class simulating a network link. This is a simple and naive solution just
- // faking capacity and adding an extra transport delay in addition to the
- // capacity introduced delay.
- class SimulatedNetworkInterface : public NetworkBehaviorInterface {
- public:
- // Sets a new configuration. This won't affect packets already in the pipe.
- virtual void SetConfig(const BuiltInNetworkBehaviorConfig& config) = 0;
- virtual void UpdateConfig(
- std::function<void(BuiltInNetworkBehaviorConfig*)> config_modifier) = 0;
- virtual void PauseTransmissionUntil(int64_t until_us) = 0;
- };
- } // namespace webrtc
- #endif // API_TEST_SIMULATED_NETWORK_H_
|