This reverts commit f2a083f262d86737893e774c696716742fcab3e3. Reason for revert: Test problem fixed in https://webrtc-review.googlesource.com/c/src/+/291333. Original change's description: > Revert "Delete PacketReceiver::DeliverPacket from all implementations" > > This reverts commit 897ea04db5db2e591e28bd884191be58d9bcdc63. > > Reason for revert: Speculative revert as it could be the reason why perf tests started failing: https://ci.chromium.org/p/webrtc/g/perf/console?limit=200 > > Original change's description: > > Delete PacketReceiver::DeliverPacket from all implementations > > > > And fix tests that still depend on extensions to be known by the receiver. > > > > Change-Id: I62227829af81af07769189e547f1cdb8ed4d06b3 > > > > Bug: webrtc:7135,webrtc:14795 > > Change-Id: I62227829af81af07769189e547f1cdb8ed4d06b3 > > Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/290996 > > Commit-Queue: Per Kjellander <perkj@webrtc.org> > > Reviewed-by: Danil Chapovalov <danilchap@webrtc.org> > > Reviewed-by: Erik Språng <sprang@webrtc.org> > > Cr-Commit-Position: refs/heads/main@{#39184} > > Bug: webrtc:7135,webrtc:14795,b/266658815 > Change-Id: I9d03f4952938d176ffee110a707acadc1846457c > No-Presubmit: true > No-Tree-Checks: true > No-Try: true > Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/291400 > Commit-Queue: Andrey Logvin <landrey@webrtc.org> > Bot-Commit: rubber-stamper@appspot.gserviceaccount.com <rubber-stamper@appspot.gserviceaccount.com> > Owners-Override: Andrey Logvin <landrey@webrtc.org> > Reviewed-by: Jeremy Leconte <jleconte@google.com> > Cr-Commit-Position: refs/heads/main@{#39189} Bug: webrtc:7135,webrtc:14795,b/266658815 Change-Id: Ia640f4342a1f42012ba5295003e17aef7613ad80 Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/291440 Reviewed-by: Erik Språng <sprang@webrtc.org> Reviewed-by: Andrey Logvin <landrey@webrtc.org> Commit-Queue: Per Kjellander <perkj@webrtc.org> Cr-Commit-Position: refs/heads/main@{#39199}
87 lines
2.7 KiB
C++
87 lines
2.7 KiB
C++
/*
|
|
* Copyright (c) 2013 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 TEST_DIRECT_TRANSPORT_H_
|
|
#define TEST_DIRECT_TRANSPORT_H_
|
|
|
|
#include <memory>
|
|
|
|
#include "api/call/transport.h"
|
|
#include "api/sequence_checker.h"
|
|
#include "api/task_queue/task_queue_base.h"
|
|
#include "api/test/simulated_network.h"
|
|
#include "call/call.h"
|
|
#include "call/simulated_packet_receiver.h"
|
|
#include "rtc_base/synchronization/mutex.h"
|
|
#include "rtc_base/task_utils/repeating_task.h"
|
|
#include "rtc_base/thread_annotations.h"
|
|
|
|
namespace webrtc {
|
|
|
|
class PacketReceiver;
|
|
|
|
namespace test {
|
|
class Demuxer {
|
|
public:
|
|
explicit Demuxer(const std::map<uint8_t, MediaType>& payload_type_map);
|
|
~Demuxer() = default;
|
|
|
|
Demuxer(const Demuxer&) = delete;
|
|
Demuxer& operator=(const Demuxer&) = delete;
|
|
|
|
MediaType GetMediaType(const uint8_t* packet_data,
|
|
size_t packet_length) const;
|
|
const std::map<uint8_t, MediaType> payload_type_map_;
|
|
};
|
|
|
|
// Objects of this class are expected to be allocated and destroyed on the
|
|
// same task-queue - the one that's passed in via the constructor.
|
|
class DirectTransport : public Transport {
|
|
public:
|
|
DirectTransport(TaskQueueBase* task_queue,
|
|
std::unique_ptr<SimulatedPacketReceiverInterface> pipe,
|
|
Call* send_call,
|
|
const std::map<uint8_t, MediaType>& payload_type_map,
|
|
rtc::ArrayView<const RtpExtension> audio_extensions,
|
|
rtc::ArrayView<const RtpExtension> video_extensions);
|
|
|
|
~DirectTransport() override;
|
|
|
|
// TODO(holmer): Look into moving this to the constructor.
|
|
virtual void SetReceiver(PacketReceiver* receiver);
|
|
|
|
bool SendRtp(const uint8_t* data,
|
|
size_t length,
|
|
const PacketOptions& options) override;
|
|
bool SendRtcp(const uint8_t* data, size_t length) override;
|
|
|
|
int GetAverageDelayMs();
|
|
|
|
private:
|
|
void ProcessPackets() RTC_EXCLUSIVE_LOCKS_REQUIRED(&process_lock_);
|
|
void LegacySendPacket(const uint8_t* data, size_t length);
|
|
void Start();
|
|
|
|
Call* const send_call_;
|
|
|
|
TaskQueueBase* const task_queue_;
|
|
|
|
Mutex process_lock_;
|
|
RepeatingTaskHandle next_process_task_ RTC_GUARDED_BY(&process_lock_);
|
|
|
|
const Demuxer demuxer_;
|
|
const std::unique_ptr<SimulatedPacketReceiverInterface> fake_network_;
|
|
const RtpHeaderExtensionMap audio_extensions_;
|
|
const RtpHeaderExtensionMap video_extensions_;
|
|
};
|
|
} // namespace test
|
|
} // namespace webrtc
|
|
|
|
#endif // TEST_DIRECT_TRANSPORT_H_
|