Reland "Make cricket::SctpTransportInternalFactory injectable through PeerConnectionFactory Deps"
This is to allow testing without using the singleton sctp library. cricket::SctpTransportInternalFactory is renamed to webrtc::SctpTransportFactoryInterface and moved to the API folder to follow the API structure. Tests can use test/pc/sctp/fake_sctp_transport.h to inject a faked data channel implementation. patch 1 contain the original cl. patch 2 modifications Bug: none Change-Id: Ic088da3eb7d9aada79e6d601dbf2d1aa2be777f6 Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/182840 Reviewed-by: Taylor <deadbeef@webrtc.org> Reviewed-by: Mirko Bonadei <mbonadei@webrtc.org> Reviewed-by: Erik Språng <sprang@webrtc.org> Commit-Queue: Per Kjellander <perkj@webrtc.org> Cr-Commit-Position: refs/heads/master@{#32024}
This commit is contained in:
committed by
Commit Bot
parent
e537e9ca13
commit
2bca008914
@ -1,69 +0,0 @@
|
||||
/*
|
||||
* Copyright 2017 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 PC_TEST_FAKE_SCTP_TRANSPORT_H_
|
||||
#define PC_TEST_FAKE_SCTP_TRANSPORT_H_
|
||||
|
||||
#include <memory>
|
||||
|
||||
#include "media/sctp/sctp_transport_internal.h"
|
||||
|
||||
// Used for tests in this file to verify that PeerConnection responds to signals
|
||||
// from the SctpTransport correctly, and calls Start with the correct
|
||||
// local/remote ports.
|
||||
class FakeSctpTransport : public cricket::SctpTransportInternal {
|
||||
public:
|
||||
void SetDtlsTransport(rtc::PacketTransportInternal* transport) override {}
|
||||
bool Start(int local_port, int remote_port, int max_message_size) override {
|
||||
local_port_.emplace(local_port);
|
||||
remote_port_.emplace(remote_port);
|
||||
max_message_size_ = max_message_size;
|
||||
return true;
|
||||
}
|
||||
bool OpenStream(int sid) override { return true; }
|
||||
bool ResetStream(int sid) override { return true; }
|
||||
bool SendData(const cricket::SendDataParams& params,
|
||||
const rtc::CopyOnWriteBuffer& payload,
|
||||
cricket::SendDataResult* result = nullptr) override {
|
||||
return true;
|
||||
}
|
||||
bool ReadyToSendData() override { return true; }
|
||||
void set_debug_name_for_testing(const char* debug_name) override {}
|
||||
|
||||
int max_message_size() const { return max_message_size_; }
|
||||
absl::optional<int> max_outbound_streams() const { return absl::nullopt; }
|
||||
absl::optional<int> max_inbound_streams() const { return absl::nullopt; }
|
||||
int local_port() const { return *local_port_; }
|
||||
int remote_port() const { return *remote_port_; }
|
||||
|
||||
private:
|
||||
absl::optional<int> local_port_;
|
||||
absl::optional<int> remote_port_;
|
||||
int max_message_size_;
|
||||
};
|
||||
|
||||
class FakeSctpTransportFactory : public cricket::SctpTransportInternalFactory {
|
||||
public:
|
||||
std::unique_ptr<cricket::SctpTransportInternal> CreateSctpTransport(
|
||||
rtc::PacketTransportInternal*) override {
|
||||
last_fake_sctp_transport_ = new FakeSctpTransport();
|
||||
return std::unique_ptr<cricket::SctpTransportInternal>(
|
||||
last_fake_sctp_transport_);
|
||||
}
|
||||
|
||||
FakeSctpTransport* last_fake_sctp_transport() {
|
||||
return last_fake_sctp_transport_;
|
||||
}
|
||||
|
||||
private:
|
||||
FakeSctpTransport* last_fake_sctp_transport_ = nullptr;
|
||||
};
|
||||
|
||||
#endif // PC_TEST_FAKE_SCTP_TRANSPORT_H_
|
||||
Reference in New Issue
Block a user