mirror of
https://github.com/mollyim/webrtc.git
synced 2025-05-13 13:50:40 +01:00

This field trial is configured via command line flag, so may use flag system directly, reducing dependency on global field trial string. Bug: webrtc:7101, webrtc:10335 Change-Id: I1e48e0e3fdc251b73a375c6d7f1a46fa4f8a179b Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/322624 Reviewed-by: Mirko Bonadei <mbonadei@webrtc.org> Reviewed-by: Harald Alvestrand <hta@webrtc.org> Commit-Queue: Danil Chapovalov <danilchap@webrtc.org> Cr-Commit-Position: refs/heads/main@{#40897}
61 lines
2.4 KiB
C++
61 lines
2.4 KiB
C++
/*
|
|
* Copyright (c) 2014 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.
|
|
*/
|
|
|
|
#include "absl/flags/flag.h"
|
|
#include "api/test/metrics/global_metrics_logger_and_exporter.h"
|
|
#include "api/test/metrics/metric.h"
|
|
#include "modules/audio_coding/neteq/tools/neteq_performance_test.h"
|
|
#include "test/gtest.h"
|
|
#include "test/test_flags.h"
|
|
|
|
namespace webrtc {
|
|
namespace {
|
|
|
|
using ::webrtc::test::GetGlobalMetricsLogger;
|
|
using ::webrtc::test::ImprovementDirection;
|
|
using ::webrtc::test::Unit;
|
|
|
|
// Runs a test with 10% packet losses and 10% clock drift, to exercise
|
|
// both loss concealment and time-stretching code.
|
|
TEST(NetEqPerformanceTest, 10_Pl_10_Drift) {
|
|
const int kSimulationTimeMs = 10000000;
|
|
const int kQuickSimulationTimeMs = 100000;
|
|
const int kLossPeriod = 10; // Drop every 10th packet.
|
|
const double kDriftFactor = 0.1;
|
|
int64_t runtime = test::NetEqPerformanceTest::Run(
|
|
absl::GetFlag(FLAGS_webrtc_quick_perf_test) ? kQuickSimulationTimeMs
|
|
: kSimulationTimeMs,
|
|
kLossPeriod, kDriftFactor);
|
|
ASSERT_GT(runtime, 0);
|
|
GetGlobalMetricsLogger()->LogSingleValueMetric(
|
|
"neteq_performance", "10_pl_10_drift", runtime, Unit::kMilliseconds,
|
|
ImprovementDirection::kNeitherIsBetter);
|
|
}
|
|
|
|
// Runs a test with neither packet losses nor clock drift, to put
|
|
// emphasis on the "good-weather" code path, which is presumably much
|
|
// more lightweight.
|
|
TEST(NetEqPerformanceTest, 0_Pl_0_Drift) {
|
|
const int kSimulationTimeMs = 10000000;
|
|
const int kQuickSimulationTimeMs = 100000;
|
|
const int kLossPeriod = 0; // No losses.
|
|
const double kDriftFactor = 0.0; // No clock drift.
|
|
int64_t runtime = test::NetEqPerformanceTest::Run(
|
|
absl::GetFlag(FLAGS_webrtc_quick_perf_test) ? kQuickSimulationTimeMs
|
|
: kSimulationTimeMs,
|
|
kLossPeriod, kDriftFactor);
|
|
ASSERT_GT(runtime, 0);
|
|
GetGlobalMetricsLogger()->LogSingleValueMetric(
|
|
"neteq_performance", "0_pl_0_drift", runtime, Unit::kMilliseconds,
|
|
ImprovementDirection::kNeitherIsBetter);
|
|
}
|
|
|
|
} // namespace
|
|
} // namespace webrtc
|