From 6b2163a12e0d8d19f87a08308a5c3e6484167090 Mon Sep 17 00:00:00 2001 From: "lee.fordyce" Date: Wed, 14 Feb 2024 14:07:20 -0700 Subject: [PATCH] feat: add ability to package timed text --- include/packager/live_packager.h | 9 +- packager/live_packager.cc | 86 ++++++++++++++++-- packager/live_packager_test.cc | 82 +++++++++++++++++ .../timed_text_vtt/0000.vtt | 7 ++ .../timed_text_vtt/0001.vtt | 4 + .../timed_text_vtt/0002.vtt | 5 + .../timed_text_vtt/0003.vtt | 5 + .../timed_text_vtt/0004.vtt | 4 + .../timed_text_vtt/0005.vtt | 5 + .../timed_text_vtt/0006.vtt | 4 + .../timed_text_vtt/0007.vtt | 4 + .../timed_text_vtt/0008.vtt | 4 + .../timed_text_vtt/0009.vtt | 4 + .../timed_text_vtt/0010.vtt | 5 + .../timed_text_vtt_mp4/0001.m4s | Bin 0 -> 1049 bytes .../timed_text_vtt_mp4/0002.m4s | Bin 0 -> 1340 bytes .../timed_text_vtt_mp4/0003.m4s | Bin 0 -> 1544 bytes .../timed_text_vtt_mp4/0004.m4s | Bin 0 -> 1716 bytes .../timed_text_vtt_mp4/0005.m4s | Bin 0 -> 2152 bytes .../timed_text_vtt_mp4/0006.m4s | Bin 0 -> 2257 bytes .../timed_text_vtt_mp4/0007.m4s | Bin 0 -> 2498 bytes .../timed_text_vtt_mp4/0008.m4s | Bin 0 -> 2625 bytes .../timed_text_vtt_mp4/0009.m4s | Bin 0 -> 2912 bytes .../timed_text_vtt_mp4/init.mp4 | Bin 0 -> 737 bytes 24 files changed, 220 insertions(+), 8 deletions(-) create mode 100644 packager/media/test/data/live_packager_tests/timed_text_vtt/0000.vtt create mode 100644 packager/media/test/data/live_packager_tests/timed_text_vtt/0001.vtt create mode 100644 packager/media/test/data/live_packager_tests/timed_text_vtt/0002.vtt create mode 100644 packager/media/test/data/live_packager_tests/timed_text_vtt/0003.vtt create mode 100644 packager/media/test/data/live_packager_tests/timed_text_vtt/0004.vtt create mode 100644 packager/media/test/data/live_packager_tests/timed_text_vtt/0005.vtt create mode 100644 packager/media/test/data/live_packager_tests/timed_text_vtt/0006.vtt create mode 100644 packager/media/test/data/live_packager_tests/timed_text_vtt/0007.vtt create mode 100644 packager/media/test/data/live_packager_tests/timed_text_vtt/0008.vtt create mode 100644 packager/media/test/data/live_packager_tests/timed_text_vtt/0009.vtt create mode 100644 packager/media/test/data/live_packager_tests/timed_text_vtt/0010.vtt create mode 100644 packager/media/test/data/live_packager_tests/timed_text_vtt_mp4/0001.m4s create mode 100644 packager/media/test/data/live_packager_tests/timed_text_vtt_mp4/0002.m4s create mode 100644 packager/media/test/data/live_packager_tests/timed_text_vtt_mp4/0003.m4s create mode 100644 packager/media/test/data/live_packager_tests/timed_text_vtt_mp4/0004.m4s create mode 100644 packager/media/test/data/live_packager_tests/timed_text_vtt_mp4/0005.m4s create mode 100644 packager/media/test/data/live_packager_tests/timed_text_vtt_mp4/0006.m4s create mode 100644 packager/media/test/data/live_packager_tests/timed_text_vtt_mp4/0007.m4s create mode 100644 packager/media/test/data/live_packager_tests/timed_text_vtt_mp4/0008.m4s create mode 100644 packager/media/test/data/live_packager_tests/timed_text_vtt_mp4/0009.m4s create mode 100644 packager/media/test/data/live_packager_tests/timed_text_vtt_mp4/init.mp4 diff --git a/include/packager/live_packager.h b/include/packager/live_packager.h index 0665ab4af3c..6c57c11cba7 100644 --- a/include/packager/live_packager.h +++ b/include/packager/live_packager.h @@ -61,11 +61,15 @@ struct LiveConfig { enum class OutputFormat { FMP4, TS, + VTTMP4, + TTMLMP4, + TTML, }; enum class TrackType { AUDIO, VIDEO, + TEXT, }; enum class EncryptionScheme { @@ -89,7 +93,7 @@ struct LiveConfig { /// For FMP4 output: /// It can be used to set the moof header sequence number if > 0. /// For M2TS output: - /// It is be used to set the continuity counter (TODO: UNIMPLEMENTED). + /// It is be used to set the continuity counter. uint32_t segment_number = 0; /// The offset to be applied to transport stream (e.g. MPEG2-TS, HLS packed @@ -118,6 +122,9 @@ class LivePackager { const Segment& media_segment, FullSegmentBuffer& output); + Status PackageTimedText(const Segment& media_segment, + FullSegmentBuffer& output); + LivePackager(const LivePackager&) = delete; LivePackager& operator=(const LivePackager&) = delete; diff --git a/packager/live_packager.cc b/packager/live_packager.cc index 28e7da49925..1a4d05de816 100644 --- a/packager/live_packager.cc +++ b/packager/live_packager.cc @@ -43,12 +43,27 @@ const std::string INPUT_FNAME = "memory://input_file"; const std::string INIT_SEGMENT_FNAME = "init.mp4"; std::string getSegmentTemplate(const LiveConfig& config) { - return LiveConfig::OutputFormat::TS == config.format ? "$Number$.ts" - : "$Number$.m4s"; + switch (config.format) { + case LiveConfig::OutputFormat::TS: + return "$Number$.ts"; + case LiveConfig::OutputFormat::TTML: + return "$Number$.ttml"; + case LiveConfig::OutputFormat::VTTMP4: + case LiveConfig::OutputFormat::TTMLMP4: + case LiveConfig::OutputFormat::FMP4: + return "$Number$.m4s"; + } } std::string getStreamSelector(const LiveConfig& config) { - return LiveConfig::TrackType::VIDEO == config.track_type ? "video" : "audio"; + switch (config.track_type) { + case LiveConfig::TrackType::VIDEO: + return "video"; + case LiveConfig::TrackType::AUDIO: + return "audio"; + case LiveConfig::TrackType::TEXT: + return "text"; + } } StreamDescriptors setupStreamDescriptors( @@ -61,10 +76,25 @@ StreamDescriptors setupStreamDescriptors( desc.stream_selector = getStreamSelector(config); - if (LiveConfig::OutputFormat::FMP4 == config.format) { - // init segment - desc.output = - File::MakeCallbackFileName(init_cb_params, INIT_SEGMENT_FNAME); + switch (config.format) { + case LiveConfig::OutputFormat::VTTMP4: + desc.output_format = "vtt+mp4"; + desc.output = + File::MakeCallbackFileName(init_cb_params, INIT_SEGMENT_FNAME); + break; + case LiveConfig::OutputFormat::TTMLMP4: + desc.output_format = "ttml+mp4"; + desc.output = + File::MakeCallbackFileName(init_cb_params, INIT_SEGMENT_FNAME); + break; + case LiveConfig::OutputFormat::FMP4: + // init segment + desc.output = + File::MakeCallbackFileName(init_cb_params, INIT_SEGMENT_FNAME); + break; + case LiveConfig::OutputFormat::TS: + case LiveConfig::OutputFormat::TTML: + break; } desc.segment_template = @@ -356,6 +386,48 @@ Status LivePackager::Package(const Segment& init_segment, return packager.Run(); } +Status LivePackager::PackageTimedText(const Segment& in, + FullSegmentBuffer& out) { + SegmentDataReader reader(in); + shaka::BufferCallbackParams callback_params; + callback_params.read_func = [&reader](const std::string& name, void* buffer, + uint64_t size) { + return reader.Read(buffer, size); + }; + + callback_params.write_func = [&out](const std::string& name, const void* data, + uint64_t size) { + out.AppendData(reinterpret_cast(data), size); + return size; + }; + + shaka::BufferCallbackParams init_callback_params; + init_callback_params.write_func = [&out](const std::string& name, + const void* data, uint64_t size) { + if (out.InitSegmentSize() == 0) { + out.SetInitSegment(reinterpret_cast(data), size); + } + return size; + }; + + shaka::PackagingParams packaging_params; + packaging_params.chunking_params.segment_duration_in_seconds = + DEFAULT_SEGMENT_DURATION; + + packaging_params.mp4_output_params.include_pssh_in_stream = false; + + StreamDescriptors descriptors = + setupStreamDescriptors(config_, callback_params, init_callback_params); + + shaka::Packager packager; + shaka::Status status = packager.Initialize(packaging_params, descriptors); + + if (status != Status::OK) { + return status; + } + return packager.Run(); +} + SegmentManager::SegmentManager() = default; int64_t SegmentManager::OnSegmentWrite(const std::string& name, diff --git a/packager/live_packager_test.cc b/packager/live_packager_test.cc index 0cda88eb7d4..64eb55821d9 100644 --- a/packager/live_packager_test.cc +++ b/packager/live_packager_test.cc @@ -942,4 +942,86 @@ INSTANTIATE_TEST_CASE_P( 5, "audio/en/init.mp4", LiveConfig::EncryptionScheme::SAMPLE_AES, LiveConfig::OutputFormat::TS, LiveConfig::TrackType::AUDIO, "audio/en/%05d.m4s", false})); + +TEST_F(LivePackagerBaseTest, TestPackageTimedTextVTTMp4) { + std::vector init_segment_buffer = + ReadTestDataFile("timed_text_vtt_mp4/init.mp4"); + ASSERT_FALSE(init_segment_buffer.empty()); + + for (unsigned int i = 1; i < kNumSegments; i++) { + std::string segment_num = absl::StrFormat("timed_text_vtt_mp4/%04d.m4s", i); + std::vector segment_buffer = ReadTestDataFile(segment_num); + ASSERT_FALSE(segment_buffer.empty()); + + FullSegmentBuffer in; + in.SetInitSegment(init_segment_buffer.data(), init_segment_buffer.size()); + in.AppendData(segment_buffer.data(), segment_buffer.size()); + + FullSegmentBuffer out; + + LiveConfig live_config; + live_config.format = LiveConfig::OutputFormat::FMP4; + live_config.track_type = LiveConfig::TrackType::TEXT; + live_config.protection_scheme = LiveConfig::EncryptionScheme::NONE; + + SetupLivePackagerConfig(live_config); + // TODO: investigate failure. possibly caused by bad input - generate valid + // VTT in MP4 input + ASSERT_NE(Status::OK, live_packager_->PackageTimedText(in, out)); + } +} + +struct TimedTextTestCase { + const char* media_segment_format; + LiveConfig::OutputFormat output_format; +}; + +class TimedTextParameterizedTest + : public LivePackagerBaseTest, + public ::testing::WithParamInterface { + void SetUp() override { + LivePackagerBaseTest::SetUp(); + + LiveConfig live_config; + live_config.format = GetParam().output_format; + live_config.track_type = LiveConfig::TrackType::TEXT; + live_config.protection_scheme = LiveConfig::EncryptionScheme::NONE; + SetupLivePackagerConfig(live_config); + } +}; + +TEST_P(TimedTextParameterizedTest, VerifyTimedText) { + for (unsigned int i = 0; i < kNumSegments; i++) { + std::string format_output; + + std::vector format_args; + format_args.emplace_back(i); + absl::UntypedFormatSpec format(GetParam().media_segment_format); + + ASSERT_TRUE(absl::FormatUntyped(&format_output, format, format_args)); + std::vector segment_buffer = ReadTestDataFile(format_output); + ASSERT_FALSE(segment_buffer.empty()); + + SegmentData media_seg(segment_buffer.data(), segment_buffer.size()); + FullSegmentBuffer out; + + ASSERT_EQ(Status::OK, live_packager_->PackageTimedText(media_seg, out)); + ASSERT_GT(out.SegmentSize(), 0); + } +} + +INSTANTIATE_TEST_CASE_P(LivePackagerTimedText, + TimedTextParameterizedTest, + ::testing::Values( + // VTT in text --> VTT in MP4 + TimedTextTestCase{"timed_text_vtt/%04d.vtt", + LiveConfig::OutputFormat::VTTMP4}, + // VTT in text --> TTML in Text + TimedTextTestCase{"timed_text_vtt/%04d.vtt", + LiveConfig::OutputFormat::TTML}, + // VTT in text --> TTML in MP4 + TimedTextTestCase{ + "timed_text_vtt/%04d.vtt", + LiveConfig::OutputFormat::TTMLMP4})); + } // namespace shaka diff --git a/packager/media/test/data/live_packager_tests/timed_text_vtt/0000.vtt b/packager/media/test/data/live_packager_tests/timed_text_vtt/0000.vtt new file mode 100644 index 00000000000..0d7bb026d18 --- /dev/null +++ b/packager/media/test/data/live_packager_tests/timed_text_vtt/0000.vtt @@ -0,0 +1,7 @@ +WEBVTT + +00:16.858 --> 00:19.444 +I thought you'd never get back. + +00:19.569 --> 00:21.571 +There was a heck of a crowd on the piste. diff --git a/packager/media/test/data/live_packager_tests/timed_text_vtt/0001.vtt b/packager/media/test/data/live_packager_tests/timed_text_vtt/0001.vtt new file mode 100644 index 00000000000..d25a1d8e595 --- /dev/null +++ b/packager/media/test/data/live_packager_tests/timed_text_vtt/0001.vtt @@ -0,0 +1,4 @@ +WEBVTT + +00:22.113 --> 00:23.573 +So I see. diff --git a/packager/media/test/data/live_packager_tests/timed_text_vtt/0002.vtt b/packager/media/test/data/live_packager_tests/timed_text_vtt/0002.vtt new file mode 100644 index 00000000000..e64318d5085 --- /dev/null +++ b/packager/media/test/data/live_packager_tests/timed_text_vtt/0002.vtt @@ -0,0 +1,5 @@ +WEBVTT + +00:24.616 --> 00:27.953 +- Mission accomplished? +- Best beluga. diff --git a/packager/media/test/data/live_packager_tests/timed_text_vtt/0003.vtt b/packager/media/test/data/live_packager_tests/timed_text_vtt/0003.vtt new file mode 100644 index 00000000000..acc1cd4cc82 --- /dev/null +++ b/packager/media/test/data/live_packager_tests/timed_text_vtt/0003.vtt @@ -0,0 +1,5 @@ +WEBVTT + +00:29.120 --> 00:34.042 +Vodka - rather shaken - +and one microchip. diff --git a/packager/media/test/data/live_packager_tests/timed_text_vtt/0004.vtt b/packager/media/test/data/live_packager_tests/timed_text_vtt/0004.vtt new file mode 100644 index 00000000000..f7ae1635b49 --- /dev/null +++ b/packager/media/test/data/live_packager_tests/timed_text_vtt/0004.vtt @@ -0,0 +1,4 @@ +WEBVTT + +00:34.125 --> 00:37.587 +Good. I'll make a signal to M. diff --git a/packager/media/test/data/live_packager_tests/timed_text_vtt/0005.vtt b/packager/media/test/data/live_packager_tests/timed_text_vtt/0005.vtt new file mode 100644 index 00000000000..0c8733b79fa --- /dev/null +++ b/packager/media/test/data/live_packager_tests/timed_text_vtt/0005.vtt @@ -0,0 +1,5 @@ +WEBVTT + +00:42.133 --> 00:45.470 +Be a good girl, would you, +and put her on automatic. diff --git a/packager/media/test/data/live_packager_tests/timed_text_vtt/0006.vtt b/packager/media/test/data/live_packager_tests/timed_text_vtt/0006.vtt new file mode 100644 index 00000000000..2d96097a825 --- /dev/null +++ b/packager/media/test/data/live_packager_tests/timed_text_vtt/0006.vtt @@ -0,0 +1,4 @@ +WEBVTT + +00:50.267 --> 00:53.270 +And we could do with a couple of glasses. diff --git a/packager/media/test/data/live_packager_tests/timed_text_vtt/0007.vtt b/packager/media/test/data/live_packager_tests/timed_text_vtt/0007.vtt new file mode 100644 index 00000000000..70e1aac419f --- /dev/null +++ b/packager/media/test/data/live_packager_tests/timed_text_vtt/0007.vtt @@ -0,0 +1,4 @@ +WEBVTT + +00:54.187 --> 00:56.439 +They're in the overhead rack. diff --git a/packager/media/test/data/live_packager_tests/timed_text_vtt/0008.vtt b/packager/media/test/data/live_packager_tests/timed_text_vtt/0008.vtt new file mode 100644 index 00000000000..41b49cc83ec --- /dev/null +++ b/packager/media/test/data/live_packager_tests/timed_text_vtt/0008.vtt @@ -0,0 +1,4 @@ +WEBVTT + +01:01.444 --> 01:03.280 +Commander Bond... diff --git a/packager/media/test/data/live_packager_tests/timed_text_vtt/0009.vtt b/packager/media/test/data/live_packager_tests/timed_text_vtt/0009.vtt new file mode 100644 index 00000000000..e1e43f450f5 --- /dev/null +++ b/packager/media/test/data/live_packager_tests/timed_text_vtt/0009.vtt @@ -0,0 +1,4 @@ +WEBVTT + +01:03.363 --> 01:06.950 +Call me James. It's five days to Alaska. diff --git a/packager/media/test/data/live_packager_tests/timed_text_vtt/0010.vtt b/packager/media/test/data/live_packager_tests/timed_text_vtt/0010.vtt new file mode 100644 index 00000000000..934862e6ea2 --- /dev/null +++ b/packager/media/test/data/live_packager_tests/timed_text_vtt/0010.vtt @@ -0,0 +1,5 @@ +WEBVTT + +02:53.885 --> 02:58.223 +- Thank goodness you're here, James. +- That's very nice, Moneypenny. diff --git a/packager/media/test/data/live_packager_tests/timed_text_vtt_mp4/0001.m4s b/packager/media/test/data/live_packager_tests/timed_text_vtt_mp4/0001.m4s new file mode 100644 index 0000000000000000000000000000000000000000..6baf376dc11b7528b4fa1eeaa2a06c3bd1f9a0d5 GIT binary patch literal 1049 zcmcIjyGq1B6uoX-*fO$PSOyVnb_Kyg(pgvtVq{Vb)CbFZNAc>4n1_kt&)7gk{?kDU-CH94eSI*5Oc0E?*}t(A1XwlmP+`s z)kw2?5|g9QIMy zgM;5OAcxyT2mr$2V@nVGhaSeLxet0c40<>Uz0xn((t)2n?{pB!y?n=K{Qj4)(9QTA ub^-g^#dP&c9}DOt!`;j=FI8DAt28qen-;l)My<=cI=N1qF{d&>MD+z8VX?OW literal 0 HcmV?d00001 diff --git a/packager/media/test/data/live_packager_tests/timed_text_vtt_mp4/0002.m4s b/packager/media/test/data/live_packager_tests/timed_text_vtt_mp4/0002.m4s new file mode 100644 index 0000000000000000000000000000000000000000..28ef24e04eed2f4cac5d6eec33b69a38e91163dd GIT binary patch literal 1340 zcmcIk%SyvQ6rDCcif)4K!sQ?ZH?|?PoIo2M6;F?gP-wy_+oMt%H zT$W<*Dk+H5dom`#+E9bN7v;A1CJkNi8fdV0w5Z|KB>@15FdXgT6C7U#%*(7AQV&9-gk3ND=;RE<2 zK8D|HQYlhMUCh8TyR)-9`3?D&F*ep_RjTsthQU%@++!$OOQDlc#TwyDoyr&5haE8H zebv*=ni<9h>(@FcRZ+y4`YKLjlZP|x!Bm3c+)%v70?a9nF<8U*G01!qOWgNkLsKnt zteRYwVeTs_D5w8yOa$-9VC&+zy}ON}hdc)cTcbmU3!eaB)Sos64>=ADwnm2x!5aa< z_F*_go&$re(ILZ>698-0{(RHkuwanm%v%sRv|R zTDEtOYb|@UPkO@t>W|=|eXoR{Vm$rQ_7oZq5g%$}<|0eyc@Rdqi7LcyOR>skg!f-qx8DIYS-l Si1z_cuj8gO|JxD!hJFK@-xyN> literal 0 HcmV?d00001 diff --git a/packager/media/test/data/live_packager_tests/timed_text_vtt_mp4/0004.m4s b/packager/media/test/data/live_packager_tests/timed_text_vtt_mp4/0004.m4s new file mode 100644 index 0000000000000000000000000000000000000000..37794a6f97db5763672d3bdbd3068c8553c3cb3c GIT binary patch literal 1716 zcmcJP&q@O^5XNKIKh@Jhdk{njQtU;Ff(Plb7ZKEh_yVEXZI>q9rAfuUL607N1Rudu zpU21Wo9tE=DQu1GKu9wEGPA#devGk>v5QP+*H;XYnDhoq(_IQP9_rX2ePI&$O1~p^ z7z@7g4*!N>_J!)i_UzQkFC0|k-eCYt% z=fanc3tu`zZtXQxs^mwmb|?3vfHdR@_|Ju>*x_Hn1p5H%>6bqZ;8R27+s4|FP|0Z8 zA4XFf&5%3K#6sPssqFE)u2Ni!NyG&=5DCR?${%`Ac{<$k6K^T#YpbR~4*Z8{xY`@0 Wadd(@n8KmPPBqul`2Q4~-+u!FfiD68 literal 0 HcmV?d00001 diff --git a/packager/media/test/data/live_packager_tests/timed_text_vtt_mp4/0005.m4s b/packager/media/test/data/live_packager_tests/timed_text_vtt_mp4/0005.m4s new file mode 100644 index 0000000000000000000000000000000000000000..beb94ab2dd2c81ac2467b5a51e28277dd8b56017 GIT binary patch literal 2152 zcmcJQy-EW?5XU!(A2Bv3NnyE2z$S>Ig#-(+7Au9c%k6!^-R*I=r{)b(T3Yx3c7m0U z-~))y;A8lo%|(I)k}TZ7GP`sCo#8heJB+b@p~qR0ot-dPRH$>Tgw9eFp_}*x!h<4` zkMteZV662s-OkQTGuE9vO@lH~%E#78{7_ap++o)`7Zm53;!QThp5j>D349xi%+bC? zzCY{fyi9Sbv@FKnNu(f6`(A4g-jc!8#dVW=8AB5~3kFl8MutO&0ASRgWehE7EEr6U z8X1Pq1OQuwVFNk~22-O(h8s=*uvHi~p|fBxHELuKuZCbXhAle=Q=>+P@^}q~Z94{2 zqeh0w#~KXuZd&|HrbdknFPC!+Uvu*zUN9eapuMf;!+td%4iKBY`IKsIE|}c?>0D@$ zhTdkpeeFAV^kerFeuNeNn-e3<3m5TTp>-hQC`gB{mufFZ>>?B6_{!sg2TDmEM0q^m z52}nMAFFcE5vk-^sd?z-T%}x;S|vh9?h)=<&Y!nW+$AH1Wj*RZvqq0h?gc$+d?OEf Rv-b{9|IVyOb@j%~=wI3`g(?65 literal 0 HcmV?d00001 diff --git a/packager/media/test/data/live_packager_tests/timed_text_vtt_mp4/0006.m4s b/packager/media/test/data/live_packager_tests/timed_text_vtt_mp4/0006.m4s new file mode 100644 index 0000000000000000000000000000000000000000..411b7baf7c5b590b0c0d9220dc1d6b539eb76498 GIT binary patch literal 2257 zcmcJR&q~8U5XRS5Yqgg^d+@l3;H8KK57Lv~t@r?5mTb}n@{jJ;TJQmS^yt9{@a9$M zO)tKJZ{TD2%_fy1LYsvhSaxSJnU7xx`N9}GQhJsr`B{%4B9)zEC6r5{Mt%}1l)EaD z_jDbx#aR8jI4*Oh8EelUi=s@jEX2`E!jUZda1XoEV?lMUsa|7!oT-l0o?~xfQFuC( znD-kUJ)We<%3c=Z>?KlAPxDUe0J|lF(Z%g%_Bw_d`YafXhC_y9j{p$#eAY44(PP12 zG#oPYp9lc43Bxw}EEtT2LxyWk0EkT(cFAf^+#h=aWZsE^$>LGu5Ks(LBd)ZoGA28NAl1PbwO%e}@ntIcG~j+Vi6xgApGJDb1?71h@GRuRSSS^!6B3}GfgeN}hcW;F literal 0 HcmV?d00001 diff --git a/packager/media/test/data/live_packager_tests/timed_text_vtt_mp4/0007.m4s b/packager/media/test/data/live_packager_tests/timed_text_vtt_mp4/0007.m4s new file mode 100644 index 0000000000000000000000000000000000000000..8066fb956bfde71989012b10674f2d303154b7ab GIT binary patch literal 2498 zcmcJRy-EW?5XV=~X#9eMq_8|Bl14?rLQy)2>KTOXLFGtf#g`Z>cUH)N=HF7!Z#l4eb1`G4_6f35)$Me9A{T$)_ zJoIkqbJ!AN*4KDDIWx&vZFDyddU2Zi*xIolctsxWuydJliaV0x%dCYx#j$E5_$n5e zEqxF5eyuLEeu7hx%OdRU*yEH_9Y`tQH5pW2TvxT{F)SlbgF*E$$k4P207mnf$6z5x zgF*E$$k4hc0N5f7E6CGeP(2JXTsQ;(TZEy4JPiib!yp5HQUr@Jtm-kS9tIiuM>oKSv1{t2;OE7HcF{mB}8Qw0Z7+$AzI+~%= zo5<}HI=xfq^e$o(?WIyv`mAa<#`vGx3RAN=ye;q?IK>!rR?%3 z>?SQ&BvNFE?e+LD>I7og%!Csrjtqp84n!6R?l~EEZw`^9Dfl0sxJyP~cHS_ykW*q9 bs`iXwR31?WL)iX?rDMC9)_5uwbaMh36#q<ZYiBEzo300{m*^BD4| zF<=l4iwvy^10WV*SVo-zgJ@V}IIl4PViAS{>I@h}!y<$GCSpBXjo);y~x0@X2u{I78%|@ zGBB*0F^GmmhOes`hL;(?r2p|t8>qcZ{nBRYm$s4Pw}l(Wj8BrY>rgbz9MZQ<~zBv2ipPKMdZRD$o)*ZLs>x8Yg7iup?ZfoF<`X{i2Zm7Jtb{vJO L(P;2NY`(q$2lc|w literal 0 HcmV?d00001 diff --git a/packager/media/test/data/live_packager_tests/timed_text_vtt_mp4/0009.m4s b/packager/media/test/data/live_packager_tests/timed_text_vtt_mp4/0009.m4s new file mode 100644 index 0000000000000000000000000000000000000000..46922fc721495146d684f2878622429b126f7f48 GIT binary patch literal 2912 zcmcJRze)o^5XM*Ie~lbyVYz6)Mnu6vQYltS5DQBSm)u=)c$Dwk z65i48h$$g*U)^K>Sy&;~I``dVsO$9@$3Vx`uvdpWqGX$j^3qa%S`=}nJl0wV`vMk4 zVB-+|2C;6Nts0(swIani(4nH5gU@W`N^nP4)8IX4E@@W{~G%fK-2 z#=sgL89J{S80fp{@Gh~2M~26v3=E5I46Nai;pII8!;%{VYj|XMyU4(>?8d+v9vMD9 zGcc^UF|dY5hVSbk2E11Tzm$&fOL^2@_WaUD&o6Bv*Y`lwYRD&X??Trn<*0_d3cNsm z3p>6KbL5dqSXY01Qwjd5jQqN>wxZIcQY)6DnvI&s?KM<8JyB^YbtKP}j?At+wcAF< z$!#P<)i%=B<#DRajoL-MqX+x>!d(jb-{a=8ikb{_;oc+WGXI1=n8)%rcFbomm;amx Gd(&Ti$^`cS literal 0 HcmV?d00001 diff --git a/packager/media/test/data/live_packager_tests/timed_text_vtt_mp4/init.mp4 b/packager/media/test/data/live_packager_tests/timed_text_vtt_mp4/init.mp4 new file mode 100644 index 0000000000000000000000000000000000000000..a099b53cc52923ea6db342213d02fda0271e8fa3 GIT binary patch literal 737 zcmZva%}&BV5XToZ@j{FTyciEXaPVLS5fkx5P!qWs19&kZ+ufx_y0qy|3wrPod^`lxz@H~_vntyb+3IH7gGJXuu^9aGZ}ygR`lBg)3q76IWRGMlxAb=<6( z(zijGjAaIE)=e&~(8d>jgn*9mh+7!PZP{3~MK@$MVsp8&#H~Ne3OkaIC|ZW(|F^#P z8ZX$-w+O@x^4oNgFX@E4_;MI;ax@uYuJ9!9@<3?Tp>I