mirror of
https://github.com/mollyim/webrtc.git
synced 2025-05-20 00:57:49 +01:00

The new API stores events gathered by event type. For example, it is possible to ask for a list of all incoming RTCP messages or all audio playout events. The new API is experimental and may change over next few weeks. Once it has stabilized and all unit tests and existing tools have been ported to the new API, the old one will be removed. This CL also updates the event_log_visualizer tool to use the new parser API. This is not a funcional change except for: - Incoming and outgoing audio level are now drawn in two separate plots. - Incoming and outgoing timstamps are now drawn in two separate plots. - RTCP count is no longer split into Video and Audio. It also counts all RTCP packets rather than only specific message types. - Slight timing difference in sendside BWE simulation due to only iterating over transport feedbacks and not over all RTCP packets. This timing changes are not visible in the plots. Media type for RTCP messages might not be identified correctly by rtc_event_log2text anymore. On the other hand, assigning a specific media type to an RTCP packet was a bit hacky to begin with. Bug: webrtc:8111 Change-Id: Ib244338c86a2c1a010c668a7aba440482023b512 Reviewed-on: https://webrtc-review.googlesource.com/73140 Reviewed-by: Sebastian Jansson <srte@webrtc.org> Reviewed-by: Minyue Li <minyue@webrtc.org> Commit-Queue: Björn Terelius <terelius@webrtc.org> Cr-Commit-Position: refs/heads/master@{#23056}
93 lines
4 KiB
C++
93 lines
4 KiB
C++
/*
|
|
* Copyright (c) 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 LOGGING_RTC_EVENT_LOG_RTC_EVENT_LOG_UNITTEST_HELPER_H_
|
|
#define LOGGING_RTC_EVENT_LOG_RTC_EVENT_LOG_UNITTEST_HELPER_H_
|
|
|
|
#include "call/call.h"
|
|
#include "logging/rtc_event_log/rtc_event_log_parser_new.h"
|
|
#include "modules/rtp_rtcp/source/rtp_packet_received.h"
|
|
#include "modules/rtp_rtcp/source/rtp_packet_to_send.h"
|
|
|
|
namespace webrtc {
|
|
|
|
class RtcEventLogTestHelper {
|
|
public:
|
|
static void VerifyVideoReceiveStreamConfig(
|
|
const ParsedRtcEventLogNew& parsed_log,
|
|
size_t index,
|
|
const rtclog::StreamConfig& config);
|
|
static void VerifyVideoSendStreamConfig(
|
|
const ParsedRtcEventLogNew& parsed_log,
|
|
size_t index,
|
|
const rtclog::StreamConfig& config);
|
|
static void VerifyAudioReceiveStreamConfig(
|
|
const ParsedRtcEventLogNew& parsed_log,
|
|
size_t index,
|
|
const rtclog::StreamConfig& config);
|
|
static void VerifyAudioSendStreamConfig(
|
|
const ParsedRtcEventLogNew& parsed_log,
|
|
size_t index,
|
|
const rtclog::StreamConfig& config);
|
|
static void VerifyIncomingRtpEvent(const ParsedRtcEventLogNew& parsed_log,
|
|
size_t index,
|
|
const RtpPacketReceived& expected_packet);
|
|
static void VerifyOutgoingRtpEvent(const ParsedRtcEventLogNew& parsed_log,
|
|
size_t index,
|
|
const RtpPacketToSend& expected_packet);
|
|
static void VerifyRtcpEvent(const ParsedRtcEventLogNew& parsed_log,
|
|
size_t index,
|
|
PacketDirection direction,
|
|
const uint8_t* packet,
|
|
size_t total_size);
|
|
static void VerifyPlayoutEvent(const ParsedRtcEventLogNew& parsed_log,
|
|
size_t index,
|
|
uint32_t ssrc);
|
|
static void VerifyBweLossEvent(const ParsedRtcEventLogNew& parsed_log,
|
|
size_t index,
|
|
int32_t bitrate,
|
|
uint8_t fraction_loss,
|
|
int32_t total_packets);
|
|
static void VerifyBweDelayEvent(const ParsedRtcEventLogNew& parsed_log,
|
|
size_t index,
|
|
int32_t bitrate,
|
|
BandwidthUsage detector_state);
|
|
|
|
static void VerifyAudioNetworkAdaptation(
|
|
const ParsedRtcEventLogNew& parsed_log,
|
|
size_t index,
|
|
const AudioEncoderRuntimeConfig& config);
|
|
|
|
static void VerifyLogStartEvent(const ParsedRtcEventLogNew& parsed_log,
|
|
size_t index);
|
|
static void VerifyLogEndEvent(const ParsedRtcEventLogNew& parsed_log,
|
|
size_t index);
|
|
|
|
static void VerifyBweProbeCluster(const ParsedRtcEventLogNew& parsed_log,
|
|
size_t index,
|
|
uint32_t id,
|
|
uint32_t bitrate_bps,
|
|
uint32_t min_probes,
|
|
uint32_t min_bytes);
|
|
|
|
static void VerifyProbeResultSuccess(const ParsedRtcEventLogNew& parsed_log,
|
|
size_t index,
|
|
uint32_t id,
|
|
uint32_t bitrate_bps);
|
|
|
|
static void VerifyProbeResultFailure(const ParsedRtcEventLogNew& parsed_log,
|
|
size_t index,
|
|
uint32_t id,
|
|
ProbeFailureReason failure_reason);
|
|
};
|
|
|
|
} // namespace webrtc
|
|
|
|
#endif // LOGGING_RTC_EVENT_LOG_RTC_EVENT_LOG_UNITTEST_HELPER_H_
|