From 1a1adf3275aa6513b091bc0ea57023301b526557 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Andr=C3=A9?= <34163393+amtins@users.noreply.github.com> Date: Wed, 31 May 2023 16:25:34 +0200 Subject: [PATCH] fix(player): address loss of crossOrigin value when loadMedia is called (#8085) --- src/js/player.js | 6 ++++++ test/unit/player.test.js | 45 ++++++++++++++++++++++++++++++++++++++++ 2 files changed, 51 insertions(+) diff --git a/src/js/player.js b/src/js/player.js index 7d42ddd224..3cb780ab1c 100644 --- a/src/js/player.js +++ b/src/js/player.js @@ -4899,6 +4899,8 @@ class Player extends Component { return; } + const crossOrigin = this.crossOrigin(); + this.reset(); // Clone the media object so it cannot be mutated from outside. @@ -4914,6 +4916,10 @@ class Player extends Component { }]; } + if (crossOrigin) { + this.crossOrigin(crossOrigin); + } + if (src) { this.src(src); } diff --git a/test/unit/player.test.js b/test/unit/player.test.js index 9831b0090d..fa5875d3b6 100644 --- a/test/unit/player.test.js +++ b/test/unit/player.test.js @@ -3230,3 +3230,48 @@ QUnit.test('turning on audioPosterMode when audioOnlyMode is already on will tur assert.notOk(player.audioOnlyMode(), 'audioOnlyMode is false'); }); }); + +QUnit.test('crossOrigin value should be maintained after loadMedia is called', function(assert) { + const fixture = document.getElementById('qunit-fixture'); + + const example1 = ''; + const example2 = ''; + const example3 = ''; + + fixture.innerHTML += example1; + fixture.innerHTML += example2; + fixture.innerHTML += example3; + + const tagExample1 = document.getElementById('example_1'); + const tagExample2 = document.getElementById('example_2'); + const tagExample3 = document.getElementById('example_3'); + const playerExample1 = TestHelpers.makePlayer({techOrder: ['Html5']}, tagExample1); + const playerExample2 = TestHelpers.makePlayer({techOrder: ['Html5'], crossOrigin: 'use-credentials'}, tagExample2); + const playerExample3 = TestHelpers.makePlayer({techOrder: ['Html5']}, tagExample3); + + this.clock.tick(1000); + + playerExample1.crossOrigin('anonymous'); + playerExample1.loadMedia({ + src: 'foo.mp4' + }); + playerExample2.loadMedia({ + src: 'foo.mp4' + }); + playerExample3.loadMedia({ + src: 'foo.mp4' + }); + + assert.strictEqual(playerExample1.crossOrigin(), 'anonymous', 'crossOrigin value remains correct when assigned by the crossOrigin method and loadMedia is called'); + assert.ok(tagExample1.crossOrigin === 'anonymous'); + + assert.strictEqual(playerExample2.crossOrigin(), 'use-credentials', 'crossOrigin value remains correct when passed through the options and loadMedia is called'); + assert.ok(tagExample2.crossOrigin === 'use-credentials'); + + assert.strictEqual(playerExample3.crossOrigin(), 'anonymous', 'crossOrigin value remains correct when passed via the html property and loadMedia is called'); + assert.ok(tagExample3.crossOrigin === 'anonymous'); + + playerExample1.dispose(); + playerExample2.dispose(); + playerExample3.dispose(); +});