blob: a1a679fe258ec0c915a92b6a09be75057be4a527 [file] [log] [blame]
/*
* Copyright (c) 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.
*/
#include "modules/audio_processing/aec3/skew_estimator.h"
#include "test/gtest.h"
namespace webrtc {
namespace aec3 {
// Tests that the skew ends up as it should after a skew change.
TEST(SkewEstimator, SkewChangeAdaptation) {
constexpr int kNumSkewsLog2 = 7;
constexpr int kNumSkews = 1 << kNumSkewsLog2;
SkewEstimator estimator(kNumSkewsLog2);
for (int k = 0; k < kNumSkews - 1; ++k) {
estimator.LogRenderCall();
auto skew = estimator.GetSkewFromCapture();
EXPECT_FALSE(skew);
}
estimator.LogRenderCall();
rtc::Optional<int> skew;
for (int k = 0; k < kNumSkews; ++k) {
estimator.LogRenderCall();
skew = estimator.GetSkewFromCapture();
EXPECT_TRUE(skew);
}
EXPECT_EQ(1, *skew);
estimator.LogRenderCall();
for (int k = 0; k < kNumSkews; ++k) {
estimator.LogRenderCall();
skew = estimator.GetSkewFromCapture();
EXPECT_TRUE(skew);
}
EXPECT_EQ(2, *skew);
}
// Tests that the skew ends up as it should for a surplus of render calls.
TEST(SkewEstimator, SkewForSurplusRender) {
constexpr int kNumSkewsLog2 = 7;
constexpr int kNumSkews = 1 << kNumSkewsLog2;
SkewEstimator estimator(kNumSkewsLog2);
for (int k = 0; k < kNumSkews - 1; ++k) {
estimator.LogRenderCall();
auto skew = estimator.GetSkewFromCapture();
EXPECT_FALSE(skew);
}
estimator.LogRenderCall();
rtc::Optional<int> skew;
for (int k = 0; k < kNumSkews; ++k) {
estimator.LogRenderCall();
skew = estimator.GetSkewFromCapture();
EXPECT_TRUE(skew);
}
EXPECT_EQ(1, *skew);
}
// Tests that the skew ends up as it should for a surplus of capture calls.
TEST(SkewEstimator, SkewForSurplusCapture) {
constexpr int kNumSkewsLog2 = 7;
constexpr int kNumSkews = 1 << kNumSkewsLog2;
SkewEstimator estimator(kNumSkewsLog2);
for (int k = 0; k < kNumSkews - 1; ++k) {
estimator.LogRenderCall();
auto skew = estimator.GetSkewFromCapture();
EXPECT_FALSE(skew);
}
rtc::Optional<int> skew;
skew = estimator.GetSkewFromCapture();
for (int k = 0; k < kNumSkews; ++k) {
estimator.LogRenderCall();
skew = estimator.GetSkewFromCapture();
EXPECT_TRUE(skew);
}
EXPECT_EQ(-1, *skew);
}
// Tests that the skew estimator returns a null optional when it should.
TEST(SkewEstimator, NullEstimate) {
constexpr int kNumSkewsLog2 = 4;
constexpr int kNumSkews = 1 << kNumSkewsLog2;
SkewEstimator estimator(kNumSkewsLog2);
for (int k = 0; k < kNumSkews - 1; ++k) {
estimator.LogRenderCall();
auto skew = estimator.GetSkewFromCapture();
EXPECT_FALSE(skew);
}
estimator.LogRenderCall();
auto skew = estimator.GetSkewFromCapture();
EXPECT_TRUE(skew);
estimator.Reset();
for (int k = 0; k < kNumSkews - 1; ++k) {
estimator.LogRenderCall();
auto skew = estimator.GetSkewFromCapture();
EXPECT_FALSE(skew);
}
}
} // namespace aec3
} // namespace webrtc