From 7043b0cb95404d68898e658d30a33078a3b4f844 Mon Sep 17 00:00:00 2001 From: Gustav Grusell Date: Wed, 13 Nov 2019 22:59:20 +0100 Subject: [PATCH] Recognize mimetypes for webm segments --- src/toM3u8.js | 4 +- test/index.test.js | 8 ++ test/manifests/webmsegments.js | 154 ++++++++++++++++++++++++++++++++ test/manifests/webmsegments.mpd | 21 +++++ 4 files changed, 185 insertions(+), 2 deletions(-) create mode 100644 test/manifests/webmsegments.js create mode 100644 test/manifests/webmsegments.mpd diff --git a/src/toM3u8.js b/src/toM3u8.js index ea692602..1da95af0 100644 --- a/src/toM3u8.js +++ b/src/toM3u8.js @@ -243,9 +243,9 @@ export const toM3u8 = (dashPlaylists, sidxMapping = {}) => { } = dashPlaylists[0].attributes; const videoOnly = ({ attributes }) => - attributes.mimeType === 'video/mp4' || attributes.contentType === 'video'; + attributes.mimeType === 'video/mp4' || attributes.mimeType === 'video/webm' || attributes.contentType === 'video'; const audioOnly = ({ attributes }) => - attributes.mimeType === 'audio/mp4' || attributes.contentType === 'audio'; + attributes.mimeType === 'audio/mp4' || attributes.mimeType === 'audio/webm' || attributes.contentType === 'audio'; const vttOnly = ({ attributes }) => attributes.mimeType === 'text/vtt' || attributes.contentType === 'text'; diff --git a/test/index.test.js b/test/index.test.js index 19912ab4..6153eb16 100644 --- a/test/index.test.js +++ b/test/index.test.js @@ -6,6 +6,7 @@ import maatVttSegmentTemplate from './manifests/maat_vtt_segmentTemplate.mpd'; import segmentBaseTemplate from './manifests/segmentBase.mpd'; import segmentListTemplate from './manifests/segmentList.mpd'; import multiperiod from './manifests/multiperiod.mpd'; +import webmsegments from './manifests/webmsegments.mpd'; import { parsedManifest as maatVttSegmentTemplateManifest } from './manifests/maat_vtt_segmentTemplate.js'; @@ -18,6 +19,9 @@ import { import { parsedManifest as multiperiodManifest } from './manifests/multiperiod.js'; +import { + parsedManifest as webmsegmentsManifest +} from './manifests/webmsegments.js'; QUnit.module('mpd-parser'); @@ -45,6 +49,10 @@ QUnit.test('has parse', function(assert) { name: 'multiperiod', input: multiperiod, expected: multiperiodManifest +}, { + name: 'webmsegments', + input: webmsegments, + expected: webmsegmentsManifest }].forEach(({ name, input, expected }) => { QUnit.test(`${name} test manifest`, function(assert) { const actual = parse(input); diff --git a/test/manifests/webmsegments.js b/test/manifests/webmsegments.js new file mode 100644 index 00000000..e8c3fee1 --- /dev/null +++ b/test/manifests/webmsegments.js @@ -0,0 +1,154 @@ +export const parsedManifest = { + allowCache: true, + discontinuityStarts: [], + segments: [], + endList: true, + mediaGroups: { + 'AUDIO': { + audio: { + en: { + language: 'en', + autoselect: true, + default: true, + playlists: [ + { + attributes: { + 'NAME': '2', + 'BANDWIDTH': 32000, + 'CODECS': 'opus', + 'PROGRAM-ID': 1 + }, + uri: '', + endList: true, + timeline: 1, + resolvedUri: '', + targetDuration: 4, + segments: [ + { + uri: 'audio/segment_0.chk', + timeline: 1, + duration: 4, + resolvedUri: 'https://www.example.com/audio/segment_0.chk', + map: { + uri: 'audio/init.hdr', + resolvedUri: 'https://www.example.com/audio/init.hdr' + }, + number: 0 + }, + { + uri: 'audio/segment_1.chk', + timeline: 1, + duration: 4, + resolvedUri: 'https://www.example.com/audio/segment_1.chk', + map: { + uri: 'audio/init.hdr', + resolvedUri: 'https://www.example.com/audio/init.hdr' + }, + number: 1 + }, + { + uri: 'audio/segment_2.chk', + timeline: 1, + duration: 4, + resolvedUri: 'https://www.example.com/audio/segment_2.chk', + map: { + uri: 'audio/init.hdr', + resolvedUri: 'https://www.example.com/audio/init.hdr' + }, + number: 2 + }, + { + uri: 'audio/segment_3.chk', + timeline: 1, + duration: 4, + resolvedUri: 'https://www.example.com/audio/segment_3.chk', + map: { + uri: 'audio/init.hdr', + resolvedUri: 'https://www.example.com/audio/init.hdr' + }, + number: 3 + } + ], + mediaSequence: 0 + } + ], + uri: '' + } + } + }, + 'VIDEO': {}, + 'CLOSED-CAPTIONS': {}, + 'SUBTITLES': {} + }, + uri: '', + duration: 16, + playlists: [ + { + attributes: { + 'NAME': '1', + 'AUDIO': 'audio', + 'SUBTITLES': 'subs', + 'RESOLUTION': { + width: 480, + height: 200 + }, + 'CODECS': 'av1', + 'BANDWIDTH': 100000, + 'PROGRAM-ID': 1 + }, + uri: '', + endList: true, + timeline: 1, + resolvedUri: '', + targetDuration: 4, + segments: [ + { + uri: 'video/segment_0.chk', + timeline: 1, + duration: 4, + resolvedUri: 'https://www.example.com/video/segment_0.chk', + map: { + uri: 'video/init.hdr', + resolvedUri: 'https://www.example.com/video/init.hdr' + }, + number: 0 + }, + { + uri: 'video/segment_1.chk', + timeline: 1, + duration: 4, + resolvedUri: 'https://www.example.com/video/segment_1.chk', + map: { + uri: 'video/init.hdr', + resolvedUri: 'https://www.example.com/video/init.hdr' + }, + number: 1 + }, + { + uri: 'video/segment_2.chk', + timeline: 1, + duration: 4, + resolvedUri: 'https://www.example.com/video/segment_2.chk', + map: { + uri: 'video/init.hdr', + resolvedUri: 'https://www.example.com/video/init.hdr' + }, + number: 2 + }, + { + uri: 'video/segment_3.chk', + timeline: 1, + duration: 4, + resolvedUri: 'https://www.example.com/video/segment_3.chk', + map: { + uri: 'video/init.hdr', + resolvedUri: 'https://www.example.com/video/init.hdr' + }, + number: 3 + } + ], + mediaSequence: 0 + } + ], + minimumUpdatePeriod: 0 +}; diff --git a/test/manifests/webmsegments.mpd b/test/manifests/webmsegments.mpd new file mode 100644 index 00000000..a2bae9c3 --- /dev/null +++ b/test/manifests/webmsegments.mpd @@ -0,0 +1,21 @@ + + + + https://www.example.com/base + + + + + + + + + + + + +