/* * 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 kRemoteCaptureClockOffset = Int64MsToQ32x32(-350); CaptureClockOffsetUpdater updater; updater.SetRemoteToLocalClockOffset(absl::nullopt); EXPECT_EQ( updater.AdjustEstimatedCaptureClockOffset(kRemoteCaptureClockOffset), absl::nullopt); } TEST(AbsoluteCaptureTimeReceiverTest, SkipEstimatedCaptureClockOffsetIfRemoteCaptureClockOffsetIsUnknown) { static const absl::optional kCaptureClockOffsetNull = absl::nullopt; CaptureClockOffsetUpdater updater; updater.SetRemoteToLocalClockOffset(0); EXPECT_EQ(updater.AdjustEstimatedCaptureClockOffset(kCaptureClockOffsetNull), kCaptureClockOffsetNull); static const absl::optional kRemoteCaptureClockOffset = Int64MsToQ32x32(-350); EXPECT_EQ( updater.AdjustEstimatedCaptureClockOffset(kRemoteCaptureClockOffset), kRemoteCaptureClockOffset); } TEST(AbsoluteCaptureTimeReceiverTest, EstimatedCaptureClockOffsetArithmetic) { static const absl::optional kRemoteCaptureClockOffset = Int64MsToQ32x32(-350); static const absl::optional 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 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