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

In change https://webrtc-review.googlesource.com/c/src/+/319961, I changed a error. Also the same code will be added for video to enable Glass 2 Glass metric for Android. To me it make sense to add this method, and then change the audio code and video code to use it. Bug: None Change-Id: Id5d38c3bb8266213a93e67ceb82e88d65f29de53 Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/320080 Reviewed-by: Danil Chapovalov <danilchap@webrtc.org> Commit-Queue: Olov Brändström <brandstrom@google.com> Cr-Commit-Position: refs/heads/main@{#40745}
79 lines
3.1 KiB
C++
79 lines
3.1 KiB
C++
/*
|
|
* Copyright (c) 2021 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/rtp_rtcp/source/capture_clock_offset_updater.h"
|
|
|
|
#include "system_wrappers/include/ntp_time.h"
|
|
#include "test/gmock.h"
|
|
#include "test/gtest.h"
|
|
|
|
namespace webrtc {
|
|
|
|
TEST(AbsoluteCaptureTimeReceiverTest,
|
|
SkipEstimatedCaptureClockOffsetIfRemoteToLocalClockOffsetIsUnknown) {
|
|
static const absl::optional<int64_t> kRemoteCaptureClockOffset =
|
|
Int64MsToQ32x32(-350);
|
|
CaptureClockOffsetUpdater updater;
|
|
updater.SetRemoteToLocalClockOffset(absl::nullopt);
|
|
EXPECT_EQ(
|
|
updater.AdjustEstimatedCaptureClockOffset(kRemoteCaptureClockOffset),
|
|
absl::nullopt);
|
|
}
|
|
|
|
TEST(AbsoluteCaptureTimeReceiverTest,
|
|
SkipEstimatedCaptureClockOffsetIfRemoteCaptureClockOffsetIsUnknown) {
|
|
static const absl::optional<int64_t> kCaptureClockOffsetNull = absl::nullopt;
|
|
CaptureClockOffsetUpdater updater;
|
|
updater.SetRemoteToLocalClockOffset(0);
|
|
EXPECT_EQ(updater.AdjustEstimatedCaptureClockOffset(kCaptureClockOffsetNull),
|
|
kCaptureClockOffsetNull);
|
|
|
|
static const absl::optional<int64_t> kRemoteCaptureClockOffset =
|
|
Int64MsToQ32x32(-350);
|
|
EXPECT_EQ(
|
|
updater.AdjustEstimatedCaptureClockOffset(kRemoteCaptureClockOffset),
|
|
kRemoteCaptureClockOffset);
|
|
}
|
|
|
|
TEST(AbsoluteCaptureTimeReceiverTest, EstimatedCaptureClockOffsetArithmetic) {
|
|
static const absl::optional<int64_t> kRemoteCaptureClockOffset =
|
|
Int64MsToQ32x32(-350);
|
|
static const absl::optional<int64_t> kRemoteToLocalClockOffset =
|
|
Int64MsToQ32x32(-7000007);
|
|
CaptureClockOffsetUpdater updater;
|
|
updater.SetRemoteToLocalClockOffset(kRemoteToLocalClockOffset);
|
|
EXPECT_THAT(
|
|
updater.AdjustEstimatedCaptureClockOffset(kRemoteCaptureClockOffset),
|
|
::testing::Optional(::testing::Eq(*kRemoteCaptureClockOffset +
|
|
*kRemoteToLocalClockOffset)));
|
|
}
|
|
|
|
TEST(AbsoluteCaptureTimeReceiverTest, ConvertClockOffset) {
|
|
constexpr TimeDelta kNegative = TimeDelta::Millis(-350);
|
|
constexpr int64_t kNegativeQ32x32 =
|
|
kNegative.ms() * (NtpTime::kFractionsPerSecond / 1000);
|
|
constexpr TimeDelta kPositive = TimeDelta::Millis(400);
|
|
constexpr int64_t kPositiveQ32x32 =
|
|
kPositive.ms() * (NtpTime::kFractionsPerSecond / 1000);
|
|
constexpr TimeDelta kEpsilon = TimeDelta::Millis(1);
|
|
absl::optional<TimeDelta> converted =
|
|
CaptureClockOffsetUpdater::ConvertsToTimeDela(kNegativeQ32x32);
|
|
EXPECT_GT(converted, kNegative - kEpsilon);
|
|
EXPECT_LT(converted, kNegative + kEpsilon);
|
|
|
|
converted = CaptureClockOffsetUpdater::ConvertsToTimeDela(kPositiveQ32x32);
|
|
EXPECT_GT(converted, kPositive - kEpsilon);
|
|
EXPECT_LT(converted, kPositive + kEpsilon);
|
|
|
|
EXPECT_FALSE(
|
|
CaptureClockOffsetUpdater::ConvertsToTimeDela(absl::nullopt).has_value());
|
|
}
|
|
|
|
} // namespace webrtc
|