From 510eea10240a6a94878d7eed20c3dca882e908f6 Mon Sep 17 00:00:00 2001 From: Luke Frox <105777240+skywilliamsonl@users.noreply.github.com> Date: Wed, 18 Oct 2023 10:46:42 +0100 Subject: [PATCH] Increase preroll frames requested to 3 (#196) Summary: Increase frames requested before prerolling to speed up buffering of content after seek. Type: Bug Test Plan: Unittests, YtCert Progressive Test Suite (RIALTO-25, RIALTO-5) Jira: RIALTO-372 --- media/server/main/include/ShmUtils.h | 2 +- tests/media/server/main/mediaPipeline/CallbackTest.cpp | 2 +- tests/media/server/main/mediaPipeline/HaveDataTest.cpp | 2 +- .../server/main/mediaPipeline/MiscellaneousFunctionsTest.cpp | 4 ++-- .../server/main/needMediaData/NeedMediaDataTestsFixture.cpp | 2 +- 5 files changed, 6 insertions(+), 6 deletions(-) diff --git a/media/server/main/include/ShmUtils.h b/media/server/main/include/ShmUtils.h index 766eb7bac..ede9aa5a4 100644 --- a/media/server/main/include/ShmUtils.h +++ b/media/server/main/include/ShmUtils.h @@ -25,7 +25,7 @@ namespace firebolt::rialto::server { -constexpr std::uint32_t kPrerollNumFrames{1}; +constexpr std::uint32_t kPrerollNumFrames{3}; constexpr std::uint32_t kMaxFrames{24}; constexpr std::uint32_t getMaxMetadataBytes() { diff --git a/tests/media/server/main/mediaPipeline/CallbackTest.cpp b/tests/media/server/main/mediaPipeline/CallbackTest.cpp index ed0bb8f58..e2e75c0c9 100644 --- a/tests/media/server/main/mediaPipeline/CallbackTest.cpp +++ b/tests/media/server/main/mediaPipeline/CallbackTest.cpp @@ -88,7 +88,7 @@ TEST_F(RialtoServerMediaPipelineCallbackTest, notifyNeedMediaDataInPrerollingSta { auto mediaSourceType = firebolt::rialto::MediaSourceType::VIDEO; int sourceId = attachSource(mediaSourceType, "video/h264"); - int numFrames{1}; + int numFrames{3}; expectNotifyNeedData(mediaSourceType, sourceId, numFrames); diff --git a/tests/media/server/main/mediaPipeline/HaveDataTest.cpp b/tests/media/server/main/mediaPipeline/HaveDataTest.cpp index 202b3f969..9c7adf47b 100644 --- a/tests/media/server/main/mediaPipeline/HaveDataTest.cpp +++ b/tests/media/server/main/mediaPipeline/HaveDataTest.cpp @@ -28,7 +28,7 @@ using ::testing::Throw; class RialtoServerMediaPipelineHaveDataTest : public MediaPipelineTestBase { protected: - const uint32_t m_kNumFrames{1}; + const uint32_t m_kNumFrames{3}; const uint32_t m_kNeedDataRequestId{0}; const std::chrono::milliseconds m_kNeedMediaDataResendTimeout{100}; diff --git a/tests/media/server/main/mediaPipeline/MiscellaneousFunctionsTest.cpp b/tests/media/server/main/mediaPipeline/MiscellaneousFunctionsTest.cpp index a0f381ec1..6ac337f15 100644 --- a/tests/media/server/main/mediaPipeline/MiscellaneousFunctionsTest.cpp +++ b/tests/media/server/main/mediaPipeline/MiscellaneousFunctionsTest.cpp @@ -163,10 +163,10 @@ TEST_F(RialtoServerMediaPipelineMiscellaneousFunctionsTest, SetPositionResetEos) EXPECT_TRUE(m_mediaPipeline->setPosition(m_kPosition)); // Expect need data notified to client - expectNotifyNeedData(firebolt::rialto::MediaSourceType::VIDEO, videoSourceId, 1); + expectNotifyNeedData(firebolt::rialto::MediaSourceType::VIDEO, videoSourceId, 3); m_gstPlayerCallback->notifyNeedMediaData(firebolt::rialto::MediaSourceType::VIDEO); - expectNotifyNeedData(firebolt::rialto::MediaSourceType::AUDIO, audioSourceId, 1); + expectNotifyNeedData(firebolt::rialto::MediaSourceType::AUDIO, audioSourceId, 3); m_gstPlayerCallback->notifyNeedMediaData(firebolt::rialto::MediaSourceType::AUDIO); } diff --git a/tests/media/server/main/needMediaData/NeedMediaDataTestsFixture.cpp b/tests/media/server/main/needMediaData/NeedMediaDataTestsFixture.cpp index cfd2938ff..2237002df 100644 --- a/tests/media/server/main/needMediaData/NeedMediaDataTestsFixture.cpp +++ b/tests/media/server/main/needMediaData/NeedMediaDataTestsFixture.cpp @@ -30,7 +30,7 @@ constexpr int kSourceId{1}; constexpr std::uint32_t kBufferLen{7 * 1024 * 1024}; constexpr std::uint32_t kMetadataOffset{1024}; constexpr int kRequestId{0}; -constexpr int kPrerollingNumFrames{1}; +constexpr int kPrerollingNumFrames{3}; constexpr int kMaxFrames{24}; constexpr int kMaxMetadataBytes{2500}; } // namespace