webrtc/modules/rtp_rtcp/source/capture_clock_offset_updater_unittest.cc
Olov Brändström 0efb8323d5 Method for converting q32 to TimeDelta in capture clock offset updater
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}
2023-09-13 18:37:22 +00:00

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