Skip to content

Commit

Permalink
fix: text roles being combined incorrectly in some multiperiod cases (#…
Browse files Browse the repository at this point in the history
…6055)

Resolves #6054
  • Loading branch information
littlespex authored and avelad committed Jan 9, 2024
1 parent ea8f3fc commit ee42570
Show file tree
Hide file tree
Showing 2 changed files with 54 additions and 0 deletions.
5 changes: 5 additions & 0 deletions lib/util/periods.js
Original file line number Diff line number Diff line change
Expand Up @@ -1142,6 +1142,11 @@ shaka.util.PeriodCombiner = class {
return true;
}

// Forced subtitles should be treated as unique streams
if (outputStream.forced !== candidate.forced) {
return false;
}

const languageRelatedness = LanguageUtils.relatedness(
outputStream.language, candidate.language);

Expand Down
49 changes: 49 additions & 0 deletions test/util/periods_unit.js
Original file line number Diff line number Diff line change
Expand Up @@ -603,6 +603,55 @@ describe('PeriodCombiner', () => {
}
});

// Regression test for #6054, where we failed on multi-period content with
// different numbers of forced-subtitle streams per period.
it('Does not combine subtitle and forced-subtitle tracks', async () => {
const videoStreams = [makeVideoStream(1280)];
const audioStreams = [makeAudioStream('en', /* channels= */ 2)];
const imageStreams = [];

const forcedSubtitle = makeTextStream('de');
forcedSubtitle.roles = ['forced-subtitle'];
forcedSubtitle.forced = true;

const subtitle = makeTextStream('de');
subtitle.roles = ['subtitle'];

/** @type {!Array.<shaka.extern.Period>} */
const periods = [
{
id: '1',
videoStreams,
audioStreams,
textStreams: [
forcedSubtitle,
subtitle,
],
imageStreams,
},
{
id: '2',
videoStreams,
audioStreams,
textStreams: [
subtitle,
],
imageStreams,
},
{
id: '3',
videoStreams,
audioStreams,
textStreams: [],
imageStreams,
},
];

await combiner.combinePeriods(periods, /* isDynamic= */ true);
const textStreams = combiner.getTextStreams();
expect(textStreams.every((s) => s.roles.length === 1)).toBe(true);
});

// Regression test for #3383, where we failed on multi-period content with
// multiple image streams per period.
it('Can handle multiple image streams', async () => {
Expand Down

0 comments on commit ee42570

Please sign in to comment.