2015-05-04 01:12:38 +02:00
|
|
|
import Flash from '../../../src/js/tech/flash.js';
|
2015-03-26 06:43:41 +02:00
|
|
|
import document from 'global/document';
|
2013-08-24 01:05:04 +03:00
|
|
|
|
2015-06-08 22:47:04 +02:00
|
|
|
let tech;
|
|
|
|
|
|
|
|
q.module('Flash', {
|
|
|
|
setup() {
|
|
|
|
tech = new Flash({});
|
|
|
|
},
|
|
|
|
teardown() {
|
|
|
|
tech.dispose();
|
|
|
|
}
|
|
|
|
});
|
2015-03-11 03:01:11 +02:00
|
|
|
|
2013-08-24 01:05:04 +03:00
|
|
|
var streamToPartsAndBack = function(url) {
|
2015-03-11 03:01:11 +02:00
|
|
|
var parts = Flash.streamToParts(url);
|
|
|
|
return Flash.streamFromParts(parts.connection, parts.stream);
|
2013-08-24 01:05:04 +03:00
|
|
|
};
|
|
|
|
|
|
|
|
test('test using both streamToParts and streamFromParts', function() {
|
|
|
|
ok('rtmp://myurl.com/&isthis' === streamToPartsAndBack('rtmp://myurl.com/isthis'));
|
|
|
|
ok('rtmp://myurl.com/&isthis' === streamToPartsAndBack('rtmp://myurl.com/&isthis'));
|
|
|
|
ok('rtmp://myurl.com/isthis/&andthis' === streamToPartsAndBack('rtmp://myurl.com/isthis/andthis'));
|
|
|
|
});
|
|
|
|
|
|
|
|
test('test streamToParts', function() {
|
2015-03-11 03:01:11 +02:00
|
|
|
var parts = Flash.streamToParts('http://myurl.com/streaming&/is/fun');
|
2013-08-24 01:05:04 +03:00
|
|
|
ok(parts.connection === 'http://myurl.com/streaming');
|
|
|
|
ok(parts.stream === '/is/fun');
|
|
|
|
|
2015-03-11 03:01:11 +02:00
|
|
|
parts = Flash.streamToParts('http://myurl.com/&streaming&/is/fun');
|
2013-08-24 01:05:04 +03:00
|
|
|
ok(parts.connection === 'http://myurl.com/');
|
|
|
|
ok(parts.stream === 'streaming&/is/fun');
|
|
|
|
|
2015-03-11 03:01:11 +02:00
|
|
|
parts = Flash.streamToParts('http://myurl.com/streaming/is/fun');
|
2013-08-24 01:05:04 +03:00
|
|
|
ok(parts.connection === 'http://myurl.com/streaming/is/');
|
|
|
|
ok(parts.stream === 'fun');
|
|
|
|
|
2015-03-11 03:01:11 +02:00
|
|
|
parts = Flash.streamToParts('whatisgoingonhere');
|
2013-08-24 01:05:04 +03:00
|
|
|
ok(parts.connection === 'whatisgoingonhere');
|
|
|
|
ok(parts.stream === '');
|
|
|
|
|
2015-03-11 03:01:11 +02:00
|
|
|
parts = Flash.streamToParts();
|
2013-08-24 01:05:04 +03:00
|
|
|
ok(parts.connection === '');
|
|
|
|
ok(parts.stream === '');
|
|
|
|
});
|
|
|
|
|
|
|
|
test('test isStreamingSrc', function() {
|
2015-03-11 03:01:11 +02:00
|
|
|
var isStreamingSrc = Flash.isStreamingSrc;
|
2013-08-24 01:05:04 +03:00
|
|
|
ok(isStreamingSrc('rtmp://streaming.is/fun'));
|
|
|
|
ok(isStreamingSrc('rtmps://streaming.is/fun'));
|
|
|
|
ok(isStreamingSrc('rtmpe://streaming.is/fun'));
|
|
|
|
ok(isStreamingSrc('rtmpt://streaming.is/fun'));
|
|
|
|
// test invalid protocols
|
|
|
|
ok(!isStreamingSrc('rtmp:streaming.is/fun'));
|
|
|
|
ok(!isStreamingSrc('rtmpz://streaming.is/fun'));
|
|
|
|
ok(!isStreamingSrc('http://streaming.is/fun'));
|
|
|
|
ok(!isStreamingSrc('https://streaming.is/fun'));
|
|
|
|
ok(!isStreamingSrc('file://streaming.is/fun'));
|
2013-10-29 21:00:54 +03:00
|
|
|
});
|
|
|
|
|
|
|
|
test('test canPlaySource', function() {
|
2015-03-11 03:01:11 +02:00
|
|
|
var canPlaySource = Flash.canPlaySource;
|
2013-10-29 21:00:54 +03:00
|
|
|
|
|
|
|
// supported
|
|
|
|
ok(canPlaySource({ type: 'video/mp4; codecs=avc1.42E01E,mp4a.40.2' }), 'codecs supported');
|
|
|
|
ok(canPlaySource({ type: 'video/mp4' }), 'video/mp4 supported');
|
|
|
|
ok(canPlaySource({ type: 'video/x-flv' }), 'video/x-flv supported');
|
|
|
|
ok(canPlaySource({ type: 'video/flv' }), 'video/flv supported');
|
|
|
|
ok(canPlaySource({ type: 'video/m4v' }), 'video/m4v supported');
|
|
|
|
ok(canPlaySource({ type: 'VIDEO/FLV' }), 'capitalized mime type');
|
|
|
|
|
|
|
|
// not supported
|
|
|
|
ok(!canPlaySource({ type: 'video/webm; codecs="vp8, vorbis"' }));
|
|
|
|
ok(!canPlaySource({ type: 'video/webm' }));
|
|
|
|
});
|
2014-01-24 02:13:22 +03:00
|
|
|
|
|
|
|
test('currentTime is the seek target during seeking', function() {
|
|
|
|
var noop = function() {},
|
|
|
|
seeking = false,
|
|
|
|
parentEl = document.createElement('div'),
|
2015-03-11 03:01:11 +02:00
|
|
|
tech = new Flash({
|
2014-01-24 02:13:22 +03:00
|
|
|
id: noop,
|
2014-08-14 02:44:36 +03:00
|
|
|
bufferedPercent: noop,
|
2014-01-24 02:13:22 +03:00
|
|
|
on: noop,
|
2014-08-14 02:44:36 +03:00
|
|
|
trigger: noop,
|
2015-02-14 01:18:07 +02:00
|
|
|
ready: noop,
|
|
|
|
addChild: noop,
|
2015-03-26 06:43:41 +02:00
|
|
|
options_: {},
|
|
|
|
// This complexity is needed because of the VTT.js loading
|
|
|
|
// It'd be great if we can find a better solution for that
|
|
|
|
options: function(){ return {}; },
|
|
|
|
el: function(){
|
|
|
|
return {
|
|
|
|
appendChild: noop
|
|
|
|
};
|
|
|
|
}
|
2014-01-24 02:13:22 +03:00
|
|
|
}, {
|
|
|
|
'parentEl': parentEl
|
|
|
|
}),
|
|
|
|
currentTime;
|
|
|
|
|
|
|
|
tech.el().vjs_setProperty = function(property, value) {
|
|
|
|
if (property === 'currentTime') {
|
|
|
|
currentTime = value;
|
|
|
|
}
|
|
|
|
};
|
|
|
|
tech.el().vjs_getProperty = function(name) {
|
|
|
|
if (name === 'currentTime') {
|
|
|
|
return currentTime;
|
|
|
|
} else if (name === 'seeking') {
|
|
|
|
return seeking;
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
currentTime = 3;
|
|
|
|
strictEqual(3, tech.currentTime(), 'currentTime is retreived from the SWF');
|
|
|
|
|
|
|
|
tech['setCurrentTime'](7);
|
|
|
|
seeking = true;
|
|
|
|
strictEqual(7, tech.currentTime(), 'during seeks the target time is returned');
|
|
|
|
});
|
2014-07-17 00:01:01 +03:00
|
|
|
|
2014-07-09 23:08:47 +03:00
|
|
|
test('dispose removes the object element even before ready fires', function() {
|
|
|
|
var noop = function() {},
|
|
|
|
parentEl = document.createElement('div'),
|
2015-03-11 03:01:11 +02:00
|
|
|
tech = new Flash({
|
2014-07-09 23:08:47 +03:00
|
|
|
id: noop,
|
|
|
|
on: noop,
|
2015-01-16 22:05:21 +02:00
|
|
|
off: noop,
|
2014-08-14 02:44:36 +03:00
|
|
|
trigger: noop,
|
2015-02-14 01:18:07 +02:00
|
|
|
ready: noop,
|
|
|
|
addChild: noop,
|
2015-03-26 06:43:41 +02:00
|
|
|
options: function(){ return {}; },
|
2014-07-09 23:08:47 +03:00
|
|
|
options_: {}
|
|
|
|
}, {
|
|
|
|
'parentEl': parentEl
|
|
|
|
});
|
|
|
|
|
|
|
|
tech.dispose();
|
|
|
|
strictEqual(tech.el(), null, 'tech el is null');
|
|
|
|
strictEqual(parentEl.children.length, 0, 'parent el is empty');
|
|
|
|
});
|
2014-07-29 03:27:29 +03:00
|
|
|
|
2014-07-17 00:01:01 +03:00
|
|
|
test('ready triggering before and after disposing the tech', function() {
|
|
|
|
var checkReady, fixtureDiv, playerDiv, techEl;
|
|
|
|
|
2015-03-26 06:43:41 +02:00
|
|
|
checkReady = sinon.stub(Flash, 'checkReady');
|
2014-07-17 00:01:01 +03:00
|
|
|
|
|
|
|
fixtureDiv = document.getElementById('qunit-fixture');
|
|
|
|
playerDiv = document.createElement('div');
|
|
|
|
techEl = document.createElement('div');
|
|
|
|
|
|
|
|
playerDiv.appendChild(techEl);
|
|
|
|
fixtureDiv.appendChild(playerDiv);
|
|
|
|
|
|
|
|
techEl.id = 'foo1234';
|
2015-05-06 20:01:52 +02:00
|
|
|
|
|
|
|
techEl.tech = {
|
|
|
|
el() { return techEl; }
|
|
|
|
};
|
|
|
|
|
2014-07-17 00:01:01 +03:00
|
|
|
playerDiv['player'] = {
|
2015-05-06 20:01:52 +02:00
|
|
|
tech: techEl.tech
|
2014-07-17 00:01:01 +03:00
|
|
|
};
|
|
|
|
|
2015-03-11 03:01:11 +02:00
|
|
|
Flash['onReady'](techEl.id);
|
2014-07-17 00:01:01 +03:00
|
|
|
ok(checkReady.called, 'checkReady should be called before the tech is disposed');
|
|
|
|
|
|
|
|
// remove the tech el from the player div to simulate being disposed
|
|
|
|
playerDiv.removeChild(techEl);
|
2015-03-11 03:01:11 +02:00
|
|
|
Flash['onReady'](techEl.id);
|
2014-07-17 00:01:01 +03:00
|
|
|
ok(!checkReady.calledTwice, 'checkReady should not be called after the tech is disposed');
|
|
|
|
|
2015-03-11 03:01:11 +02:00
|
|
|
Flash['checkReady'].restore();
|
2014-07-17 00:01:01 +03:00
|
|
|
});
|
2014-12-03 00:22:34 +02:00
|
|
|
|
|
|
|
test('should have the source handler interface', function() {
|
2015-03-11 03:01:11 +02:00
|
|
|
ok(Flash.registerSourceHandler, 'has the registerSourceHandler function');
|
2014-12-03 00:22:34 +02:00
|
|
|
});
|
2015-03-24 20:52:04 +02:00
|
|
|
|
|
|
|
test('canHandleSource should be able to work with src objects without a type', function () {
|
2015-04-04 00:15:42 +02:00
|
|
|
var canHandleSource = Flash.nativeSourceHandler.canHandleSource;
|
2015-03-24 20:52:04 +02:00
|
|
|
equal('maybe', canHandleSource({src: 'test.video.mp4'}), 'should guess that it is a mp4 video');
|
|
|
|
equal('maybe', canHandleSource({src: 'test.video.m4v'}), 'should guess that it is a m4v video');
|
|
|
|
equal('maybe', canHandleSource({src: 'test.video.flv'}), 'should guess that it is a flash video');
|
|
|
|
equal('', canHandleSource({src: 'test.video.wgg'}), 'should return empty string if it can not play the video');
|
|
|
|
});
|
2015-06-08 22:47:04 +02:00
|
|
|
|
|
|
|
test('seekable should be for the length of the loaded video', function() {
|
|
|
|
let duration = 23;
|
|
|
|
|
|
|
|
// mock out duration
|
|
|
|
tech.el().vjs_getProperty = function(name) {
|
|
|
|
if (name === 'duration') {
|
|
|
|
return duration;
|
|
|
|
}
|
|
|
|
};
|
|
|
|
equal(tech.seekable().length, 1, 'seekable is non-empty');
|
|
|
|
equal(tech.seekable().start(0), 0, 'starts at zero');
|
|
|
|
equal(tech.seekable().end(0), duration, 'ends at the duration');
|
|
|
|
});
|
|
|
|
|
|
|
|
test('seekable should be empty if no video is loaded', function() {
|
|
|
|
// mock out duration
|
|
|
|
tech.el().vjs_getProperty = function(name) {
|
|
|
|
if (name === 'duration') {
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
equal(tech.seekable().length, 0, 'seekable is empty');
|
|
|
|
});
|