blob: f05dae281d94d39b50b664365cc3fd3d1543e234 [file] [log] [blame]
/*
* 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