mirror of
https://github.com/videojs/video.js.git
synced 2025-01-21 11:02:08 +02:00
3dc6fbf6e7
Fixes #5887
118 lines
3.9 KiB
JavaScript
118 lines
3.9 KiB
JavaScript
/* eslint-env qunit */
|
|
import VideoTrackList from '../../../src/js/tracks/video-track-list.js';
|
|
import VideoTrack from '../../../src/js/tracks/video-track.js';
|
|
import EventTarget from '../../../src/js/event-target.js';
|
|
|
|
QUnit.module('Video Track List');
|
|
|
|
QUnit.test('trigger "change" when "selectedchange" is fired on a track', function(assert) {
|
|
const track = new EventTarget();
|
|
|
|
track.loaded_ = true;
|
|
const videoTrackList = new VideoTrackList([track]);
|
|
let changes = 0;
|
|
const changeHandler = function() {
|
|
changes++;
|
|
};
|
|
|
|
videoTrackList.on('change', changeHandler);
|
|
track.trigger('selectedchange');
|
|
assert.equal(changes, 1, 'one change events for trigger');
|
|
|
|
videoTrackList.off('change', changeHandler);
|
|
videoTrackList.onchange = changeHandler;
|
|
|
|
track.trigger('selectedchange');
|
|
assert.equal(changes, 2, 'one change events for another trigger');
|
|
|
|
videoTrackList.removeTrack(track);
|
|
videoTrackList.off('change');
|
|
});
|
|
|
|
QUnit.test('only one track is ever selected', function(assert) {
|
|
const track = new VideoTrack({selected: true});
|
|
const track2 = new VideoTrack({selected: true});
|
|
const track3 = new VideoTrack({selected: true});
|
|
const track4 = new VideoTrack();
|
|
const list = new VideoTrackList([track, track2]);
|
|
|
|
assert.equal(track.selected, false, 'track is unselected');
|
|
assert.equal(track2.selected, true, 'track2 is selected');
|
|
|
|
track.selected = true;
|
|
assert.equal(track.selected, true, 'track is selected');
|
|
assert.equal(track2.selected, false, 'track2 is unselected');
|
|
|
|
list.addTrack(track3);
|
|
assert.equal(track.selected, false, 'track is unselected');
|
|
assert.equal(track2.selected, false, 'track2 is unselected');
|
|
assert.equal(track3.selected, true, 'track3 is selected');
|
|
|
|
track2.selected = true;
|
|
assert.equal(track.selected, false, 'track is unselected');
|
|
assert.equal(track2.selected, true, 'track2 is selected');
|
|
assert.equal(track3.selected, false, 'track3 is unselected');
|
|
|
|
list.addTrack(track4);
|
|
assert.equal(track.selected, false, 'track is unselected');
|
|
assert.equal(track2.selected, true, 'track2 is selected');
|
|
assert.equal(track3.selected, false, 'track3 is unselected');
|
|
assert.equal(track4.selected, false, 'track4 is unselected');
|
|
|
|
list.removeTrack(track);
|
|
list.removeTrack(track2);
|
|
list.removeTrack(track3);
|
|
list.removeTrack(track4);
|
|
});
|
|
|
|
QUnit.test('all tracks can be unselected', function(assert) {
|
|
const track = new VideoTrack();
|
|
const track2 = new VideoTrack();
|
|
const list = new VideoTrackList([track, track2]);
|
|
|
|
assert.equal(track.selected, false, 'track is unselected');
|
|
assert.equal(track2.selected, false, 'track2 is unselected');
|
|
|
|
track.selected = true;
|
|
assert.equal(track.selected, true, 'track is selected');
|
|
assert.equal(track2.selected, false, 'track2 is unselected');
|
|
|
|
track.selected = false;
|
|
assert.equal(track.selected, false, 'track is unselected');
|
|
assert.equal(track2.selected, false, 'track2 is unselected');
|
|
|
|
list.removeTrack(track);
|
|
list.removeTrack(track2);
|
|
});
|
|
|
|
QUnit.test('trigger a change event per selected change', function(assert) {
|
|
const track = new VideoTrack({selected: true});
|
|
const track2 = new VideoTrack({selected: true});
|
|
const track3 = new VideoTrack({selected: true});
|
|
const track4 = new VideoTrack();
|
|
const list = new VideoTrackList([track, track2]);
|
|
let change = 0;
|
|
|
|
list.on('change', () => change++);
|
|
track.selected = true;
|
|
assert.equal(change, 1, 'one change triggered');
|
|
|
|
list.addTrack(track3);
|
|
assert.equal(change, 2, 'another change triggered by adding an selected track');
|
|
|
|
track.selected = true;
|
|
assert.equal(change, 3, 'another change trigger by changing selected');
|
|
|
|
track.selected = false;
|
|
assert.equal(change, 4, 'another change trigger by changing selected');
|
|
|
|
list.addTrack(track4);
|
|
assert.equal(change, 4, 'no change triggered by adding a unselected track');
|
|
|
|
list.removeTrack(track);
|
|
list.removeTrack(track2);
|
|
list.removeTrack(track3);
|
|
list.removeTrack(track4);
|
|
list.off('change');
|
|
});
|