From 70ba84eb6a059e8969723c3bbdaad4076a256f18 Mon Sep 17 00:00:00 2001 From: Pat O'Neill Date: Thu, 20 Jun 2019 13:40:55 -0400 Subject: [PATCH] fix(liveui): do not seek to live on first seek when autoplaying a live stream (#6062) Before listening for the play/timeupdate combination when starting the LiveTracker, check if the player has already started playback. --- src/js/live-tracker.js | 9 +++++++- test/unit/live-tracker.test.js | 38 ++++++++++++++++++++++++++++++++++ 2 files changed, 46 insertions(+), 1 deletion(-) diff --git a/src/js/live-tracker.js b/src/js/live-tracker.js index 5eb3b75d2..cc2f3e9b4 100644 --- a/src/js/live-tracker.js +++ b/src/js/live-tracker.js @@ -110,16 +110,23 @@ class LiveTracker extends Component { return; } + // If we haven't seen a timeupdate, we need to check whether playback + // began before this component started tracking. This can happen commonly + // when using autoplay. + if (!this.timeupdateSeen_) { + this.timeupdateSeen_ = this.player_.hasStarted(); + } + this.trackingInterval_ = this.setInterval(this.trackLive_, 30); this.trackLive_(); this.on(this.player_, 'play', this.trackLive_); this.on(this.player_, 'pause', this.trackLive_); - this.one(this.player_, 'play', this.handlePlay); // this is to prevent showing that we are not live // before a video starts to play if (!this.timeupdateSeen_) { + this.one(this.player_, 'play', this.handlePlay); this.handleTimeupdate = () => { this.timeupdateSeen_ = true; this.handleTimeupdate = null; diff --git a/test/unit/live-tracker.test.js b/test/unit/live-tracker.test.js index 8375edb82..ac69e437b 100644 --- a/test/unit/live-tracker.test.js +++ b/test/unit/live-tracker.test.js @@ -153,6 +153,44 @@ QUnit.module('LiveTracker', () => { assert.equal(playCalls, 0, 'should not have called play'); }); + QUnit.test('seeks to live edge on the first timeupdate after playback is requested', function(assert) { + sinon.spy(this.liveTracker, 'seekToLiveEdge'); + + // Begin live tracking. + this.player.duration(Infinity); + assert.ok(this.liveTracker.seekToLiveEdge.notCalled, 'seekToLiveEdge was not called yet'); + + this.player.trigger('play'); + this.player.trigger('playing'); + assert.ok(this.liveTracker.seekToLiveEdge.notCalled, 'seekToLiveEdge was not called yet'); + + this.player.trigger('timeupdate'); + assert.ok(this.liveTracker.seekToLiveEdge.calledOnce, 'seekToLiveEdge was called'); + + this.player.trigger('timeupdate'); + assert.ok(this.liveTracker.seekToLiveEdge.calledOnce, 'seekToLiveEdge was not called on subsequent timeupdate'); + }); + + QUnit.test('does not seek to live edge on the first timeupdate after playback is requested if playback already began', function(assert) { + sinon.spy(this.liveTracker, 'seekToLiveEdge'); + + // Begin live tracking. + this.liveTracker.stopTracking(); + this.player.hasStarted = () => true; + this.liveTracker.startTracking(); + assert.ok(this.liveTracker.seekToLiveEdge.notCalled, 'seekToLiveEdge was not called'); + + this.player.trigger('play'); + this.player.trigger('playing'); + assert.ok(this.liveTracker.seekToLiveEdge.notCalled, 'seekToLiveEdge was not called'); + + this.player.trigger('timeupdate'); + assert.ok(this.liveTracker.seekToLiveEdge.notCalled, 'seekToLiveEdge was not called'); + + this.player.trigger('timeupdate'); + assert.ok(this.liveTracker.seekToLiveEdge.notCalled, 'seekToLiveEdge was not called'); + }); + QUnit.test('single seekable, helpers should be correct', function(assert) { // simple this.player.seekable = () => createTimeRanges(10, 50);