blob: e8e1e54790b6c7a90ed48ee12be8d795dcab290c [file] [log] [blame]
function runTest(config,qualifier) {
var testname = testnamePrefix(qualifier, config.keysystem)
+ ', persistent-usage-record, '
+ /video\/([^;]*)/.exec(config.videoType)[1]
+ ', playback, check events';
var configuration = { initDataTypes: [config.initDataType ],
audioCapabilities: [{contentType: config.audioType}],
videoCapabilities: [{contentType: config.videoType}],
sessionTypes: ['persistent-usage-record']};
async_test(function(test) {
var _video = config.video,
_mediaKeys,
_mediaKeySession,
_sessionId,
_timeupdateEvent = false,
_events = [ ];
function recordEventFunc(eventType) {
return function() { _events.push(eventType); };
}
function onFailure(error) {
forceTestFailureFromPromise(test, error);
}
function onMessage(event) {
assert_equals(event.target, _mediaKeySession);
assert_true(event instanceof window.MediaKeyMessageEvent);
assert_equals(event.type, 'message');
if (event.messageType !== 'individualization-request') {
_events.push(event.messageType);
}
config.messagehandler(event.messageType, event.message).then(function(response) {
_events.push(event.messageType + '-response');
return _mediaKeySession.update(response);
}).then(test.step_func(function() {
_events.push('update-resolved');
if (event.messageType === 'license-release') {
checkEventSequence( _events,
['encrypted','generaterequest-done',
['license-request', 'license-request-response', 'update-resolved'], // potentially repeating
'keystatuseschange',
'playing',
'remove-resolved',
'keystatuseschange',
'license-release',
'license-release-response',
'closed-attribute-resolved',
'update-resolved' ]);
test.done();
}
if ( event.messageType === 'license-request' ) {
_video.setMediaKeys(_mediaKeys);
}
})).catch(onFailure);
}
function onEncrypted(event) {
assert_equals(event.target, _video);
assert_true(event instanceof window.MediaEncryptedEvent);
_events.push(event.type);
_mediaKeySession.generateRequest( config.initDataType || event.initDataType,
config.initData || event.initData ).then( function() {
_events.push( 'generaterequest-done' );
_sessionId = _mediaKeySession.sessionId;
}).catch(onFailure);
}
function onTimeupdate(event) {
if (_video.currentTime > (config.duration || 1) && !_timeupdateEvent) {
_timeupdateEvent = true;
_video.pause();
_mediaKeySession.remove().then(recordEventFunc('remove-resolved')).catch(onFailure);
}
}
navigator.requestMediaKeySystemAccess(config.keysystem, [configuration]).then(function(access) {
return access.createMediaKeys();
}).then(function(mediaKeys) {
_mediaKeys = mediaKeys;
waitForEventAndRunStep('encrypted', _video, onEncrypted, test);
waitForEventAndRunStep('playing', _video, recordEventFunc('playing'), test);
// Not using waitForEventAndRunStep() to avoid too many
// EVENT(onTimeUpdate) logs.
_video.addEventListener('timeupdate', onTimeupdate, true);
_mediaKeySession = _mediaKeys.createSession( 'persistent-usage-record' );
waitForEventAndRunStep('message', _mediaKeySession, onMessage, test);
waitForEventAndRunStep('keystatuseschange', _mediaKeySession, recordEventFunc('keystatuseschange'), test);
_mediaKeySession.closed.then(recordEventFunc('closed-attribute-resolved'));
return config.servercertificate ? _mediaKeys.setServerCertificate(config.servercertificate) : true;
}).then(function( success ) {
return testmediasource(config);
}).then(function(source) {
_video.src = URL.createObjectURL(source);
return source.done;
}).then(function(){
_video.play();
}).catch(onFailure);
}, testname);
}