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();
+});