webrtc/pc/test/mock_data_channel.h
Philipp Hancke 423faa6067 stats: do not expose dataChannelIdentifier before it is set
filtering out the -1 value as it is done for "legacy" stats.
Also change the protocol and don't use "udp" and "tcp" which are misleading since the datachannel protocol is user-supplied.

BUG=webrtc:15071

Change-Id: I45d735fcf30144969630f5b8a91b40f12585bbfd
Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/300483
Commit-Queue: Philipp Hancke <phancke@microsoft.com>
Reviewed-by: Henrik Boström <hbos@webrtc.org>
Reviewed-by: Harald Alvestrand <hta@webrtc.org>
Cr-Commit-Position: refs/heads/main@{#40333}
2023-06-22 09:28:40 +00:00

79 lines
2.9 KiB
C++

/*
* Copyright 2016 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_MOCK_DATA_CHANNEL_H_
#define PC_TEST_MOCK_DATA_CHANNEL_H_
#include <string>
#include <utility>
#include "pc/sctp_data_channel.h"
#include "test/gmock.h"
namespace webrtc {
class MockSctpDataChannel : public SctpDataChannel {
public:
MockSctpDataChannel(
rtc::WeakPtr<SctpDataChannelControllerInterface> controller,
int id,
DataState state)
: MockSctpDataChannel(std::move(controller),
id,
"MockSctpDataChannel",
state,
"someProtocol",
0,
0,
0,
0) {}
MockSctpDataChannel(
rtc::WeakPtr<SctpDataChannelControllerInterface> controller,
int id,
const std::string& label,
DataState state,
const std::string& protocol,
uint32_t messages_sent,
uint64_t bytes_sent,
uint32_t messages_received,
uint64_t bytes_received,
const InternalDataChannelInit& config = InternalDataChannelInit(),
rtc::Thread* signaling_thread = rtc::Thread::Current(),
rtc::Thread* network_thread = rtc::Thread::Current())
: SctpDataChannel(config,
std::move(controller),
label,
false,
signaling_thread,
network_thread) {
EXPECT_CALL(*this, id()).WillRepeatedly(::testing::Return(id));
EXPECT_CALL(*this, state()).WillRepeatedly(::testing::Return(state));
EXPECT_CALL(*this, protocol()).WillRepeatedly(::testing::Return(protocol));
EXPECT_CALL(*this, messages_sent())
.WillRepeatedly(::testing::Return(messages_sent));
EXPECT_CALL(*this, bytes_sent())
.WillRepeatedly(::testing::Return(bytes_sent));
EXPECT_CALL(*this, messages_received())
.WillRepeatedly(::testing::Return(messages_received));
EXPECT_CALL(*this, bytes_received())
.WillRepeatedly(::testing::Return(bytes_received));
}
MOCK_METHOD(int, id, (), (const, override));
MOCK_METHOD(DataState, state, (), (const, override));
MOCK_METHOD(std::string, protocol, (), (const, override));
MOCK_METHOD(uint32_t, messages_sent, (), (const, override));
MOCK_METHOD(uint64_t, bytes_sent, (), (const, override));
MOCK_METHOD(uint32_t, messages_received, (), (const, override));
MOCK_METHOD(uint64_t, bytes_received, (), (const, override));
};
} // namespace webrtc
#endif // PC_TEST_MOCK_DATA_CHANNEL_H_