/* * Copyright (c) 2026 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 #include #include "logging/rtc_event_log/rtc_event_log_parser.h" #include "test/gtest.h" #include "video/timing/simulator/log_classifiers.h" #include "video/timing/simulator/test/parsed_rtc_event_log_from_resources.h" namespace webrtc::video_timing_simulator { namespace { // The tests in this file verify that the test resources logs have the expected // RTX OSN logging status. // // Logs prior to https://webrtc-review.googlesource.com/c/src/+/442320 should // be either std::nullopt (if no RTX recovery/padding was received), or // `kNoRtxOsnLogged` (if RTX was received). // // Logs after https://webrtc-review.googlesource.com/c/src/+/442320 should be // either std::nullopt (if no RTX recovery/padding was received), or // `kAllRtxOsnLogged` (if RTX was received). // Before https://webrtc-review.googlesource.com/c/src/+/442320. TEST(TestResourcesTest, VideoRecvVp8Pt96IsUnset) { std::unique_ptr parsed_log = ParsedRtcEventLogFromResources("video_recv_vp8_pt96"); EXPECT_EQ(GetRtxOsnLoggingStatus(*parsed_log), std::nullopt); } // After https://webrtc-review.googlesource.com/c/src/+/442320. TEST(TestResourcesTest, VideoRecvVp8Pt96LossyIskAllRtxOsnLogged) { std::unique_ptr parsed_log = ParsedRtcEventLogFromResources("video_recv_vp8_pt96_lossy"); EXPECT_EQ(GetRtxOsnLoggingStatus(*parsed_log), RtxOsnLoggingStatus::kAllRtxOsnLogged); } // Before https://webrtc-review.googlesource.com/c/src/+/442320. TEST(TestResourcesTest, VideoRecvVp9Pt98IskNoRtxOsnLogged) { std::unique_ptr parsed_log = ParsedRtcEventLogFromResources("video_recv_vp9_pt98"); EXPECT_EQ(GetRtxOsnLoggingStatus(*parsed_log), RtxOsnLoggingStatus::kNoRtxOsnLogged); } // Before https://webrtc-review.googlesource.com/c/src/+/442320. TEST(TestResourcesTest, VideoRecvAv1Pt45IskNoRtxOsnLogged) { std::unique_ptr parsed_log = ParsedRtcEventLogFromResources("video_recv_av1_pt45"); EXPECT_EQ(GetRtxOsnLoggingStatus(*parsed_log), RtxOsnLoggingStatus::kNoRtxOsnLogged); } // Before https://webrtc-review.googlesource.com/c/src/+/442320. TEST(TestResourcesTest, VideoRecvSequentialJoinVp8Vp9Av1IsUnset) { std::unique_ptr parsed_log = ParsedRtcEventLogFromResources("video_recv_sequential_join_vp8_vp9_av1"); EXPECT_EQ(GetRtxOsnLoggingStatus(*parsed_log), std::nullopt); } } // namespace } // namespace webrtc::video_timing_simulator