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