summaryrefslogtreecommitdiffstats
path: root/testing/web-platform/tests/encrypted-media
diff options
context:
space:
mode:
authorMoonchild <moonchild@palemoon.org>2021-02-25 01:03:57 +0000
committerMoonchild <moonchild@palemoon.org>2021-02-25 01:03:57 +0000
commitceadffab6b357723981a429e11222daf6cd6dcfb (patch)
tree5603053048d6a460f79b22bdf165fb74d32d39b0 /testing/web-platform/tests/encrypted-media
parent14fb2f966e9b54598c451e3cb35b4aa0480dafed (diff)
parentad5a13bd501e379517da1a944c104a11d951a3f5 (diff)
downloadUXP-ceadffab6b357723981a429e11222daf6cd6dcfb.tar
UXP-ceadffab6b357723981a429e11222daf6cd6dcfb.tar.gz
UXP-ceadffab6b357723981a429e11222daf6cd6dcfb.tar.lz
UXP-ceadffab6b357723981a429e11222daf6cd6dcfb.tar.xz
UXP-ceadffab6b357723981a429e11222daf6cd6dcfb.zip
Merge branch 'master' into releaseRC_20210225
Diffstat (limited to 'testing/web-platform/tests/encrypted-media')
-rw-r--r--testing/web-platform/tests/encrypted-media/EncryptedMediaExtensions.idl119
-rw-r--r--testing/web-platform/tests/encrypted-media/Google/chromium_specific_disabled/encrypted-media-async-creation-with-gc.html41
-rw-r--r--testing/web-platform/tests/encrypted-media/Google/chromium_specific_disabled/encrypted-media-async-setcert-with-gc.html32
-rw-r--r--testing/web-platform/tests/encrypted-media/Google/chromium_specific_disabled/encrypted-media-lifetime-mediakeys-with-session.html104
-rw-r--r--testing/web-platform/tests/encrypted-media/Google/chromium_specific_disabled/encrypted-media-lifetime-mediakeys.html59
-rw-r--r--testing/web-platform/tests/encrypted-media/Google/chromium_specific_disabled/encrypted-media-lifetime-mediakeysession-reference.html157
-rw-r--r--testing/web-platform/tests/encrypted-media/Google/chromium_specific_disabled/encrypted-media-lifetime-mediakeysession-release-noreference.html131
-rw-r--r--testing/web-platform/tests/encrypted-media/Google/chromium_specific_disabled/encrypted-media-lifetime-mediakeysession-release.html118
-rw-r--r--testing/web-platform/tests/encrypted-media/Google/chromium_specific_disabled/encrypted-media-lifetime-multiple-mediakeys.html131
-rw-r--r--testing/web-platform/tests/encrypted-media/Google/chromium_specific_disabled/encrypted-media-lifetime-reload.html103
-rw-r--r--testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-check-init-data-type.html51
-rw-r--r--testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-clear-key-invalid-license.html47
-rw-r--r--testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-clearkey-update-non-ascii-input.html53
-rw-r--r--testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-events.html65
-rw-r--r--testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-generate-request-disallowed-input.html107
-rw-r--r--testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-keystatuses-multiple-sessions.html121
-rw-r--r--testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-keystatuses-multiple-updates.html87
-rw-r--r--testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-keystatuses.html174
-rw-r--r--testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-not-callable-after-createsession.html67
-rw-r--r--testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-onencrypted.html44
-rw-r--r--testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-playback-encrypted-and-clear-sources.html130
-rw-r--r--testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-playback-multiple-sessions.html143
-rw-r--r--testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-playback-setmediakeys-after-src.html96
-rw-r--r--testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-playback-setmediakeys-before-src.html96
-rw-r--r--testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-playback-two-videos.html90
-rw-r--r--testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-requestmediakeysystemaccess.html322
-rw-r--r--testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-reset-src-after-setmediakeys.html67
-rw-r--r--testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-session-closed-event.html51
-rw-r--r--testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-setmediakeys-again-after-playback.html48
-rw-r--r--testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-setmediakeys-again-after-resetting-src.html44
-rw-r--r--testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-setmediakeys-at-same-time.html109
-rw-r--r--testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-setmediakeys-multiple-times-with-different-mediakeys.html83
-rw-r--r--testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-setmediakeys-multiple-times-with-the-same-mediakeys.html50
-rw-r--r--testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-setmediakeys-to-multiple-video-elements.html50
-rw-r--r--testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-setmediakeys.html59
-rw-r--r--testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-syntax.html1017
-rw-r--r--testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-unique-origin.html79
-rw-r--r--testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-update-disallowed-input.html73
-rw-r--r--testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-utils.js333
-rw-r--r--testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-waiting-for-a-key.html168
-rw-r--r--testing/web-platform/tests/encrypted-media/Google/webm/test-encrypted-different-av-keys.webmbin221378 -> 0 bytes
-rw-r--r--testing/web-platform/tests/encrypted-media/Google/webm/test-encrypted.webmbin223402 -> 0 bytes
-rw-r--r--testing/web-platform/tests/encrypted-media/Google/webm/test.webmbin219448 -> 0 bytes
-rw-r--r--testing/web-platform/tests/encrypted-media/OWNERS1
-rw-r--r--testing/web-platform/tests/encrypted-media/README.md7
-rw-r--r--testing/web-platform/tests/encrypted-media/clearkey-check-initdata-type.html32
-rw-r--r--testing/web-platform/tests/encrypted-media/clearkey-events-session-closed-event.html40
-rw-r--r--testing/web-platform/tests/encrypted-media/clearkey-events.html44
-rw-r--r--testing/web-platform/tests/encrypted-media/clearkey-generate-request-disallowed-input.html32
-rw-r--r--testing/web-platform/tests/encrypted-media/clearkey-invalid-license.html31
-rw-r--r--testing/web-platform/tests/encrypted-media/clearkey-keystatuses-multiple-sessions.html51
-rw-r--r--testing/web-platform/tests/encrypted-media/clearkey-keystatuses.html50
-rw-r--r--testing/web-platform/tests/encrypted-media/clearkey-mp4-playback-destroy-persistent-license.html52
-rw-r--r--testing/web-platform/tests/encrypted-media/clearkey-mp4-playback-persistent-license-events.html52
-rw-r--r--testing/web-platform/tests/encrypted-media/clearkey-mp4-playback-persistent-license.html52
-rw-r--r--testing/web-platform/tests/encrypted-media/clearkey-mp4-playback-persistent-usage-record-events.html52
-rw-r--r--testing/web-platform/tests/encrypted-media/clearkey-mp4-playback-persistent-usage-record.html52
-rw-r--r--testing/web-platform/tests/encrypted-media/clearkey-mp4-playback-retrieve-destroy-persistent-license.html53
-rw-r--r--testing/web-platform/tests/encrypted-media/clearkey-mp4-playback-retrieve-persistent-license.html53
-rw-r--r--testing/web-platform/tests/encrypted-media/clearkey-mp4-playback-retrieve-persistent-usage-record.html52
-rw-r--r--testing/web-platform/tests/encrypted-media/clearkey-mp4-playback-temporary-clear-encrypted.html53
-rw-r--r--testing/web-platform/tests/encrypted-media/clearkey-mp4-playback-temporary-encrypted-clear-sources.html58
-rw-r--r--testing/web-platform/tests/encrypted-media/clearkey-mp4-playback-temporary-encrypted-clear.html53
-rw-r--r--testing/web-platform/tests/encrypted-media/clearkey-mp4-playback-temporary-events.html52
-rw-r--r--testing/web-platform/tests/encrypted-media/clearkey-mp4-playback-temporary-multikey-sequential-readyState.html55
-rw-r--r--testing/web-platform/tests/encrypted-media/clearkey-mp4-playback-temporary-multikey-sequential.html54
-rw-r--r--testing/web-platform/tests/encrypted-media/clearkey-mp4-playback-temporary-multikey.html53
-rw-r--r--testing/web-platform/tests/encrypted-media/clearkey-mp4-playback-temporary-multisession.html52
-rw-r--r--testing/web-platform/tests/encrypted-media/clearkey-mp4-playback-temporary-setMediaKeys-after-src.html52
-rw-r--r--testing/web-platform/tests/encrypted-media/clearkey-mp4-playback-temporary-setMediaKeys-after-update.html52
-rw-r--r--testing/web-platform/tests/encrypted-media/clearkey-mp4-playback-temporary-setMediaKeys-immediately.html52
-rw-r--r--testing/web-platform/tests/encrypted-media/clearkey-mp4-playback-temporary-setMediaKeys-onencrypted.html52
-rw-r--r--testing/web-platform/tests/encrypted-media/clearkey-mp4-playback-temporary-two-videos.html55
-rw-r--r--testing/web-platform/tests/encrypted-media/clearkey-mp4-playback-temporary-waitingforkey.html52
-rw-r--r--testing/web-platform/tests/encrypted-media/clearkey-mp4-playback-temporary.html52
-rw-r--r--testing/web-platform/tests/encrypted-media/clearkey-mp4-requestmediakeysystemaccess.html40
-rw-r--r--testing/web-platform/tests/encrypted-media/clearkey-mp4-reset-src-after-setmediakeys.html47
-rw-r--r--testing/web-platform/tests/encrypted-media/clearkey-mp4-setmediakeys-again-after-playback.html53
-rw-r--r--testing/web-platform/tests/encrypted-media/clearkey-mp4-setmediakeys-again-after-resetting-src.html53
-rw-r--r--testing/web-platform/tests/encrypted-media/clearkey-mp4-setmediakeys-at-same-time.html43
-rw-r--r--testing/web-platform/tests/encrypted-media/clearkey-mp4-setmediakeys-multiple-times-with-different-mediakeys.html49
-rw-r--r--testing/web-platform/tests/encrypted-media/clearkey-mp4-setmediakeys-multiple-times-with-the-same-mediakeys.html49
-rw-r--r--testing/web-platform/tests/encrypted-media/clearkey-mp4-setmediakeys-to-multiple-video-elements.html47
-rw-r--r--testing/web-platform/tests/encrypted-media/clearkey-mp4-setmediakeys.html43
-rw-r--r--testing/web-platform/tests/encrypted-media/clearkey-mp4-syntax-mediakeys.html42
-rw-r--r--testing/web-platform/tests/encrypted-media/clearkey-mp4-syntax-mediakeysession.html42
-rw-r--r--testing/web-platform/tests/encrypted-media/clearkey-mp4-syntax-mediakeysystemaccess.html42
-rw-r--r--testing/web-platform/tests/encrypted-media/clearkey-mp4-unique-origin.html43
-rw-r--r--testing/web-platform/tests/encrypted-media/clearkey-mp4-update-disallowed-input.html28
-rw-r--r--testing/web-platform/tests/encrypted-media/clearkey-mp4-waiting-for-a-key.html52
-rw-r--r--testing/web-platform/tests/encrypted-media/clearkey-not-callable-after-createsession.html35
-rw-r--r--testing/web-platform/tests/encrypted-media/clearkey-update-non-ascii-input.html36
-rw-r--r--testing/web-platform/tests/encrypted-media/content/audio_aac-lc_128k_2keys_2sess.mp4bin166614 -> 0 bytes
-rw-r--r--testing/web-platform/tests/encrypted-media/content/audio_aac-lc_128k_dashinit.mp4bin85332 -> 0 bytes
-rw-r--r--testing/web-platform/tests/encrypted-media/content/audio_aac-lc_128k_enc_dashinit.mp4bin90594 -> 0 bytes
-rw-r--r--testing/web-platform/tests/encrypted-media/content/content-metadata.js297
-rw-r--r--testing/web-platform/tests/encrypted-media/content/video_512x288_h264-360k_clear_dashinit.mp4bin238401 -> 0 bytes
-rw-r--r--testing/web-platform/tests/encrypted-media/content/video_512x288_h264-360k_clear_enc_dashinit.mp4bin241564 -> 0 bytes
-rw-r--r--testing/web-platform/tests/encrypted-media/content/video_512x288_h264-360k_dashinit.mp4bin1425859 -> 0 bytes
-rw-r--r--testing/web-platform/tests/encrypted-media/content/video_512x288_h264-360k_enc_2keys_2sess.mp4bin475456 -> 0 bytes
-rw-r--r--testing/web-platform/tests/encrypted-media/content/video_512x288_h264-360k_enc_clear_dashinit.mp4bin241049 -> 0 bytes
-rw-r--r--testing/web-platform/tests/encrypted-media/content/video_512x288_h264-360k_enc_dashinit.mp4bin241862 -> 0 bytes
-rw-r--r--testing/web-platform/tests/encrypted-media/content/video_512x288_h264-360k_multikey_dashinit.mp4bin246574 -> 0 bytes
-rw-r--r--testing/web-platform/tests/encrypted-media/content/video_512x288_h264-360k_multikey_key1_dashinit.mp40
-rw-r--r--testing/web-platform/tests/encrypted-media/content/video_512x288_h264-360k_multikey_key2_dashinit.mp4bin241870 -> 0 bytes
-rw-r--r--testing/web-platform/tests/encrypted-media/drm-check-initdata-type.html32
-rw-r--r--testing/web-platform/tests/encrypted-media/drm-events-session-closed-event.html39
-rw-r--r--testing/web-platform/tests/encrypted-media/drm-events.html71
-rw-r--r--testing/web-platform/tests/encrypted-media/drm-expiration.html67
-rw-r--r--testing/web-platform/tests/encrypted-media/drm-generate-request-disallowed-input.html32
-rw-r--r--testing/web-platform/tests/encrypted-media/drm-invalid-license.html32
-rw-r--r--testing/web-platform/tests/encrypted-media/drm-keystatuses-multiple-sessions.html55
-rw-r--r--testing/web-platform/tests/encrypted-media/drm-keystatuses.html52
-rw-r--r--testing/web-platform/tests/encrypted-media/drm-mp4-onencrypted.html47
-rw-r--r--testing/web-platform/tests/encrypted-media/drm-mp4-playback-destroy-persistent-license.html52
-rw-r--r--testing/web-platform/tests/encrypted-media/drm-mp4-playback-persistent-license-events.html52
-rw-r--r--testing/web-platform/tests/encrypted-media/drm-mp4-playback-persistent-license.html52
-rw-r--r--testing/web-platform/tests/encrypted-media/drm-mp4-playback-persistent-usage-record-events.html53
-rw-r--r--testing/web-platform/tests/encrypted-media/drm-mp4-playback-persistent-usage-record.html54
-rw-r--r--testing/web-platform/tests/encrypted-media/drm-mp4-playback-retrieve-destroy-persistent-license.html54
-rw-r--r--testing/web-platform/tests/encrypted-media/drm-mp4-playback-retrieve-persistent-license.html54
-rw-r--r--testing/web-platform/tests/encrypted-media/drm-mp4-playback-retrieve-persistent-usage-record.html53
-rw-r--r--testing/web-platform/tests/encrypted-media/drm-mp4-playback-temporary-clear-encrypted.html53
-rw-r--r--testing/web-platform/tests/encrypted-media/drm-mp4-playback-temporary-encrypted-clear-sources.html58
-rw-r--r--testing/web-platform/tests/encrypted-media/drm-mp4-playback-temporary-encrypted-clear.html53
-rw-r--r--testing/web-platform/tests/encrypted-media/drm-mp4-playback-temporary-events.html53
-rw-r--r--testing/web-platform/tests/encrypted-media/drm-mp4-playback-temporary-expired.html52
-rw-r--r--testing/web-platform/tests/encrypted-media/drm-mp4-playback-temporary-multikey-sequential-readyState.html58
-rw-r--r--testing/web-platform/tests/encrypted-media/drm-mp4-playback-temporary-multikey-sequential.html57
-rw-r--r--testing/web-platform/tests/encrypted-media/drm-mp4-playback-temporary-multikey.html52
-rw-r--r--testing/web-platform/tests/encrypted-media/drm-mp4-playback-temporary-multisession.html55
-rw-r--r--testing/web-platform/tests/encrypted-media/drm-mp4-playback-temporary-setMediaKeys-after-src.html52
-rw-r--r--testing/web-platform/tests/encrypted-media/drm-mp4-playback-temporary-setMediaKeys-after-update.html52
-rw-r--r--testing/web-platform/tests/encrypted-media/drm-mp4-playback-temporary-setMediaKeys-immediately.html52
-rw-r--r--testing/web-platform/tests/encrypted-media/drm-mp4-playback-temporary-setMediaKeys-onencrypted.html52
-rw-r--r--testing/web-platform/tests/encrypted-media/drm-mp4-playback-temporary-two-videos.html54
-rw-r--r--testing/web-platform/tests/encrypted-media/drm-mp4-playback-temporary-waitingforkey.html53
-rw-r--r--testing/web-platform/tests/encrypted-media/drm-mp4-playback-temporary.html52
-rw-r--r--testing/web-platform/tests/encrypted-media/drm-mp4-requestmediakeysystemaccess.html41
-rw-r--r--testing/web-platform/tests/encrypted-media/drm-mp4-reset-src-after-setmediakeys.html46
-rw-r--r--testing/web-platform/tests/encrypted-media/drm-mp4-setmediakeys-again-after-playback.html52
-rw-r--r--testing/web-platform/tests/encrypted-media/drm-mp4-setmediakeys-again-after-resetting-src.html52
-rw-r--r--testing/web-platform/tests/encrypted-media/drm-mp4-setmediakeys-at-same-time.html44
-rw-r--r--testing/web-platform/tests/encrypted-media/drm-mp4-setmediakeys-multiple-times-with-different-mediakeys.html50
-rw-r--r--testing/web-platform/tests/encrypted-media/drm-mp4-setmediakeys-multiple-times-with-the-same-mediakeys.html50
-rw-r--r--testing/web-platform/tests/encrypted-media/drm-mp4-setmediakeys-to-multiple-video-elements.html48
-rw-r--r--testing/web-platform/tests/encrypted-media/drm-mp4-setmediakeys.html44
-rw-r--r--testing/web-platform/tests/encrypted-media/drm-mp4-syntax-mediakeys.html43
-rw-r--r--testing/web-platform/tests/encrypted-media/drm-mp4-syntax-mediakeysession.html43
-rw-r--r--testing/web-platform/tests/encrypted-media/drm-mp4-syntax-mediakeysystemaccess.html43
-rw-r--r--testing/web-platform/tests/encrypted-media/drm-mp4-unique-origin.html44
-rw-r--r--testing/web-platform/tests/encrypted-media/drm-mp4-waiting-for-a-key.html52
-rw-r--r--testing/web-platform/tests/encrypted-media/drm-not-callable-after-createsession.html35
-rw-r--r--testing/web-platform/tests/encrypted-media/drm-temporary-license-type.html71
-rw-r--r--testing/web-platform/tests/encrypted-media/idlharness.html51
-rw-r--r--testing/web-platform/tests/encrypted-media/polyfill/cast-polyfill.js80
-rw-r--r--testing/web-platform/tests/encrypted-media/polyfill/chrome-polyfill.js37
-rw-r--r--testing/web-platform/tests/encrypted-media/polyfill/clearkey-polyfill.js510
-rw-r--r--testing/web-platform/tests/encrypted-media/polyfill/edge-keystatuses.js144
-rw-r--r--testing/web-platform/tests/encrypted-media/polyfill/edge-persistent-usage-record.js193
-rw-r--r--testing/web-platform/tests/encrypted-media/polyfill/firefox-polyfill.js23
-rw-r--r--testing/web-platform/tests/encrypted-media/polyfill/make-polyfill-tests.py29
-rw-r--r--testing/web-platform/tests/encrypted-media/resources/clearkey-retrieve-destroy-persistent-license.html106
-rw-r--r--testing/web-platform/tests/encrypted-media/resources/clearkey-retrieve-persistent-license.html74
-rw-r--r--testing/web-platform/tests/encrypted-media/resources/drm-retrieve-destroy-persistent-license.html107
-rw-r--r--testing/web-platform/tests/encrypted-media/resources/drm-retrieve-persistent-license.html72
-rw-r--r--testing/web-platform/tests/encrypted-media/resources/drm-retrieve-persistent-usage-record.html71
-rw-r--r--testing/web-platform/tests/encrypted-media/resources/retrieve-persistent-usage-record.html93
-rw-r--r--testing/web-platform/tests/encrypted-media/scripts/check-initdata-type.js35
-rw-r--r--testing/web-platform/tests/encrypted-media/scripts/clearkey-update-non-ascii-input.js48
-rw-r--r--testing/web-platform/tests/encrypted-media/scripts/events-session-closed-event.js52
-rw-r--r--testing/web-platform/tests/encrypted-media/scripts/events.js59
-rw-r--r--testing/web-platform/tests/encrypted-media/scripts/expiration.js43
-rw-r--r--testing/web-platform/tests/encrypted-media/scripts/generate-request-disallowed-input.js73
-rw-r--r--testing/web-platform/tests/encrypted-media/scripts/invalid-license.js33
-rw-r--r--testing/web-platform/tests/encrypted-media/scripts/keystatuses-multiple-sessions.js103
-rw-r--r--testing/web-platform/tests/encrypted-media/scripts/keystatuses.js165
-rw-r--r--testing/web-platform/tests/encrypted-media/scripts/not-callable-after-createsession.js50
-rw-r--r--testing/web-platform/tests/encrypted-media/scripts/onencrypted.js47
-rw-r--r--testing/web-platform/tests/encrypted-media/scripts/playback-destroy-persistent-license.js93
-rw-r--r--testing/web-platform/tests/encrypted-media/scripts/playback-persistent-license-events.js128
-rw-r--r--testing/web-platform/tests/encrypted-media/scripts/playback-persistent-license.js75
-rw-r--r--testing/web-platform/tests/encrypted-media/scripts/playback-persistent-usage-record-events.js113
-rw-r--r--testing/web-platform/tests/encrypted-media/scripts/playback-persistent-usage-record.js102
-rw-r--r--testing/web-platform/tests/encrypted-media/scripts/playback-retrieve-persistent-license.js106
-rw-r--r--testing/web-platform/tests/encrypted-media/scripts/playback-retrieve-persistent-usage-record.js108
-rw-r--r--testing/web-platform/tests/encrypted-media/scripts/playback-temporary-encrypted-clear-sources.js107
-rw-r--r--testing/web-platform/tests/encrypted-media/scripts/playback-temporary-events.js134
-rw-r--r--testing/web-platform/tests/encrypted-media/scripts/playback-temporary-expired.js84
-rw-r--r--testing/web-platform/tests/encrypted-media/scripts/playback-temporary-multikey-multisession.js91
-rw-r--r--testing/web-platform/tests/encrypted-media/scripts/playback-temporary-multikey-sequential.js122
-rw-r--r--testing/web-platform/tests/encrypted-media/scripts/playback-temporary-multisession.js74
-rw-r--r--testing/web-platform/tests/encrypted-media/scripts/playback-temporary-setMediaKeys.js103
-rw-r--r--testing/web-platform/tests/encrypted-media/scripts/playback-temporary-two-videos.js81
-rw-r--r--testing/web-platform/tests/encrypted-media/scripts/playback-temporary-waitingforkey.js69
-rw-r--r--testing/web-platform/tests/encrypted-media/scripts/playback-temporary.js80
-rw-r--r--testing/web-platform/tests/encrypted-media/scripts/requestmediakeysystemaccess.js320
-rw-r--r--testing/web-platform/tests/encrypted-media/scripts/reset-src-after-setmediakeys.js61
-rw-r--r--testing/web-platform/tests/encrypted-media/scripts/setmediakeys-again-after-playback.js79
-rw-r--r--testing/web-platform/tests/encrypted-media/scripts/setmediakeys-again-after-resetting-src.js79
-rw-r--r--testing/web-platform/tests/encrypted-media/scripts/setmediakeys-at-same-time.js59
-rw-r--r--testing/web-platform/tests/encrypted-media/scripts/setmediakeys-multiple-times-with-different-mediakeys.js86
-rw-r--r--testing/web-platform/tests/encrypted-media/scripts/setmediakeys-multiple-times-with-the-same-mediakeys.js46
-rw-r--r--testing/web-platform/tests/encrypted-media/scripts/setmediakeys-to-multiple-video-elements.js54
-rw-r--r--testing/web-platform/tests/encrypted-media/scripts/setmediakeys.js49
-rw-r--r--testing/web-platform/tests/encrypted-media/scripts/syntax-mediakeys.js184
-rw-r--r--testing/web-platform/tests/encrypted-media/scripts/syntax-mediakeysession.js445
-rw-r--r--testing/web-platform/tests/encrypted-media/scripts/syntax-mediakeysystemaccess.js144
-rw-r--r--testing/web-platform/tests/encrypted-media/scripts/temporary-license-type.js61
-rw-r--r--testing/web-platform/tests/encrypted-media/scripts/unique-origin.js64
-rw-r--r--testing/web-platform/tests/encrypted-media/scripts/update-disallowed-input.js45
-rw-r--r--testing/web-platform/tests/encrypted-media/scripts/waiting-for-a-key.js166
-rw-r--r--testing/web-platform/tests/encrypted-media/util/clearkey-messagehandler.js64
-rw-r--r--testing/web-platform/tests/encrypted-media/util/drm-messagehandler.js262
-rw-r--r--testing/web-platform/tests/encrypted-media/util/fetch.js456
-rw-r--r--testing/web-platform/tests/encrypted-media/util/testmediasource.js43
-rw-r--r--testing/web-platform/tests/encrypted-media/util/utf8.js22
-rw-r--r--testing/web-platform/tests/encrypted-media/util/utils.js271
218 files changed, 0 insertions, 16958 deletions
diff --git a/testing/web-platform/tests/encrypted-media/EncryptedMediaExtensions.idl b/testing/web-platform/tests/encrypted-media/EncryptedMediaExtensions.idl
deleted file mode 100644
index fbe898b20..000000000
--- a/testing/web-platform/tests/encrypted-media/EncryptedMediaExtensions.idl
+++ /dev/null
@@ -1,119 +0,0 @@
-// Encrypted Media Extensions WebIDL
-//
-// NOTE: Please update the link below to the specification version from
-// which this IDL was extracted.
-//
-// https://www.w3.org/TR/2016/WD-encrypted-media-20160610/
-// + commit 5499821932391ae2c2e53756ae7ab9fae89d5863
-//
-
-partial interface Navigator {
- Promise<MediaKeySystemAccess> requestMediaKeySystemAccess (DOMString keySystem, sequence<MediaKeySystemConfiguration> supportedConfigurations);
-};
-
-enum MediaKeysRequirement {
- "required",
- "optional",
- "not-allowed"
-};
-
-dictionary MediaKeySystemConfiguration {
- DOMString label = "";
- sequence<DOMString> initDataTypes = [];
- sequence<MediaKeySystemMediaCapability> audioCapabilities = [];
- sequence<MediaKeySystemMediaCapability> videoCapabilities = [];
- MediaKeysRequirement distinctiveIdentifier = "optional";
- MediaKeysRequirement persistentState = "optional";
- sequence<DOMString> sessionTypes;
-};
-
-dictionary MediaKeySystemMediaCapability {
- DOMString contentType = "";
- DOMString robustness = "";
-};
-
-interface MediaKeySystemAccess {
- readonly attribute DOMString keySystem;
- MediaKeySystemConfiguration getConfiguration ();
- Promise<MediaKeys> createMediaKeys ();
-};
-
-enum MediaKeySessionType {
- "temporary",
- "persistent-usage-record",
- "persistent-license"
-};
-
-interface MediaKeys {
- MediaKeySession createSession (optional MediaKeySessionType sessionType = "temporary");
- Promise<boolean> setServerCertificate (BufferSource serverCertificate);
-};
-
-interface MediaKeySession : EventTarget {
- readonly attribute DOMString sessionId;
- readonly attribute unrestricted double expiration;
- readonly attribute Promise<void> closed;
- readonly attribute MediaKeyStatusMap keyStatuses;
- attribute EventHandler onkeystatuseschange;
- attribute EventHandler onmessage;
- Promise<void> generateRequest (DOMString initDataType, BufferSource initData);
- Promise<boolean> load (DOMString sessionId);
- Promise<void> update (BufferSource response);
- Promise<void> close ();
- Promise<void> remove ();
-};
-
-interface MediaKeyStatusMap {
- iterable<BufferSource,MediaKeyStatus>;
- readonly attribute unsigned long size;
- boolean has (BufferSource keyId);
- any get (BufferSource keyId);
-};
-
-enum MediaKeyStatus {
- "usable",
- "expired",
- "released",
- "output-restricted",
- "output-downscaled",
- "status-pending",
- "internal-error"
-};
-
-enum MediaKeyMessageType {
- "license-request",
- "license-renewal",
- "license-release",
- "individualization-request"
-};
-
-[Constructor(DOMString type, MediaKeyMessageEventInit eventInitDict)]
-interface MediaKeyMessageEvent : Event {
- readonly attribute MediaKeyMessageType messageType;
- readonly attribute ArrayBuffer message;
-};
-
-dictionary MediaKeyMessageEventInit : EventInit {
- required MediaKeyMessageType messageType;
- required ArrayBuffer message;
-};
-
-// partial interface HTMLMediaElement : EventTarget {
-partial interface HTMLMediaElement {
- readonly attribute MediaKeys? mediaKeys;
- attribute EventHandler onencrypted;
- attribute EventHandler onwaitingforkey;
- Promise<void> setMediaKeys (MediaKeys? mediaKeys);
-};
-
-[Constructor(DOMString type, optional MediaEncryptedEventInit eventInitDict)]
-interface MediaEncryptedEvent : Event {
- readonly attribute DOMString initDataType;
- readonly attribute ArrayBuffer? initData;
-};
-
-dictionary MediaEncryptedEventInit : EventInit {
- DOMString initDataType = "";
- ArrayBuffer? initData = null;
-};
-
diff --git a/testing/web-platform/tests/encrypted-media/Google/chromium_specific_disabled/encrypted-media-async-creation-with-gc.html b/testing/web-platform/tests/encrypted-media/Google/chromium_specific_disabled/encrypted-media-async-creation-with-gc.html
deleted file mode 100644
index 4dd705f9f..000000000
--- a/testing/web-platform/tests/encrypted-media/Google/chromium_specific_disabled/encrypted-media-async-creation-with-gc.html
+++ /dev/null
@@ -1,41 +0,0 @@
-<!DOCTYPE html>
-<!-- Copyright © 2016 Chromium authors and World Wide Web Consortium, (Massachusetts Institute of Technology, ERCIM, Keio University, Beihang). -->
-<html>
- <head>
- <title>Test asynchronous creation of MediaKeys and MediaKeySession while running garbage collection</title>
- <script src="encrypted-media-utils.js"></script>
-<!--
- Test requires Chromium specific content and is being disabled.
- <script src="/resources/testharness.js"></script>
- <script src="/resources/testharnessreport.js"></script>
--->
- </head>
- <body>
- <div id="log"></div>
- <script>
- async_test(function(test)
- {
- // Run garbage collection often.
- setInterval(asyncGC, 0);
-
- var initDataType;
- var initData;
- var mediaKeySession;
- navigator.requestMediaKeySystemAccess('org.w3.clearkey', getSimpleConfiguration()).then(function(access) {
- initDataType = access.getConfiguration().initDataTypes[0];
- initData = getInitData(initDataType);
- return access.createMediaKeys();
- }).then(function(mediaKeys) {
- mediaKeySession = mediaKeys.createSession();
- return mediaKeySession.generateRequest(initDataType, initData);
- }).then(function() {
- return mediaKeySession.close();
- }).then(function(result) {
- test.done();
- }).catch(function(error) {
- forceTestFailureFromPromise(test, error);
- });
- }, 'Test asynchronous creation of MediaKeys and MediaKeySession while running garbage collection.');
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/Google/chromium_specific_disabled/encrypted-media-async-setcert-with-gc.html b/testing/web-platform/tests/encrypted-media/Google/chromium_specific_disabled/encrypted-media-async-setcert-with-gc.html
deleted file mode 100644
index 4da562894..000000000
--- a/testing/web-platform/tests/encrypted-media/Google/chromium_specific_disabled/encrypted-media-async-setcert-with-gc.html
+++ /dev/null
@@ -1,32 +0,0 @@
-<!DOCTYPE html>
-<!-- Copyright © 2016 Chromium authors and World Wide Web Consortium, (Massachusetts Institute of Technology, ERCIM, Keio University, Beihang). -->
-<html>
- <head>
- <title>Test asynchronous setServerCertificate while running garbage collection</title>
- <script src="encrypted-media-utils.js"></script>
-<!--
- Test requires Chromium specific content and is being disabled.
- <script src="/resources/testharness.js"></script>
- <script src="/resources/testharnessreport.js"></script>
--->
- </head>
- <body>
- <div id="log"></div>
- <script>
- // Run garbage collection continuously.
- setInterval(asyncGC, 0);
-
- promise_test(function(test)
- {
- return navigator.requestMediaKeySystemAccess('org.w3.clearkey', getSimpleConfiguration()).then(function(access) {
- return access.createMediaKeys();
- }).then(function(mediaKeys) {
- var cert = new Uint8Array(200);
- return mediaKeys.setServerCertificate(cert);
- }).then(function(result) {
- assert_false(result);
- });
- }, 'Test asynchronous setServerCertificate while running garbage collection.');
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/Google/chromium_specific_disabled/encrypted-media-lifetime-mediakeys-with-session.html b/testing/web-platform/tests/encrypted-media/Google/chromium_specific_disabled/encrypted-media-lifetime-mediakeys-with-session.html
deleted file mode 100644
index a892b969c..000000000
--- a/testing/web-platform/tests/encrypted-media/Google/chromium_specific_disabled/encrypted-media-lifetime-mediakeys-with-session.html
+++ /dev/null
@@ -1,104 +0,0 @@
-<!DOCTYPE html>
-<!-- Copyright © 2016 Chromium authors and World Wide Web Consortium, (Massachusetts Institute of Technology, ERCIM, Keio University, Beihang). -->
-<html>
- <head>
- <title>Test MediaKeys lifetime when adding a session</title>
- <script src="encrypted-media-utils.js"></script>
-<!--
- Test requires Chromium specific content and is being disabled.
- <script src="/resources/testharness.js"></script>
- <script src="/resources/testharnessreport.js"></script>
--->
- </head>
- <body>
- <div id="log"></div>
- <script>
- // MediaKeySessions remain as long as:
- // JavaScript has a reference to it
- // OR (MediaKeys is around
- // AND the session has not received a close() event)
- // In the tests below, we do not close any session nor keep a
- // Javascript reference to any session, so MediaKeySessions remain
- // as long as the associated MediaKeys object is around.
-
- // For this test, create a MediaKeySession and verify lifetime.
- async_test(function(test)
- {
- var initDataType;
- var initData;
- var mediaKeys;
- var startingActiveDOMObjectCount = window.internals.activeDOMObjectCount(document);
-
- function numActiveDOMObjectsCreated()
- {
- return window.internals.activeDOMObjectCount(document) - startingActiveDOMObjectCount;
- }
-
- // Create a MediaKeys object with a session.
- navigator.requestMediaKeySystemAccess('org.w3.clearkey', getSimpleConfiguration()).then(function(access) {
- initDataType = access.getConfiguration().initDataTypes[0];
- initData = getInitData(initDataType);
- return access.createMediaKeys();
- }).then(function(result) {
- mediaKeys = result;
-
- // Verify MediaKeys is an ActiveDOMObject.
- // In non-Oilpan, numActiveDOMObjectsCreate() == 1.
- // In Oilpan, numActiveDOMObjectsCreate() <= 4.
- // (1 MediaKeys,
- // 1 MediaKeysInitializer and
- // 1 MediaKeySystemAccessInitializer (navigator.requestMediaKeySystemAccess() use above),
- // 1 MediaKeySystemAccessInitializer (isInitDataSupported() (via getSupportedInitDataType())))
- assert_between_inclusive(numActiveDOMObjectsCreated(), 1, 4, 'MediaKeys.create()');
-
- var mediaKeySession = mediaKeys.createSession();
- return mediaKeySession.generateRequest(initDataType, initData);
- }).then(function() {
- // Should be 1 MediaKeys + 1 MediaKeySession.
- // In non-Oilpan, numActiveDOMObjectsCreate() == 2.
- // In Oilpan, numActiveDOMObjectsCreate() <= 6.
- // (1 MediaKeys,
- // 1 MediaKeysInitializer and
- // 2 MediaKeySystemAccessInitializer,
- // 1 ContentDecryptionModuleResultPromise and
- // 1 MediaKeySession).
- assert_between_inclusive(numActiveDOMObjectsCreated(), 2, 6, 'MediaKeys.createSession()');
-
- // Run gc(), should not affect MediaKeys object nor the
- // session since we still have a reference to it.
-
- // When enabling oilpan GC, the in-active
- // ScriptPromiseResolvers will be destroyed.
- return createGCPromise();
- }).then(function(result) {
- assert_equals(typeof mediaKeys.createSession, 'function');
-
- // MediaKeys + MediaKeySessions should remain.
- // In non-Oilpan, there is also something from createGCPromise().
- assert_between_inclusive(numActiveDOMObjectsCreated(), 2, 3, 'After gc()');
-
- // Drop reference to the MediaKeys object and run gc()
- // again. Object should be collected this time. Since
- // MediaKeySessions remain alive as long as MediaKeys is
- // around, it is possible that gc() checks the
- // MediaKeySession object first, and doesn't collect it
- // since MediaKeys hasn't been collected yet. Thus run gc()
- // twice, to ensure that the unreferenced MediaKeySession
- // object get collected.
- mediaKeys = null;
- return createGCPromise();
- }).then(function(result) {
- return createGCPromise();
- }).then(function(result) {
- // No MediaKeySessions should remain.
- // In non-Oilpan, there is also something from createGCPromise().
- assert_between_inclusive(numActiveDOMObjectsCreated(), 0, 1, 'After final gc()');
-
- test.done();
- }).catch(function(error) {
- forceTestFailureFromPromise(test, error);
- });
- }, 'MediaKeys lifetime with session');
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/Google/chromium_specific_disabled/encrypted-media-lifetime-mediakeys.html b/testing/web-platform/tests/encrypted-media/Google/chromium_specific_disabled/encrypted-media-lifetime-mediakeys.html
deleted file mode 100644
index b8e79ac8b..000000000
--- a/testing/web-platform/tests/encrypted-media/Google/chromium_specific_disabled/encrypted-media-lifetime-mediakeys.html
+++ /dev/null
@@ -1,59 +0,0 @@
-<!DOCTYPE html>
-<!-- Copyright © 2016 Chromium authors and World Wide Web Consortium, (Massachusetts Institute of Technology, ERCIM, Keio University, Beihang). -->
-<html>
- <head>
- <title>Test MediaKeys lifetime</title>
- <script src="encrypted-media-utils.js"></script>
-<!--
- Test requires Chromium specific content and is being disabled.
- <script src="/resources/testharness.js"></script>
- <script src="/resources/testharnessreport.js"></script>
--->
- </head>
- <body>
- <div id="log"></div>
- <script>
- async_test(function(test)
- {
- // Create a MediaKeys object and free immediately.
- navigator.requestMediaKeySystemAccess('org.w3.clearkey', getSimpleConfiguration()).then(function(access) {
- return access.createMediaKeys();
- }).then(function(result) {
- // Do nothing with the created object
- }).then(function(result) {
- // No way to verify that MediaKeys object is actually
- // collected, but make sure it doesn't crash.
- return createGCPromise();
- }).then(function(result) {
- test.done();
- }).catch(function(error) {
- forceTestFailureFromPromise(test, error);
- });
- }, 'Creating and destroying MediaKeys does not crash');
-
- async_test(function(test)
- {
- var mediaKeys;
- navigator.requestMediaKeySystemAccess('org.w3.clearkey', getSimpleConfiguration()).then(function(access) {
- return access.createMediaKeys();
- }).then(function(result) {
- mediaKeys = result;
- return createGCPromise();
- }).then(function(result) {
- // Check that the object still exists.
- assert_equals(typeof mediaKeys.createSession, 'function');
- mediaKeys = null;
-
- // Now that the reference is dropped, it should be
- // collected. No way to verify that it is actually
- // collected, but make sure it doesn't crash.
- return createGCPromise();
- }).then(function(result) {
- test.done();
- }).catch(function(error) {
- forceTestFailureFromPromise(test, error);
- });
- }, 'MediaKeys is not collected as long as we have a reference');
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/Google/chromium_specific_disabled/encrypted-media-lifetime-mediakeysession-reference.html b/testing/web-platform/tests/encrypted-media/Google/chromium_specific_disabled/encrypted-media-lifetime-mediakeysession-reference.html
deleted file mode 100644
index 4b8ad1b46..000000000
--- a/testing/web-platform/tests/encrypted-media/Google/chromium_specific_disabled/encrypted-media-lifetime-mediakeysession-reference.html
+++ /dev/null
@@ -1,157 +0,0 @@
-<!DOCTYPE html>
-<!-- Copyright © 2016 Chromium authors and World Wide Web Consortium, (Massachusetts Institute of Technology, ERCIM, Keio University, Beihang). -->
-<html>
- <head>
- <title>Test MediaKeySession lifetime without release()</title>
- <script src="encrypted-media-utils.js"></script>
-<!--
- Test requires Chromium specific content and is being disabled.
- <script src="/resources/testharness.js"></script>
- <script src="/resources/testharnessreport.js"></script>
--->
- </head>
- <body>
- <div id="log"></div>
- <script>
- // Since MediaKeySession (and MediaKeys) are ActiveDOMObjects,
- // we can determine when they are garbage collected.
- // MediaKeySessions remain as long as:
- // JavaScript has a reference to it
- // OR (MediaKeys is around
- // AND the session has not received a close() event)
-
- async_test(function(test)
- {
- var mediaKeys;
- var mediaKeySession1;
- var mediaKeySession2;
- var mediaKeySession3;
- var initDataType;
- var initData;
- var startingActiveDOMObjectCount = window.internals.activeDOMObjectCount(document);
-
- function numActiveDOMObjectsCreated()
- {
- return window.internals.activeDOMObjectCount(document) - startingActiveDOMObjectCount;
- }
-
- navigator.requestMediaKeySystemAccess('org.w3.clearkey', getSimpleConfiguration()).then(function(access) {
- initDataType = access.getConfiguration().initDataTypes[0];
- initData = getInitData(initDataType);
- return access.createMediaKeys();
- }).then(function(result) {
- mediaKeys = result;
- assert_equals(typeof mediaKeys.createSession, 'function');
-
- // Verify MediaKeys is an ActiveDOMObject.
- // In non-Oilpan, numActiveDOMObjectsCreate() == 1.
- // In Oilpan, numActiveDOMObjectsCreate() <= 4.
- // (1 MediaKeys,
- // 1 MediaKeysInitializer and
- // 1 MediaKeySystemAccessInitializer (navigator.requestMediaKeySystemAccess() use above),
- // 1 MediaKeySystemAccessInitializer (isInitDataSupported() (via getSupportedInitDataType())))
- assert_between_inclusive(numActiveDOMObjectsCreated(), 1, 4, 'MediaKeys.create()');
-
- // Create 3 sessions.
- mediaKeySession1 = mediaKeys.createSession();
- return mediaKeySession1.generateRequest(initDataType, initData);
- }).then(function() {
- assert_true(mediaKeySession1.sessionId && mediaKeySession1.sessionId.length > 0);
-
- // Should be 1 MediaKeys + 1 MediaKeySession.
- // In non-Oilpan, numActiveDOMObjectsCreate() == 2.
- // In Oilpan, numActiveDOMObjectsCreate() <= 6.
- // (1 MediaKeys,
- // 1 MediaKeysInitializer and
- // 2 MediaKeySystemAccessInitializer,
- // 1 ContentDecryptionModuleResultPromise and
- // 1 MediaKeySession).
- assert_between_inclusive(numActiveDOMObjectsCreated(), 2, 6, 'MediaKeys.createSession(1)');
-
- mediaKeySession2 = mediaKeys.createSession();
- return mediaKeySession2.generateRequest(initDataType, initData);
- }).then(function() {
- assert_true(mediaKeySession2.sessionId && mediaKeySession2.sessionId.length > 0);
-
- // Should be 1 MediaKeys + 2 MediaKeySessions.
- // In non-Oilpan, numActiveDOMObjectsCreate() == 3.
- // In Oilpan, numActiveDOMObjectsCreate() <= 8.
- // (1 MediaKeys,
- // 1 MediaKeysInitializer and
- // 2 MediaKeySystemAccessInitializers,
- // 2 ContentDecryptionModuleResultPromise and
- // 2 MediaKeySession).
- assert_between_inclusive(numActiveDOMObjectsCreated(), 3, 8, 'mediaKeys.createSession(2)');
-
- mediaKeySession3 = mediaKeys.createSession();
- return mediaKeySession3.generateRequest(initDataType, initData);
- }).then(function() {
- assert_true(mediaKeySession3.sessionId && mediaKeySession3.sessionId.length > 0);
-
- // Should be 1 MediaKeys + 3 MediaKeySessions.
- // In non-Oilpan, numActiveDOMObjectsCreate() == 4.
- // In Oilpan, numActiveDOMObjectsCreate() <= 10.
- // (1 MediaKeys,
- // 1 MediaKeysInitializer and
- // 2 MediaKeySystemAccessInitializers,
- // 3 ContentDecryptionModuleResultPromise and
- // 3 MediaKeySession).
- assert_between_inclusive(numActiveDOMObjectsCreated(), 4, 10, 'mediaKeys.createSession(3)');
-
- // Run gc(). All sessions should remain as we have a
- // reference to each one. However, running gc()
- // asynchronously should free up the last PromiseResolver.
- return createGCPromise();
- }).then(function(result) {
- // Only MediaKeys + 3 MediaKeySessions should remain.
- // In non-Oilpan, there is also something from createGCPromise().
- assert_between_inclusive(numActiveDOMObjectsCreated(), 4, 5, 'After gc()');
-
- // Now drop references to 2 of the sessions. Even though we
- // don't have a reference, MediaKeys is still around (and
- // the sessions aren't closed), so the objects won't be
- // collected.
- mediaKeySession1 = null;
- mediaKeySession2 = null;
- return createGCPromise();
- }).then(function(result) {
- return createGCPromise();
- }).then(function(result) {
- // MediaKeys + 3 MediaKeySessions should remain.
- // In non-Oilpan, there is also something from createGCPromise().
- assert_between_inclusive(numActiveDOMObjectsCreated(), 4, 5, 'After second gc()');
-
- // Now drop the reference to MediaKeys. It and the 2
- // unreferenced sessions should be collected. Since
- // MediaKeySessions remain alive as long as MediaKeys is
- // around, it is possible that gc() checks one or both
- // MediaKeySession objects first, and doesn't collect them
- // since MediaKeys hasn't been collected yet. Thus run gc()
- // twice, to ensure that the unreferenced MediaKeySession
- // objects get collected.
- mediaKeys = null;
- return createGCPromise();
- }).then(function(result) {
- return createGCPromise();
- }).then(function(result) {
- // Only 1 MediaKeySessions should remain.
- // In non-Oilpan, there is also something from createGCPromise().
- assert_between_inclusive(numActiveDOMObjectsCreated(), 1, 2, 'After mediaKeys = null');
-
- // Drop the reference to the last session. It should get
- // collected now since MediaKeys is gone.
- mediaKeySession3 = null;
- return createGCPromise();
- }).then(function(result) {
- // No MediaKeySessions should remain.
- // In non-Oilpan, there is also something from createGCPromise().
- assert_between_inclusive(numActiveDOMObjectsCreated(), 0, 1, 'After final gc()');
-
- test.done();
- }).catch(function(error) {
- forceTestFailureFromPromise(test, error);
- });
- }, 'MediaKeySession lifetime without release()');
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/Google/chromium_specific_disabled/encrypted-media-lifetime-mediakeysession-release-noreference.html b/testing/web-platform/tests/encrypted-media/Google/chromium_specific_disabled/encrypted-media-lifetime-mediakeysession-release-noreference.html
deleted file mode 100644
index a962844a3..000000000
--- a/testing/web-platform/tests/encrypted-media/Google/chromium_specific_disabled/encrypted-media-lifetime-mediakeysession-release-noreference.html
+++ /dev/null
@@ -1,131 +0,0 @@
-<!DOCTYPE html>
-<!-- Copyright © 2016 Chromium authors and World Wide Web Consortium, (Massachusetts Institute of Technology, ERCIM, Keio University, Beihang). -->
-<html>
- <head>
- <title>Test MediaKeySession lifetime after release() without references</title>
- <script src="encrypted-media-utils.js"></script>
-<!--
- Test requires Chromium specific content and is being disabled.
- <script src="/resources/testharness.js"></script>
- <script src="/resources/testharnessreport.js"></script>
--->
- </head>
- <body>
- <div id="log"></div>
- <script>
- // Since MediaKeySession (and MediaKeys) are ActiveDOMObjects,
- // we can determine when they are garbage collected.
- // MediaKeySessions remain as long as:
- // JavaScript has a reference to it
- // OR (MediaKeys is around
- // AND the session has not received a close() event)
- async_test(function(test)
- {
- var initDataType;
- var initData;
- var startingActiveDOMObjectCount = window.internals.activeDOMObjectCount(document);
-
- function numActiveDOMObjectsCreated()
- {
- return window.internals.activeDOMObjectCount(document) - startingActiveDOMObjectCount;
- }
-
- // Create 2 sessions.
- var mediaKeys;
- var mediaKeySession1;
- var mediaKeySession2;
-
- navigator.requestMediaKeySystemAccess('org.w3.clearkey', getSimpleConfiguration()).then(function(access) {
- initDataType = access.getConfiguration().initDataTypes[0];
- initData = getInitData(initDataType);
- return access.createMediaKeys();
- }).then(function(result) {
- mediaKeys = result;
-
- // Verify MediaKeys is an ActiveDOMObject.
- // In non-Oilpan, numActiveDOMObjectsCreate() == 1.
- // In Oilpan, numActiveDOMObjectsCreate() <= 4.
- // (1 MediaKeys,
- // 1 MediaKeysInitializer and
- // 1 MediaKeySystemAccessInitializer (navigator.requestMediaKeySystemAccess() use above),
- // 1 MediaKeySystemAccessInitializer (isInitDataSupported() (via getSupportedInitDataType())))
- assert_between_inclusive(numActiveDOMObjectsCreated(), 1, 4, 'MediaKeys.create()');
-
- mediaKeySession1 = mediaKeys.createSession();
- return mediaKeySession1.generateRequest(initDataType, initData);
- }).then(function() {
- assert_true(mediaKeySession1.sessionId && mediaKeySession1.sessionId.length > 0);
-
- // Should be 1 MediaKeys + 1 MediaKeySession.
- // In non-Oilpan, numActiveDOMObjectsCreate() == 2.
- // In Oilpan, numActiveDOMObjectsCreate() <= 6.
- // (1 MediaKeys,
- // 1 MediaKeysInitializer and
- // 2 MediaKeySystemAccessInitializer,
- // 1 ContentDecryptionModuleResultPromise and
- // 1 MediaKeySession).
- assert_between_inclusive(numActiveDOMObjectsCreated(), 2, 6, 'MediaKeys.createSession(1)');
-
- mediaKeySession2 = mediaKeys.createSession();
- return mediaKeySession2.generateRequest(initDataType, initData);
- }).then(function() {
- assert_true(mediaKeySession2.sessionId && mediaKeySession2.sessionId.length > 0);
-
- // Should be 1 MediaKeys + 2 MediaKeySessions.
- // In non-Oilpan, numActiveDOMObjectsCreate() == 3.
- // In Oilpan, numActiveDOMObjectsCreate() <= 8.
- // (1 MediaKeys,
- // 1 MediaKeysInitializer and
- // 2 MediaKeySystemAccessInitializers,
- // 2 ContentDecryptionModuleResultPromise and
- // 2 MediaKeySession).
- assert_between_inclusive(numActiveDOMObjectsCreated(), 3, 8, 'mediaKeys.createSession(2)');
- }).then(function(result) {
- // Run gc(). All sessions should remain as we have a
- // reference to each one.
- return createGCPromise();
- }).then(function(result) {
- // Should be just 1 MediaKeys + 2 MediaKeySessions.
- // In non-Oilpan, there is also something from createGCPromise().
- assert_between_inclusive(numActiveDOMObjectsCreated(), 3, 4, 'After gc()');
-
- // Close the sessions. Once the close() event is received,
- // they should get garbage collected as there are no JS
- // references to them.
- var promise = mediaKeySession1.close();
- mediaKeySession1 = null;
- return promise;
- }).then(function(result) {
- // Give time so that the close event can be processed by
- // MediaKeySession.
- return delayToAllowEventProcessingPromise();
- }).then(function(result) {
- return createGCPromise();
- }).then(function(result) {
- // Only MediaKeys + mediaKeySession2 should remain.
- // In non-Oilpan, there is also something from createGCPromise().
- assert_between_inclusive(numActiveDOMObjectsCreated(), 2, 3, 'mediaKeySession1 not collected');
-
- var promise = mediaKeySession2.close();
- mediaKeySession2 = null;
- return promise;
- }).then(function(result) {
- // Provide time for the mediaKeySession2 close event to be
- // handled.
- return delayToAllowEventProcessingPromise();
- }).then(function(result) {
- return createGCPromise();
- }).then(function(result) {
- // Only MediaKeys should remain.
- // In non-Oilpan, there is also something from createGCPromise().
- assert_between_inclusive(numActiveDOMObjectsCreated(), 1, 2, 'mediaKeySession2 not collected');
-
- assert_not_equals(mediaKeys, null);
- test.done();
- }).catch(function(error) {
- forceTestFailureFromPromise(test, error);
- });
- }, 'MediaKeySession lifetime after release() without references');
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/Google/chromium_specific_disabled/encrypted-media-lifetime-mediakeysession-release.html b/testing/web-platform/tests/encrypted-media/Google/chromium_specific_disabled/encrypted-media-lifetime-mediakeysession-release.html
deleted file mode 100644
index 626526761..000000000
--- a/testing/web-platform/tests/encrypted-media/Google/chromium_specific_disabled/encrypted-media-lifetime-mediakeysession-release.html
+++ /dev/null
@@ -1,118 +0,0 @@
-<!DOCTYPE html>
-<!-- Copyright © 2016 Chromium authors and World Wide Web Consortium, (Massachusetts Institute of Technology, ERCIM, Keio University, Beihang). -->
-<html>
- <head>
- <title>MediaKeySession lifetime after release()</title>
- <script src="encrypted-media-utils.js"></script>
-<!--
- Test requires Chromium specific content and is being disabled.
- <script src="/resources/testharness.js"></script>
- <script src="/resources/testharnessreport.js"></script>
--->
- </head>
- <body>
- <div id="log"></div>
- <script>
- // Since MediaKeySession (and MediaKeys) are ActiveDOMObjects,
- // we can determine when they are garbage collected.
- // MediaKeySessions remain as long as:
- // JavaScript has a reference to it
- // OR (MediaKeys is around
- // AND the session has not received a close() event)
- async_test(function(test)
- {
- var mediaKeys;
- var mediaKeySession1;
- var mediaKeySession2;
- var initDataType;
- var initData;
- var startingActiveDOMObjectCount = window.internals.activeDOMObjectCount(document);
-
- function numActiveDOMObjectsCreated()
- {
- return window.internals.activeDOMObjectCount(document) - startingActiveDOMObjectCount;
- }
-
- // Create 2 sessions.
- navigator.requestMediaKeySystemAccess('org.w3.clearkey', getSimpleConfiguration()).then(function(access) {
- initDataType = access.getConfiguration().initDataTypes[0];
- initData = getInitData(initDataType);
- return access.createMediaKeys();
- }).then(function(result) {
- mediaKeys = result;
-
- // Verify MediaKeys is an ActiveDOMObject.
- // In non-Oilpan, numActiveDOMObjectsCreate() == 1.
- // In Oilpan, numActiveDOMObjectsCreate() <= 4.
- // (1 MediaKeys,
- // 1 MediaKeysInitializer and
- // 1 MediaKeySystemAccessInitializer (navigator.requestMediaKeySystemAccess() use above),
- // 1 MediaKeySystemAccessInitializer (isInitDataSupported() (via getSupportedInitDataType())))
- assert_between_inclusive(numActiveDOMObjectsCreated(), 1, 4, 'MediaKeys.create()');
-
- mediaKeySession1 = mediaKeys.createSession();
- return mediaKeySession1.generateRequest(initDataType, initData);
- }).then(function() {
- // Should be 1 MediaKeys + 1 MediaKeySession.
- // In non-Oilpan, numActiveDOMObjectsCreate() == 2.
- // In Oilpan, numActiveDOMObjectsCreate() <= 6.
- // (1 MediaKeys,
- // 1 MediaKeysInitializer,
- // 2 MediaKeySystemAccessInitializers,
- // 1 ContentDecryptionModuleResultPromise and
- // 1 MediaKeySession).
- assert_between_inclusive(numActiveDOMObjectsCreated(), 2, 6, 'MediaKeys.createSession(1)');
-
- mediaKeySession2 = mediaKeys.createSession();
- return mediaKeySession2.generateRequest(initDataType, initData);
- }).then(function() {
- // Should be 1 MediaKeys + 2 MediaKeySessions.
- // In non-Oilpan, numActiveDOMObjectsCreate() == 3.
- // In Oilpan, numActiveDOMObjectsCreate() <= 8.
- // (1 MediaKeys,
- // 1 MediaKeysInitializer,
- // 2 MediaKeySystemAccessInitializers,
- // 2 ContentDecryptionModuleResultPromise and
- // 2 MediaKeySession).
- assert_between_inclusive(numActiveDOMObjectsCreated(), 3, 8, 'mediaKeys.createSession(2)');
-
- // Close the sessions. Once completed, only the JS
- // reference to them keeps them around.
- return mediaKeySession1.close();
- }).then(function(result) {
- return mediaKeySession2.close();
- }).then(function(result) {
- // Since both sessions have been closed, dropping the
- // reference to them from JS will result in the session
- // being garbage-collected.
- // Should be 1 MediaKeys + 2 MediaKeySessions.
- // In non-Oilpan, numActiveDOMObjectsCreate() == 3.
- // In Oilpan, numActiveDOMObjectsCreate() <= 10.
- // (1 MediaKeys,
- // 1 MediaKeysInitializer,
- // 2 MediaKeySystemAccessInitializers,
- // 4 ContentDecryptionModuleResultPromise and
- // 2 MediaKeySession).
- assert_between_inclusive(numActiveDOMObjectsCreated(), 3, 10, 'after close');
-
- mediaKeySession1 = null;
- return createGCPromise();
- }).then(function() {
- // Only MediaKeys + mediaKeySession2 should remain.
- // In non-Oilpan, there is also something from createGCPromise().
- assert_between_inclusive(numActiveDOMObjectsCreated(), 2, 3, 'mediaKeySession1 not collected');
-
- mediaKeySession2 = null;
- return createGCPromise();
- }).then(function() {
- // Only MediaKeys should remain.
- // In non-Oilpan, there is also something from createGCPromise().
- assert_between_inclusive(numActiveDOMObjectsCreated(), 1, 2, 'mediaKeySession2 not collected');
- test.done();
- }).catch(function(error) {
- forceTestFailureFromPromise(test, error);
- });
- }, 'MediaKeySession lifetime after release()');
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/Google/chromium_specific_disabled/encrypted-media-lifetime-multiple-mediakeys.html b/testing/web-platform/tests/encrypted-media/Google/chromium_specific_disabled/encrypted-media-lifetime-multiple-mediakeys.html
deleted file mode 100644
index 42638a069..000000000
--- a/testing/web-platform/tests/encrypted-media/Google/chromium_specific_disabled/encrypted-media-lifetime-multiple-mediakeys.html
+++ /dev/null
@@ -1,131 +0,0 @@
-<!DOCTYPE html>
-<!-- Copyright © 2016 Chromium authors and World Wide Web Consortium, (Massachusetts Institute of Technology, ERCIM, Keio University, Beihang). -->
-<html>
- <head>
- <title>Test multiple MediaKeys lifetimes</title>
- <script src="encrypted-media-utils.js"></script>
-<!--
- Test requires Chromium specific content and is being disabled.
- <script src="/resources/testharness.js"></script>
- <script src="/resources/testharnessreport.js"></script>
--->
- </head>
- <body>
- <div id="log"></div>
- <script>
- // For this test, create several MediaKeys and verify lifetime.
- async_test(function(test)
- {
- var mediaKeys;
- var startingActiveDOMObjectCount = window.internals.activeDOMObjectCount(document);
-
- function numActiveDOMObjectsCreated()
- {
- return window.internals.activeDOMObjectCount(document) - startingActiveDOMObjectCount;
- }
-
- // Create a MediaKeys object. Returns a promise that resolves
- // with the new MediaKeys object.
- function createMediaKeys()
- {
- return navigator.requestMediaKeySystemAccess('org.w3.clearkey', getSimpleConfiguration()).then(function(access) {
- return access.createMediaKeys();
- }).then(function(mediaKeys) {
- return mediaKeys;
- });
- }
-
- // Create a few MediaKeys objects. Only keep a reference to the
- // last one created.
- createMediaKeys().then(function(result) {
- // Should be 1 MediaKeys.
- // In non-Oilpan, numActiveDOMObjectsCreate() == 1.
- // In Oilpan, numActiveDOMObjectsCreated() <= 4.
- // (1 MediaKeysInitializer,
- // 1 MediaKeySystemAccessInitializer (navigator.requestMediaKeySystemAccess() use above),
- // 1 MediaKeySystemAccessInitializer (isInitDataSupported() (via getSupportedInitDataType())) and
- // 1 ContentDecryptionModuleResultPromise).
- assert_between_inclusive(numActiveDOMObjectsCreated(), 1, 4);
-
- return createMediaKeys();
- }).then(function(result) {
- // Should be 2 MediaKeys.
- // In non-Oilpan, numActiveDOMObjectsCreate() == 2.
- // In Oilpan, numActiveDOMObjectsCreate() <= 8.
- // (2 MediaKeysInitializer,
- // 4 MediaKeySystemAccessInitializer and
- // 2 ContentDecryptionModuleResultPromise).
- assert_between_inclusive(numActiveDOMObjectsCreated(), 2, 8);
-
- return createMediaKeys();
- }).then(function(result) {
- // Should be 3 MediaKeys.
- // In non-Oilpan, numActiveDOMObjectsCreate() == 3.
- // In Oilpan, numActiveDOMObjectsCreate() <= 12.
- // (3 MediaKeysInitializer,
- // 6 MediaKeySystemAccessInitializer and
- // 3 ContentDecryptionModuleResultPromise).
- assert_between_inclusive(numActiveDOMObjectsCreated(), 3, 12);
-
- return createMediaKeys();
- }).then(function(result) {
- // Should be 4 MediaKeys.
- // In non-Oilpan, numActiveDOMObjectsCreate() == 4.
- // In Oilpan, numActiveDOMObjectsCreate() <= 16.
- // (4 MediaKeysInitializer,
- // 8 MediaKeySystemAccessInitializer and
- // 4 ContentDecryptionModuleResultPromise).
- assert_between_inclusive(numActiveDOMObjectsCreated(), 4, 16);
-
- return createMediaKeys();
- }).then(function(result) {
- // Should be 5 MediaKeys.
- // In non-Oilpan, numActiveDOMObjectsCreate() == 5.
- // In Oilpan, numActiveDOMObjectsCreate() <= 20.
- // (5 MediaKeysInitializer,
- // 10 MediaKeySystemAccessInitializer and
- // 5 ContentDecryptionModuleResultPromise).
- assert_between_inclusive(numActiveDOMObjectsCreated(), 5, 20);
-
- // |mediaKeys| refers to the most recently created MediaKeys
- // object.
- mediaKeys = result;
-
- // In order for the MediaKey objects to be garbage
- // collected, it needs time to process any pending events.
- return delayToAllowEventProcessingPromise();
- }).then(function(result) {
- // In non-Oilpan, numActiveDOMObjectsCreated() == 5
- // (5 MediaKeySession objects).
- // In Oilpan, numActiveDOMObjectsCreated() <= 23
- // (5 MediaKeysInitializer,
- // 12 MediaKeySystemAccessInitializer,
- // 5 ContentDecryptionModuleResultPromise and
- // 1 DOMTimer (in delayToAllowEventProcessingPromise))
- assert_between_inclusive(numActiveDOMObjectsCreated(), 5, 23);
-
- // As we only have a reference (|mediaKeys|) to the last
- // created MediaKeys object, the other 4 MediaKeys objects
- // are available to be garbage collected.
- return createGCPromise();
- }).then(function(result) {
- // Should be 1 MediaKeys and DOMTimer.
- assert_less_than_equal(numActiveDOMObjectsCreated(), 2);
- assert_equals(typeof mediaKeys.createSession, 'function');
-
- // Release the last MediaKeys object created.
- mediaKeys = null;
-
- // Run gc() again to reclaim the remaining MediaKeys object.
- return createGCPromise();
- }).then(function(result) {
- // Should be just a DOMTimer.
- assert_less_than_equal(numActiveDOMObjectsCreated(), 1);
- test.done();
- }).catch(function(error) {
- forceTestFailureFromPromise(test, error);
- });
- }, 'Multiple MediaKeys lifetime');
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/Google/chromium_specific_disabled/encrypted-media-lifetime-reload.html b/testing/web-platform/tests/encrypted-media/Google/chromium_specific_disabled/encrypted-media-lifetime-reload.html
deleted file mode 100644
index b2f8ffb1f..000000000
--- a/testing/web-platform/tests/encrypted-media/Google/chromium_specific_disabled/encrypted-media-lifetime-reload.html
+++ /dev/null
@@ -1,103 +0,0 @@
-<!DOCTYPE html>
-<!-- Copyright © 2016 Chromium authors and World Wide Web Consortium, (Massachusetts Institute of Technology, ERCIM, Keio University, Beihang). -->
-<html>
- <head>
- <title>Reloading during encrypted media playback</title>
- <script src="encrypted-media-utils.js"></script>
-<!--
- Test requires Chromium specific content and is being disabled.
- <script src="/resources/testharness.js"></script>
- <script src="/resources/testharnessreport.js"></script>
--->
- </head>
- <body>
- <video id="testVideo"></video>
- <div id="log"></div>
- <script>
- async_test(function(test)
- {
- var video = document.getElementById('testVideo');
- var content = 'webm/test-encrypted.webm';
- var mediaKeySession = null;
- var hasSessionUpdateSucceeded = false;
- var encryptedEventCount = 0;
-
- var rawKey = new Uint8Array([0xeb, 0xdd, 0x62, 0xf1, 0x68, 0x14, 0xd2, 0x7b,
- 0x68, 0xef, 0x12, 0x2a, 0xfc, 0xe4, 0xae, 0x3c]);
-
- function onEncrypted(event)
- {
- assert_equals(event.target, video);
- assert_true(event instanceof window.MediaEncryptedEvent);
- assert_equals(event.type, 'encrypted');
-
- // The same decryption key is used by both the audio and
- // the video streams so only create a session once. To
- // avoid issues when comparing the expected.txt file
- // (which logs the events in the order they occur), create
- // the session on the second event. This also ensures we
- // see both events.
- if (++encryptedEventCount != 2)
- return;
-
- mediaKeySession = video.mediaKeys.createSession();
- waitForEventAndRunStep('message', mediaKeySession, onMessage, test);
- mediaKeySession.generateRequest(event.initDataType, event.initData).catch(function(error) {
- forceTestFailureFromPromise(test, error);
- });
- }
-
- function onMessage(event)
- {
- assert_true(event instanceof window.MediaKeyMessageEvent);
- assert_equals(event.target, mediaKeySession);
- assert_equals(event.type, 'message');
- assert_equals(event.messageType, 'license-request');
-
- var keyId = extractSingleKeyIdFromMessage(event.message);
- var jwkSet = stringToUint8Array(createJWKSet(createJWK(keyId, rawKey)));
- mediaKeySession.update(jwkSet).then(function(result) {
- hasSessionUpdateSucceeded = true;
- }).catch(function(error) {
- forceTestFailureFromPromise(test, error);
- });
- }
-
- function onPlaying(event)
- {
- // Not using waitForEventAndRunStep() to avoid too many
- // EVENT(onTimeUpdate) logs.
- video.addEventListener('timeupdate', onTimeUpdate, true);
- }
-
- function onTimeUpdate(event)
- {
- if (event.target.currentTime < 0.2 || !hasSessionUpdateSucceeded)
- return;
-
- // Reload the page to catch any possible teardown issues.
- if (location.hash == '#x') {
- test.done();
- return;
- }
-
- location.hash += 'x';
- location.reload();
- }
-
- navigator.requestMediaKeySystemAccess('org.w3.clearkey', getConfigurationForFile(content)).then(function(access) {
- return access.createMediaKeys();
- }).then(function(mediaKeys) {
- waitForEventAndRunStep('encrypted', video, onEncrypted, test);
- waitForEventAndRunStep('playing', video, onPlaying, test);
- video.src = content;
- return video.setMediaKeys(mediaKeys);
- }).then(function(result) {
- video.play();
- }).catch(function(error) {
- forceTestFailureFromPromise(test, error);
- });
- }, 'Reloading during encrypted media playback.');
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-check-init-data-type.html b/testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-check-init-data-type.html
deleted file mode 100644
index f71cf48a8..000000000
--- a/testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-check-init-data-type.html
+++ /dev/null
@@ -1,51 +0,0 @@
-<!DOCTYPE html>
-<!-- Copyright © 2016 Chromium authors and World Wide Web Consortium, (Massachusetts Institute of Technology, ERCIM, Keio University, Beihang). -->
-<html>
- <head>
- <title>Test support of different initDataTypes.</title>
- <script src="encrypted-media-utils.js"></script>
-<!--
- Test has been migrated to the root directory and is being disabled here.
- <script src="/resources/testharness.js"></script>
- <script src="/resources/testharnessreport.js"></script>
--->
- </head>
- <body>
- <div id="log"></div>
- <script>
- function checkInitDataType(initDataType)
- {
- return isInitDataTypeSupported(initDataType).then(function(result) {
- // If |initDataType| is not supported, simply succeed.
- if (!result)
- return Promise.resolve('Not supported');
-
- return navigator.requestMediaKeySystemAccess('org.w3.clearkey', getSimpleConfigurationForInitDataType(initDataType))
- .then(function(access) {
- return access.createMediaKeys();
- }).then(function(mediaKeys) {
- var mediaKeySession = mediaKeys.createSession();
- var initData = getInitData(initDataType);
- return mediaKeySession.generateRequest(initDataType, initData);
- });
- });
- }
-
- promise_test(function()
- {
- return checkInitDataType('webm');
- }, 'Clear key support for "webm".');
-
- promise_test(function()
- {
- return checkInitDataType('cenc');
- }, 'Clear key support for "cenc".');
-
- promise_test(function()
- {
- return checkInitDataType('keyids');
- }, 'Clear key support for "keyids".');
- </script>
- </body>
-</html>
-
diff --git a/testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-clear-key-invalid-license.html b/testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-clear-key-invalid-license.html
deleted file mode 100644
index f145dfad7..000000000
--- a/testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-clear-key-invalid-license.html
+++ /dev/null
@@ -1,47 +0,0 @@
-<!DOCTYPE html>
-<!-- Copyright © 2016 Chromium authors and World Wide Web Consortium, (Massachusetts Institute of Technology, ERCIM, Keio University, Beihang). -->
-<html>
- <head>
- <title>Invalid Clear Key License.</title>
- <script src="encrypted-media-utils.js"></script>
-<!--
- Test has been migrated to the root directory and is being disabled here.
- <script src="/resources/testharness.js"></script>
- <script src="/resources/testharnessreport.js"></script>
--->
- </head>
- <body>
- <div id="log"></div>
- <script>
- async_test(function(test)
- {
- var initDataType;
- var initData;
- var invalidLicense = new Uint8Array(
- [0x00, 0x11, 0x22, 0x33, 0x44, 0x55, 0x66, 0x77]);
-
- function handleMessage(event) {
- event.target.update(invalidLicense).then(function(event) {
- assert_unreached('Error: update() succeeded unexpectedly.');
- test.done();
- }).catch(function(error) {
- assert_equals(error.name, 'InvalidAccessError');
- test.done();
- });
- }
-
- navigator.requestMediaKeySystemAccess('org.w3.clearkey', getSimpleConfiguration()).then(function(access) {
- initDataType = access.getConfiguration().initDataTypes[0];
- initData = getInitData(initDataType);
- return access.createMediaKeys();
- }).then(function(mediaKeys) {
- var keySession = mediaKeys.createSession();
- keySession.addEventListener('message', handleMessage, false);
- keySession.generateRequest(initDataType, initData);
- }).catch(function(error) {
- forceTestFailureFromPromise(test, error);
- });
- }, 'Invalid Clear Key License.');
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-clearkey-update-non-ascii-input.html b/testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-clearkey-update-non-ascii-input.html
deleted file mode 100644
index cf237a7da..000000000
--- a/testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-clearkey-update-non-ascii-input.html
+++ /dev/null
@@ -1,53 +0,0 @@
-<!DOCTYPE html>
-<!-- Copyright © 2016 Chromium authors and World Wide Web Consortium, (Massachusetts Institute of Technology, ERCIM, Keio University, Beihang). -->
-<html>
- <head>
- <title>Test Clear Key handling of non-ASCII responses for update().</title>
- <script src="encrypted-media-utils.js"></script>
-<!--
- Test has been migrated to the root directory and is being disabled here.
- <script src="/resources/testharness.js"></script>
- <script src="/resources/testharnessreport.js"></script>
--->
- </head>
- <body>
- <div id="log"></div>
- <script>
- // This test passes |response| to update() as a JSON Web Key Set.
- // CDMs other than Clear Key won't expect |response| in this format.
-
- async_test(function(test)
- {
- var initDataType;
- var initData;
- var mediaKeySession;
-
- function processMessage(event)
- {
- // |jwkSet| includes some non-ASCII characters.
- var jwkSet = '{"keys":[{'
- + '"kty":"oct\uDC00\uD800",'
- + '"k":"MDEyMzQ1Njc4OTAxMjM0NQ",'
- + '"kid":"MDEyMzQ1Njc4OTAxMjM0NQ"'
- + '\xff\xfe}]';
- mediaKeySession.update(stringToUint8Array(jwkSet)).then(function() {
- forceTestFailureFromPromise(test, 'Error: update() succeeded');
- }, function(error) {
- assert_equals(error.name, 'InvalidAccessError');
- test.done();
- });
- }
-
- navigator.requestMediaKeySystemAccess('org.w3.clearkey', getSimpleConfiguration()).then(function(access) {
- initDataType = access.getConfiguration().initDataTypes[0];
- initData = getInitData(initDataType);
- return access.createMediaKeys();
- }).then(function(mediaKeys) {
- mediaKeySession = mediaKeys.createSession();
- waitForEventAndRunStep('message', mediaKeySession, processMessage, test);
- return mediaKeySession.generateRequest(initDataType, initData);
- });
- }, 'Clear Key update() with non-ASCII response.');
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-events.html b/testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-events.html
deleted file mode 100644
index a2a70f169..000000000
--- a/testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-events.html
+++ /dev/null
@@ -1,65 +0,0 @@
-<!DOCTYPE html>
-<!-- Copyright © 2016 Chromium authors and World Wide Web Consortium, (Massachusetts Institute of Technology, ERCIM, Keio University, Beihang). -->
-<html>
- <head>
- <title>Verify v2 events</title>
- <script src="encrypted-media-utils.js"></script>
-<!--
- Test has been migrated to the root directory and is being disabled here.
- <script src="/resources/testharness.js"></script>
- <script src="/resources/testharnessreport.js"></script>
--->
- </head>
- <body>
- <div id="log"></div>
- <script>
- // Currently Clear Key only generates aynchronous "message" and
- // "keychange" events.
- async_test(function(test)
- {
- var initDataType;
- var initData;
- var mediaKeySession;
- var rawKey = new Uint8Array([0xeb, 0xdd, 0x62, 0xf1, 0x68, 0x14, 0xd2, 0x7b,
- 0x68, 0xef, 0x12, 0x2a, 0xfc, 0xe4, 0xae, 0x3c]);
-
- function processMessage(event)
- {
- assert_true(event instanceof window.MediaKeyMessageEvent);
- assert_equals(event.target, mediaKeySession);
- assert_equals(event.type, 'message');
- assert_equals(event.messageType, 'license-request');
-
- var keyId = extractSingleKeyIdFromMessage(event.message);
- var jwkSet = stringToUint8Array(createJWKSet(createJWK(keyId, rawKey)));
-
- waitForEventAndRunStep('keystatuseschange', mediaKeySession, test.step_func(processKeyStatusesChange), test);
-
- mediaKeySession.update(jwkSet).catch(test.step_func(function(error) {
- forceTestFailureFromPromise(test, error);
- }));
- }
-
- function processKeyStatusesChange(event)
- {
- assert_true(event instanceof Event);
- assert_equals(event.target, mediaKeySession);
- assert_equals(event.type, 'keystatuseschange');
- test.done();
- }
-
- navigator.requestMediaKeySystemAccess('org.w3.clearkey', getSimpleConfiguration()).then(function(access) {
- initDataType = access.getConfiguration().initDataTypes[0];
- initData = getInitData(initDataType);
- return access.createMediaKeys();
- }).then(test.step_func(function(mediaKeys) {
- mediaKeySession = mediaKeys.createSession();
- waitForEventAndRunStep('message', mediaKeySession, test.step_func(processMessage), test);
- return mediaKeySession.generateRequest(initDataType, initData);
- })).catch(test.step_func(function(error) {
- forceTestFailureFromPromise(test, error);
- }));
- }, 'Verify v2 events.');
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-generate-request-disallowed-input.html b/testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-generate-request-disallowed-input.html
deleted file mode 100644
index 53e5c95b7..000000000
--- a/testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-generate-request-disallowed-input.html
+++ /dev/null
@@ -1,107 +0,0 @@
-<!DOCTYPE html>
-<!-- Copyright © 2016 Chromium authors and World Wide Web Consortium, (Massachusetts Institute of Technology, ERCIM, Keio University, Beihang). -->
-<html>
- <head>
- <title>Test handling of invalid initData for generateRequest().</title>
- <script src="encrypted-media-utils.js"></script>
-<!--
- Test has been migrated to the root directory and is being disabled here.
- <script src="/resources/testharness.js"></script>
- <script src="/resources/testharnessreport.js"></script>
--->
- </head>
- <body>
- <div id="log"></div>
- <script>
- // Create a session and call generateRequest() with |initDataType|
- // and |initData|. generateRequest() should fail with an
- // InvalidAccessError. Returns a promise that resolves successfully
- // if the error happened, rejects otherwise.
- function test_session(initDataType, initData)
- {
- return isInitDataTypeSupported(initDataType).then(function(result) {
- // If |initDataType| is not supported, simply succeed.
- if (!result)
- return Promise.resolve('Not supported');
-
- return navigator.requestMediaKeySystemAccess('org.w3.clearkey', getSimpleConfigurationForInitDataType(initDataType)).then(function(access) {
- return access.createMediaKeys();
- }).then(function(mediaKeys) {
- var mediaKeySession = mediaKeys.createSession();
- return mediaKeySession.generateRequest(initDataType, initData);
- }).then(function() {
- assert_unreached('generateRequest() succeeded');
- }, function(error) {
- assert_equals(error.name, 'InvalidAccessError');
- return Promise.resolve('success');
- });
- })
- }
-
- promise_test(function()
- {
- var initData = new Uint8Array(70000);
- return test_session('webm', initData);
- }, 'generateRequest() with webm initData longer than 64Kb characters.');
-
- promise_test(function()
- {
- var initData = new Uint8Array(70000);
- return test_session('cenc', initData);
- }, 'generateRequest() with cenc initData longer than 64Kb characters.');
-
- promise_test(function()
- {
- var initData = new Uint8Array(70000);
- return test_session('keyids', initData);
- }, 'generateRequest() with keyids initData longer than 64Kb characters.');
-
- promise_test(function()
- {
- // Invalid 'pssh' box as the size specified is larger than what
- // is provided.
- var initData = new Uint8Array([
- 0x00, 0x00, 0xff, 0xff, // size = huge
- 0x70, 0x73, 0x73, 0x68, // 'pssh'
- 0x00, // version = 0
- 0x00, 0x00, 0x00, // flags
- 0x10, 0x77, 0xEF, 0xEC, 0xC0, 0xB2, 0x4D, 0x02, // Common SystemID
- 0xAC, 0xE3, 0x3C, 0x1E, 0x52, 0xE2, 0xFB, 0x4B,
- 0x00, 0x00, 0x00, 0x00 // datasize
- ]);
- return test_session('cenc', initData);
- }, 'generateRequest() with invalid pssh box size.');
-
- promise_test(function()
- {
- // Invalid data as type = 'psss'.
- var initData = new Uint8Array([
- 0x00, 0x00, 0x00, 0x20, // size = 32
- 0x70, 0x73, 0x73, 0x73, // 'psss'
- 0x00, // version = 0
- 0x00, 0x00, 0x00, // flags
- 0x10, 0x77, 0xEF, 0xEC, 0xC0, 0xB2, 0x4D, 0x02, // Common SystemID
- 0xAC, 0xE3, 0x3C, 0x1E, 0x52, 0xE2, 0xFB, 0x4B,
- 0x00, 0x00, 0x00, 0x00 // datasize
- ]);
- return test_session('cenc', initData);
- }, 'generateRequest() with non pssh data.');
-
- promise_test(function()
- {
- // Valid key ID size must be at least 1 character for keyids.
- var keyId = new Uint8Array(0);
- var initData = stringToUint8Array(createKeyIDs(keyId));
- return test_session('keyids', initData);
- }, 'generateRequest() with too short key ID.');
-
- promise_test(function()
- {
- // Valid key ID size must be less than 512 characters for keyids.
- var keyId = new Uint8Array(600);
- var initData = stringToUint8Array(createKeyIDs(keyId));
- return test_session('keyids', initData);
- }, 'generateRequest() with too long key ID.');
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-keystatuses-multiple-sessions.html b/testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-keystatuses-multiple-sessions.html
deleted file mode 100644
index 3ee4e8c54..000000000
--- a/testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-keystatuses-multiple-sessions.html
+++ /dev/null
@@ -1,121 +0,0 @@
-<!DOCTYPE html>
-<!-- Copyright © 2016 Chromium authors and World Wide Web Consortium, (Massachusetts Institute of Technology, ERCIM, Keio University, Beihang). -->
-<html>
- <head>
- <title>Verify MediaKeySession.keyStatuses with multiple sessions</title>
- <script src="encrypted-media-utils.js"></script>
-<!--
- Test has been migrated to the root directory and is being disabled here.
- <script src="/resources/testharness.js"></script>
- <script src="/resources/testharnessreport.js"></script>
--->
- </head>
- <body>
- <div id="log"></div>
- <script>
- async_test(function(test)
- {
- var mediaKeySession1;
- var mediaKeySession2;
- var initDataType;
- var initData;
-
- // Even though key ids are uint8, using printable values so that
- // they can be verified easily.
- var key1 = stringToUint8Array('123');
- var key2 = stringToUint8Array('4567890');
- var rawKey1 = new Uint8Array([0xeb, 0xdd, 0x62, 0xf1, 0x68, 0x14, 0xd2, 0x7b,
- 0x68, 0xef, 0x12, 0x2a, 0xfc, 0xe4, 0xae, 0x3c]);
- var rawKey2 = new Uint8Array([0x3c, 0xae, 0xe4, 0xfc, 0x2a, 0x12, 0xef, 0x68,
- 0x7b, 0xd2, 0x14, 0x68, 0xf1, 0x62, 0xdd, 0xeb]);
-
- function processMessage1(event)
- {
- // This should only be called for session1.
- assert_equals(event.target, mediaKeySession1);
-
- // No keys added yet.
- verifyKeyStatuses(mediaKeySession1.keyStatuses, { expected: [], unexpected: [key1, key2] });
-
- // Add key1 to session1.
- var jwkSet = stringToUint8Array(createJWKSet(createJWK(key1, rawKey1)));
- mediaKeySession1.update(jwkSet).catch(function(error) {
- forceTestFailureFromPromise(test, error);
- });
- }
-
- function processKeyStatusesChange1(event)
- {
- // This should only be called for session1.
- assert_equals(event.target, mediaKeySession1);
-
- // Check that keyStatuses contains the expected key1 only.
- dumpKeyStatuses(mediaKeySession1.keyStatuses);
- verifyKeyStatuses(mediaKeySession1.keyStatuses, { expected: [key1], unexpected: [key2] });
-
- // Now trigger a message event on session2.
- mediaKeySession2.generateRequest(initDataType, initData).catch(function(error) {
- forceTestFailureFromPromise(test, error);
- });
- }
-
- function processMessage2(event)
- {
- // This should only be called for session2.
- assert_equals(event.target, mediaKeySession2);
-
- // session2 has no keys added yet.
- verifyKeyStatuses(mediaKeySession2.keyStatuses, { expected: [], unexpected: [key1, key2] });
-
- // session1 should still have 1 key.
- verifyKeyStatuses(mediaKeySession1.keyStatuses, { expected: [key1], unexpected: [key2] });
-
- // Add key2 to session2.
- var jwkSet = stringToUint8Array(createJWKSet(createJWK(key2, rawKey2)));
- mediaKeySession2.update(jwkSet).catch(function(error) {
- forceTestFailureFromPromise(test, error);
- });
- }
-
- function processKeyStatusesChange2(event)
- {
- // This should only be called for session2.
- assert_equals(event.target, mediaKeySession2);
-
- // Check that keyStatuses contains the expected key2 only.
- dumpKeyStatuses(mediaKeySession2.keyStatuses);
- verifyKeyStatuses(mediaKeySession2.keyStatuses, { expected: [key2], unexpected: [key1] });
-
- // session1 should still have 1 key.
- verifyKeyStatuses(mediaKeySession1.keyStatuses, { expected: [key1], unexpected: [key2] });
-
- test.done();
- }
-
- navigator.requestMediaKeySystemAccess('org.w3.clearkey', getSimpleConfiguration()).then(function(access) {
- initDataType = access.getConfiguration().initDataTypes[0];
- initData = getInitData(initDataType);
- return access.createMediaKeys();
- }).then(function(mediaKeys) {
- mediaKeySession1 = mediaKeys.createSession();
- mediaKeySession2 = mediaKeys.createSession();
-
- // There should be no keys defined on either session.
- verifyKeyStatuses(mediaKeySession1.keyStatuses, { expected: [], unexpected: [key1, key2] });
- verifyKeyStatuses(mediaKeySession2.keyStatuses, { expected: [], unexpected: [key1, key2] });
-
- // Bind all the event handlers now.
- waitForEventAndRunStep('message', mediaKeySession1, processMessage1, test);
- waitForEventAndRunStep('message', mediaKeySession2, processMessage2, test);
- waitForEventAndRunStep('keystatuseschange', mediaKeySession1, processKeyStatusesChange1, test);
- waitForEventAndRunStep('keystatuseschange', mediaKeySession2, processKeyStatusesChange2, test);
-
- // Generate a request on session1.
- return mediaKeySession1.generateRequest(initDataType, initData);
- }).catch(function(error) {
- forceTestFailureFromPromise(test, error);
- });
- }, 'Verify MediaKeySession.keyStatuses with multiple sessions.');
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-keystatuses-multiple-updates.html b/testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-keystatuses-multiple-updates.html
deleted file mode 100644
index 809045d99..000000000
--- a/testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-keystatuses-multiple-updates.html
+++ /dev/null
@@ -1,87 +0,0 @@
-<!DOCTYPE html>
-<!-- Copyright © 2016 Chromium authors and World Wide Web Consortium, (Massachusetts Institute of Technology, ERCIM, Keio University, Beihang). -->
-<html>
- <head>
- <title>Verify MediaKeySession.keyStatuses with multiple updates</title>
- <script src="encrypted-media-utils.js"></script>
-<!--
- Test has been migrated to the root directory and is being disabled here.
- <script src="/resources/testharness.js"></script>
- <script src="/resources/testharnessreport.js"></script>
--->
- </head>
- <body>
- <div id="log"></div>
- <script>
- async_test(function(test)
- {
- var initDataType;
- var initData;
- var mediaKeySession;
- var firstEvent;
-
- // Even though key ids are uint8, using printable values so that
- // they can be verified easily.
- var key1 = stringToUint8Array('123');
- var key2 = stringToUint8Array('4567890');
- var rawKey1 = new Uint8Array([0xeb, 0xdd, 0x62, 0xf1, 0x68, 0x14, 0xd2, 0x7b,
- 0x68, 0xef, 0x12, 0x2a, 0xfc, 0xe4, 0xae, 0x3c]);
- var rawKey2 = new Uint8Array([0x3c, 0xae, 0xe4, 0xfc, 0x2a, 0x12, 0xef, 0x68,
- 0x7b, 0xd2, 0x14, 0x68, 0xf1, 0x62, 0xdd, 0xeb]);
-
- function processMessage(event)
- {
- // No keys added yet.
- verifyKeyStatuses(mediaKeySession.keyStatuses, { expected: [], unexpected: [key1, key2] });
-
- // Add key1 to the session.
- firstEvent = true;
- var jwkSet = stringToUint8Array(createJWKSet(createJWK(key1, rawKey1)));
- mediaKeySession.update(jwkSet).catch(function(error) {
- forceTestFailureFromPromise(test, error);
- });
- }
-
- function processKeyStatusesChange(event)
- {
- if (firstEvent) {
- // Verify that the session only contains key1.
- dumpKeyStatuses(mediaKeySession.keyStatuses);
- verifyKeyStatuses(mediaKeySession.keyStatuses, { expected: [key1], unexpected: [key2] });
-
- // Now add key2 to the session.
- firstEvent = false;
- var jwkSet = stringToUint8Array(createJWKSet(createJWK(key2, rawKey2)));
- mediaKeySession.update(jwkSet).catch(function(error) {
- forceTestFailureFromPromise(test, error);
- });
- } else {
- // Verify that the session now contains key1 and key2.
- dumpKeyStatuses(mediaKeySession.keyStatuses);
- verifyKeyStatuses(mediaKeySession.keyStatuses, { expected: [key1, key2] });
-
- test.done();
- }
- }
-
- navigator.requestMediaKeySystemAccess('org.w3.clearkey', getSimpleConfiguration()).then(function(access) {
- initDataType = access.getConfiguration().initDataTypes[0];
- initData = getInitData(initDataType);
- return access.createMediaKeys();
- }).then(function(mediaKeys) {
- mediaKeySession = mediaKeys.createSession();
-
- // There should be no keys defined yet.
- assert_equals(mediaKeySession.keyStatuses.size, 0);
-
- waitForEventAndRunStep('message', mediaKeySession, processMessage, test);
- waitForEventAndRunStep('keystatuseschange', mediaKeySession, processKeyStatusesChange, test);
-
- return mediaKeySession.generateRequest(initDataType, initData);
- }).catch(function(error) {
- forceTestFailureFromPromise(test, error);
- });
- }, 'Verify MediaKeySession.keyStatuses with multiple updates.');
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-keystatuses.html b/testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-keystatuses.html
deleted file mode 100644
index 043bc1322..000000000
--- a/testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-keystatuses.html
+++ /dev/null
@@ -1,174 +0,0 @@
-<!DOCTYPE html>
-<!-- Copyright © 2016 Chromium authors and World Wide Web Consortium, (Massachusetts Institute of Technology, ERCIM, Keio University, Beihang). -->
-<html>
- <head>
- <title>Verify MediaKeySession.keyStatuses</title>
- <script src="encrypted-media-utils.js"></script>
-<!--
- Test has been migrated to the root directory and is being disabled here.
- <script src="/resources/testharness.js"></script>
- <script src="/resources/testharnessreport.js"></script>
--->
- </head>
- <body>
- <div id="log"></div>
- <script>
- async_test(function(test)
- {
- var mediaKeySession;
- var initDataType;
- var initData;
- var closed = false;
-
- // Even though key ids are uint8, using printable values so that
- // they can be verified easily.
- var key1String = '123';
- var key2String = '4567890';
- var key1 = stringToUint8Array(key1String);
- var key2 = stringToUint8Array(key2String);
- var rawKey1 = new Uint8Array([0xeb, 0xdd, 0x62, 0xf1, 0x68, 0x14, 0xd2, 0x7b,
- 0x68, 0xef, 0x12, 0x2a, 0xfc, 0xe4, 0xae, 0x3c]);
- var rawKey2 = new Uint8Array([0x3c, 0xae, 0xe4, 0xfc, 0x2a, 0x12, 0xef, 0x68,
- 0x7b, 0xd2, 0x14, 0x68, 0xf1, 0x62, 0xdd, 0xeb]);
-
- function processMessage(event)
- {
- // No keys added yet.
- assert_equals(mediaKeySession.keyStatuses.size, 0);
-
- waitForEventAndRunStep('keystatuseschange', mediaKeySession, processKeyStatusesChange, test);
-
- var jwkSet = stringToUint8Array(createJWKSet(createJWK(key1, rawKey1), createJWK(key2, rawKey2)));
- mediaKeySession.update(jwkSet).catch(function(error) {
- forceTestFailureFromPromise(test, error);
- });
- }
-
- function checkKeyStatusFor2Keys()
- {
- // Two keys added, so both should show up in |keyStatuses|.
- assert_equals(mediaKeySession.keyStatuses.size, 2);
- dumpKeyStatuses(mediaKeySession.keyStatuses);
-
- // Check |keyStatuses| for 2 entries.
- var result = [];
- for (let [keyId, status] of mediaKeySession.keyStatuses) {
- result.push({ key: arrayBufferAsString(keyId), value: status });
- }
- assert_object_equals(result,
- [{ key: key1String, value: 'usable'}, { key: key2String, value: 'usable'}],
- 'keyStatuses fails');
-
- // |keyStatuses| must contain both keys.
- result = [];
- for (var key of mediaKeySession.keyStatuses.keys()) {
- result.push(arrayBufferAsString(key));
- }
- assert_array_equals(result,
- [key1String, key2String],
- 'keyStatuses.keys() fails');
-
- // Both values in |mediaKeySession| should be 'usable'.
- result = [];
- for (var value of mediaKeySession.keyStatuses.values()) {
- result.push(value);
- }
- assert_array_equals(result,
- ['usable', 'usable'],
- 'keyStatuses.values() fails');
-
- // Check |keyStatuses.entries()|.
- result = [];
- for (var entry of mediaKeySession.keyStatuses.entries()) {
- result.push({ key: arrayBufferAsString(entry[0]), value: entry[1] });
- }
- assert_object_equals(result,
- [{ key: key1String, value: 'usable'}, { key: key2String, value: 'usable'}],
- 'keyStatuses.entries() fails');
-
- // forEach() should return both entries.
- result = [];
- mediaKeySession.keyStatuses.forEach(function(status, keyId) {
- result.push({ key: arrayBufferAsString(keyId), value: status });
- });
- assert_object_equals(result,
- [{ key: key1String, value: 'usable'}, { key: key2String, value: 'usable'}],
- 'keyStatuses.forEach() fails');
-
- // has() and get() should return the expected values.
- assert_true(mediaKeySession.keyStatuses.has(key1));
- assert_true(mediaKeySession.keyStatuses.has(key2));
- assert_equals(mediaKeySession.keyStatuses.get(key1), 'usable');
- assert_equals(mediaKeySession.keyStatuses.get(key2), 'usable');
-
- // Try some invalid keyIds.
- var invalid1 = key1.subarray(0, key1.length - 1);
- assert_false(mediaKeySession.keyStatuses.has(invalid1));
- assert_equals(mediaKeySession.keyStatuses.get(invalid1), undefined);
-
- var invalid2 = key1.subarray(1);
- assert_false(mediaKeySession.keyStatuses.has(invalid2));
- assert_equals(mediaKeySession.keyStatuses.get(invalid2), undefined);
-
- var invalid3 = new Uint8Array(key1);
- invalid3[0] += 1;
- assert_false(mediaKeySession.keyStatuses.has(invalid3));
- assert_equals(mediaKeySession.keyStatuses.get(invalid3), undefined);
-
- var invalid4 = new Uint8Array(key1);
- invalid4[invalid4.length - 1] -= 1;
- assert_false(mediaKeySession.keyStatuses.has(invalid4));
- assert_equals(mediaKeySession.keyStatuses.get(invalid4), undefined);
-
- var invalid5 = new Uint8Array(key1.length + 1);
- invalid5.set(key1, 1); // First element will be 0.
- assert_false(mediaKeySession.keyStatuses.has(invalid5));
- assert_equals(mediaKeySession.keyStatuses.get(invalid5), undefined);
-
- var invalid6 = new Uint8Array(key1.length + 1);
- invalid6.set(key1, 0); // Last element will be 0.
- assert_false(mediaKeySession.keyStatuses.has(invalid6));
- assert_equals(mediaKeySession.keyStatuses.get(invalid6), undefined);
- }
-
- function processKeyStatusesChange(event)
- {
- if ( !closed )
- {
- // The first keystatuseschange (caused by update())
- // should include both keys.
- checkKeyStatusFor2Keys();
-
- mediaKeySession.close().catch(function(error) {
- forceTestFailureFromPromise(test, error);
- });
- closed = true;
- }
- else
- {
- // The second keystatuseschange (caused by close())
- // should not have any keys.
- assert_equals(mediaKeySession.keyStatuses.size, 0);
- test.done();
- }
- }
-
- navigator.requestMediaKeySystemAccess('org.w3.clearkey', getSimpleConfiguration()).then(function(access) {
- initDataType = access.getConfiguration().initDataTypes[0];
- initData = getInitData(initDataType);
- return access.createMediaKeys();
- }).then(function(mediaKeys) {
- mediaKeySession = mediaKeys.createSession();
-
- // There should be no keys defined yet.
- assert_equals(mediaKeySession.keyStatuses.size, 0);
-
- waitForEventAndRunStep('message', mediaKeySession, processMessage, test);
- return mediaKeySession.generateRequest(initDataType, initData);
- }).catch(function(error) {
- forceTestFailureFromPromise(test, error);
- });
- }, 'Verify MediaKeySession.keyStatuses.');
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-not-callable-after-createsession.html b/testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-not-callable-after-createsession.html
deleted file mode 100644
index 9b92c6905..000000000
--- a/testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-not-callable-after-createsession.html
+++ /dev/null
@@ -1,67 +0,0 @@
-<!DOCTYPE html>
-<!-- Copyright © 2016 Chromium authors and World Wide Web Consortium, (Massachusetts Institute of Technology, ERCIM, Keio University, Beihang). -->
-<html>
- <head>
- <title>Test MediaKeySession not callable immediately after CreateSession().</title>
- <script src="encrypted-media-utils.js"></script>
-<!--
- Test has been migrated to the root directory and is being disabled here.
- <script src="/resources/testharness.js"></script>
- <script src="/resources/testharnessreport.js"></script>
--->
- </head>
- <body>
- <div id="log"></div>
- <script>
- // After creation, the MediaKeySession object is not
- // callable, and we should get a InvalidStateError.
-
- promise_test(function()
- {
- return navigator.requestMediaKeySystemAccess('org.w3.clearkey', getSimpleConfiguration()).then(function(access) {
- return access.createMediaKeys();
- }).then(function(mediaKeys) {
- var mediaKeySession = mediaKeys.createSession();
-
- var arbitraryResponse = new Uint8Array([0x00, 0x11]);
- return mediaKeySession.update(arbitraryResponse).then(function(result) {
- assert_unreached('update() succeeded unexpectedly.');
- }).catch(function(error) {
- assert_equals(error.name, 'InvalidStateError');
- });
- });
- }, 'Update() immediately after CreateSession().');
-
- promise_test(function()
- {
- return navigator.requestMediaKeySystemAccess('org.w3.clearkey', getSimpleConfiguration()).then(function(access) {
- return access.createMediaKeys();
- }).then(function(mediaKeys) {
- var mediaKeySession = mediaKeys.createSession();
-
- return mediaKeySession.close().then(function(result) {
- assert_unreached('close() succeeded unexpectedly.');
- }).catch(function(error) {
- assert_equals(error.name, 'InvalidStateError');
- });
- });
- }, 'Close() immediately after CreateSession().');
-
- promise_test(function()
- {
- return navigator.requestMediaKeySystemAccess('org.w3.clearkey', getSimpleConfiguration()).then(function(access) {
- return access.createMediaKeys();
- }).then(function(mediaKeys) {
- var mediaKeySession = mediaKeys.createSession();
-
- return mediaKeySession.remove().then(function(result) {
- assert_unreached('remove() succeeded unexpectedly.');
- }).catch(function(error) {
- assert_equals(error.name, 'InvalidStateError');
- });
- });
- }, 'Remove() immediately after CreateSession().');
- </script>
- </body>
-</html>
-
diff --git a/testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-onencrypted.html b/testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-onencrypted.html
deleted file mode 100644
index ad408f0f3..000000000
--- a/testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-onencrypted.html
+++ /dev/null
@@ -1,44 +0,0 @@
-<!DOCTYPE html>
-<!-- Copyright © 2016 Chromium authors and World Wide Web Consortium, (Massachusetts Institute of Technology, ERCIM, Keio University, Beihang). -->
-<html>
- <head>
- <title>onencrypted</title>
- <script src="encrypted-media-utils.js"></script>
-<!--
- Test has been migrated to the root directory and is being disabled here.
- <script src="/resources/testharness.js"></script>
- <script src="/resources/testharnessreport.js"></script>
--->
- </head>
- <body>
- <video id="testVideo" controls></video>
- <div id="log"></div>
- <script>
- var expectedInitData = stringToUint8Array('0123456789012345');
-
- // Will get 2 identical events, one for audio, one for video.
- var expectedEvents = 2;
-
- async_test(function(test)
- {
- var video = document.getElementById('testVideo');
- var content = 'webm/test-encrypted.webm';
-
- var onEncrypted = function(event)
- {
- assert_equals(event.target, video);
- assert_true(event instanceof window.MediaEncryptedEvent);
- assert_equals(event.type, 'encrypted');
- assert_equals(event.initDataType, 'webm');
- assert_array_equals(new Uint8Array(event.initData), expectedInitData);
-
- if (--expectedEvents == 0)
- test.done();
- };
-
- waitForEventAndRunStep('encrypted', video, onEncrypted, test);
- video.src = content;
- }, 'encrypted fired on encrypted media file.');
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-playback-encrypted-and-clear-sources.html b/testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-playback-encrypted-and-clear-sources.html
deleted file mode 100644
index 495ba4188..000000000
--- a/testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-playback-encrypted-and-clear-sources.html
+++ /dev/null
@@ -1,130 +0,0 @@
-<!DOCTYPE html>
-<!-- Copyright © 2016 Chromium authors and World Wide Web Consortium, (Massachusetts Institute of Technology, ERCIM, Keio University, Beihang). -->
-<html>
- <head>
- <title>Multiple playbacks alternating between encrypted and clear sources.</title>
- <script src="encrypted-media-utils.js"></script>
-<!--
- Test has been migrated to the root directory and is being disabled here.
- <script src="/resources/testharness.js"></script>
- <script src="/resources/testharnessreport.js"></script>
--->
- </head>
- <body>
- <video id="testVideo"></video>
- <div id="log"></div>
- <script>
- async_test(function(test)
- {
- var video = document.getElementById('testVideo');
- var isUpdatePromiseResolved = false;
- var encryptedEventCount = 0;
- var playbackCount = 0;
-
- // Content to be played. These files must be the same format.
- var encryptedContent = 'webm/test-encrypted.webm';
- var unencryptedContent = 'webm/test.webm';
-
- var rawKey = new Uint8Array([0xeb, 0xdd, 0x62, 0xf1, 0x68, 0x14, 0xd2, 0x7b,
- 0x68, 0xef, 0x12, 0x2a, 0xfc, 0xe4, 0xae, 0x3c]);
-
- function onEncrypted(event)
- {
- assert_equals(event.target, video);
- assert_true(event instanceof window.MediaEncryptedEvent);
- assert_equals(event.type, 'encrypted');
-
- // The same decryption key is used by both the audio and
- // the video streams so only create a session once. To
- // avoid issues when comparing the expected.txt file
- // (which logs the events in the order they occur), create
- // the session on the second event. This also ensures we
- // see both events.
- if (++encryptedEventCount != 2)
- return;
-
- assert_false(video.mediaKeys === null, "video.mediaKeys is null.");
- var mediaKeySession = video.mediaKeys.createSession();
- waitForEventAndRunStep('message', mediaKeySession, onMessage, test);
- mediaKeySession.generateRequest(event.initDataType, event.initData).catch(function(error) {
- forceTestFailureFromPromise(test, error);
- });
- }
-
- function onMessage(event)
- {
- assert_true(event instanceof window.MediaKeyMessageEvent);
- assert_equals(event.type, 'message');
- assert_equals(event.messageType, 'license-request');
-
- var keyId = extractSingleKeyIdFromMessage(event.message);
- var jwkSet = stringToUint8Array(createJWKSet(createJWK(keyId, rawKey)));
- event.target.update(jwkSet).then(function(result) {
- isUpdatePromiseResolved = true;
- }).catch(function(error) {
- forceTestFailureFromPromise(test, error);
- });
- }
-
- function onPlaying(event)
- {
- // Not using waitForEventAndRunStep() to avoid too many
- // EVENT(onTimeUpdate) logs.
- video.addEventListener('timeupdate', onTimeUpdate, true);
- }
-
- function onTimeUpdate(event)
- {
- if (event.target.currentTime < 0.2 || !isUpdatePromiseResolved)
- return;
-
- video.removeEventListener('timeupdate', onTimeUpdate, true);
-
- if (playbackCount > 2) {
- test.done();
- return;
- }
-
- playbackCount++;
-
- resetSrc().then(function(){
- startPlayback();
- });
- }
-
- function resetSrc() {
- encryptedEventCount = 0;
- video.removeAttribute('src');
- video.load();
- return video.setMediaKeys(null);
- }
-
- function startPlayback() {
- // Alternate between encrypted and unencrypted files.
- if (playbackCount % 2) {
- // Unencrypted files don't require MediaKeys.
- video.src = unencryptedContent;
- video.play();
- return;
- }
-
- navigator.requestMediaKeySystemAccess('org.w3.clearkey', getConfigurationForFile(encryptedContent)).then(function(access) {
- return access.createMediaKeys();
- }).then(function(mediaKeys) {
- return video.setMediaKeys(mediaKeys);
- }).then(function(result) {
- video.src = encryptedContent;
- assert_false(video.mediaKeys === null, "video.mediaKeys is null.");
- video.play();
- }).catch(function(error) {
- forceTestFailureFromPromise(test, error);
- });
- }
-
- waitForEventAndRunStep('playing', video, onPlaying, test);
- waitForEventAndRunStep('encrypted', video, onEncrypted, test);
- startPlayback();
- }, 'Multiple playbacks alternating between encrypted and clear sources.');
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-playback-multiple-sessions.html b/testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-playback-multiple-sessions.html
deleted file mode 100644
index 8bf94e13c..000000000
--- a/testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-playback-multiple-sessions.html
+++ /dev/null
@@ -1,143 +0,0 @@
-<!DOCTYPE html>
-<!-- Copyright © 2016 Chromium authors and World Wide Web Consortium, (Massachusetts Institute of Technology, ERCIM, Keio University, Beihang). -->
-<html>
- <head>
- <title>Clear Key Playback with Multiple Sessions</title>
- <script src="encrypted-media-utils.js"></script>
-<!--
- Test has been migrated to the root directory and is being disabled here.
- <script src="/resources/testharness.js"></script>
- <script src="/resources/testharnessreport.js"></script>
--->
- </head>
- <body>
- <video id="testVideo"></video>
- <div id="log"></div>
- <script>
- async_test(function(test)
- {
- var video = document.getElementById('testVideo');
- var content = 'webm/test-encrypted-different-av-keys.webm';
- var audioMediaKeySession = null;
- var videoMediaKeySession = null;
- var audioInitDataType = null;
- var videoInitDataType = null;
- var audioInitData = null;
- var videoInitData = null;
- var audioKeyProvided = false;
- var videoKeyProvided = false;
-
- // The 2 streams use different key ids and different keys.
- var audioKeyId = '1234567890123456';
- var audioKey = new Uint8Array([0x30, 0x30, 0x62, 0xF1, 0x68, 0x14, 0xD2, 0x7B,
- 0x68, 0xEF, 0x12, 0x2A, 0xFC, 0xE4, 0xAE, 0x0A]);
- var videoKeyId = '0123456789012345';
- var videoKey = new Uint8Array([0x7A, 0x7A, 0x62, 0xF1, 0x68, 0x14, 0xD2, 0x7B,
- 0x68, 0xEF, 0x12, 0x2A, 0xFC, 0xE4, 0xAE, 0x0A]);
-
- function onEncrypted(event)
- {
- var keyId = String.fromCharCode.apply(null, new Uint8Array(event.initData));
-
- // To avoid issues when comparing the expected.txt file
- // (which logs the events in the order they occur), save
- // the initData and make the calls to generateRequest()
- // only after both "onencrypted" events are received.
- // This prevents a "message" event from occurring before
- // both "onencrypted" events are received.
- var mediaKeySession = video.mediaKeys.createSession();
- if (keyId == videoKeyId) {
- assert_equals(videoMediaKeySession, null);
- videoMediaKeySession = mediaKeySession;
- videoInitDataType = event.initDataType;
- videoInitData = event.initData;
- // Return if audio "onencrypted" event not yet received.
- if (audioMediaKeySession == null)
- return;
- } else {
- assert_equals(keyId, audioKeyId);
- assert_equals(audioMediaKeySession, null);
- audioMediaKeySession = mediaKeySession;
- audioInitDataType = event.initDataType;
- audioInitData = event.initData;
- // Return if video "onencrypted" event not yet received.
- if (videoMediaKeySession == null)
- return;
- }
-
- // Both sessions have been created.
- assert_not_equals(videoMediaKeySession, null);
- assert_not_equals(audioMediaKeySession, null);
-
- var promises = [];
- waitForEventAndRunStep('message', videoMediaKeySession, onMessage, test);
- promises.push(videoMediaKeySession.generateRequest(videoInitDataType, videoInitData));
-
- waitForEventAndRunStep('message', audioMediaKeySession, onMessage, test);
- promises.push(audioMediaKeySession.generateRequest(audioInitDataType, audioInitData));
-
- Promise.all(promises).catch(function(error) {
- forceTestFailureFromPromise(test, error);
- });
- }
-
- function onMessage(event)
- {
- assert_equals(event.messageType, 'license-request');
- var keyId = extractSingleKeyIdFromMessage(event.message);
- if (event.target == videoMediaKeySession) {
- assert_equals(String.fromCharCode.apply(null, keyId), videoKeyId);
- var jwkSet = stringToUint8Array(createJWKSet(createJWK(keyId, videoKey)));
- videoMediaKeySession.update(jwkSet).then(function(result) {
- videoKeyProvided = true;
- }).catch(function(error) {
- forceTestFailureFromPromise(test, error);
- });
- } else {
- assert_equals(event.target, audioMediaKeySession);
- assert_equals(String.fromCharCode.apply(null, keyId), audioKeyId);
- var jwkSet = stringToUint8Array(createJWKSet(createJWK(keyId, audioKey)));
- audioMediaKeySession.update(jwkSet).then(function(result) {
- audioKeyProvided = true;
- }).catch(function(error) {
- forceTestFailureFromPromise(test, error);
- });
- }
- }
-
- function onPlaying(event)
- {
- // Video should not start playing until both keys have been
- // provided.
- assert_true(videoKeyProvided);
- assert_true(audioKeyProvided);
-
- // Not using waitForEventAndRunStep() to avoid too many
- // EVENT(onTimeUpdate) logs.
- video.addEventListener('timeupdate', onTimeUpdate, true);
- }
-
- function onTimeUpdate(event)
- {
- if (event.target.currentTime < 0.2)
- return;
-
- test.done();
- }
-
- navigator.requestMediaKeySystemAccess('org.w3.clearkey', getConfigurationForFile(content)).then(function(access) {
- return access.createMediaKeys();
- }).then(function(mediaKeys) {
- waitForEventAndRunStep('encrypted', video, onEncrypted, test);
- waitForEventAndRunStep('playing', video, onPlaying, test);
- video.src = content;
- return video.setMediaKeys(mediaKeys);
- }).then(function(result) {
- video.play();
- }).catch(function(error) {
- forceTestFailureFromPromise(test, error);
- });
- }, 'Playback using Clear Key key system with multiple sessions.');
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-playback-setmediakeys-after-src.html b/testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-playback-setmediakeys-after-src.html
deleted file mode 100644
index 2a8cac486..000000000
--- a/testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-playback-setmediakeys-after-src.html
+++ /dev/null
@@ -1,96 +0,0 @@
-<!DOCTYPE html>
-<!-- Copyright © 2016 Chromium authors and World Wide Web Consortium, (Massachusetts Institute of Technology, ERCIM, Keio University, Beihang). -->
-<html>
- <head>
- <title>Clear Key Playback</title>
- <script src="encrypted-media-utils.js"></script>
-<!--
- Test has been migrated to the root directory and is being disabled here.
- <script src="/resources/testharness.js"></script>
- <script src="/resources/testharnessreport.js"></script>
--->
- </head>
- <body>
- <video id="testVideo"></video>
- <div id="log"></div>
- <script>
- async_test(function(test)
- {
- var video = document.getElementById('testVideo');
- var content = 'webm/test-encrypted.webm';
- var isUpdatePromiseResolved = false;
- var encryptedEventCount = 0;
-
- var rawKey = new Uint8Array([0xeb, 0xdd, 0x62, 0xf1, 0x68, 0x14, 0xd2, 0x7b,
- 0x68, 0xef, 0x12, 0x2a, 0xfc, 0xe4, 0xae, 0x3c]);
-
- function onEncrypted(event)
- {
- assert_equals(event.target, video);
- assert_true(event instanceof window.MediaEncryptedEvent);
- assert_equals(event.type, 'encrypted');
-
- // The same decryption key is used by both the audio and
- // the video streams so only create a session once. To
- // avoid issues when comparing the expected.txt file
- // (which logs the events in the order they occur), create
- // the session on the second event. This also ensures we
- // see both events.
- if (++encryptedEventCount != 2)
- return;
-
- var mediaKeySession = video.mediaKeys.createSession();
- waitForEventAndRunStep('message', mediaKeySession, onMessage, test);
- mediaKeySession.generateRequest(event.initDataType, event.initData).catch(function(error) {
- forceTestFailureFromPromise(test, error);
- });
- }
-
- function onMessage(event)
- {
- assert_true(event instanceof window.MediaKeyMessageEvent);
- assert_equals(event.type, 'message');
- assert_equals(event.messageType, 'license-request');
-
- var keyId = extractSingleKeyIdFromMessage(event.message);
- var jwkSet = stringToUint8Array(createJWKSet(createJWK(keyId, rawKey)));
- event.target.update(jwkSet).then(function(result) {
- isUpdatePromiseResolved = true;
- }).catch(function(error) {
- forceTestFailureFromPromise(test, error);
- });
- }
-
- function onPlaying(event)
- {
- // Not using waitForEventAndRunStep() to avoid too many
- // EVENT(onTimeUpdate) logs.
- video.addEventListener('timeupdate', onTimeUpdate, true);
- }
-
- function onTimeUpdate(event)
- {
- if (event.target.currentTime < 0.2 || !isUpdatePromiseResolved)
- return;
-
- test.done();
- }
-
- navigator.requestMediaKeySystemAccess('org.w3.clearkey', getConfigurationForFile(content)).then(function(access) {
- return access.createMediaKeys();
- }).then(function(mediaKeys) {
-
- waitForEventAndRunStep('encrypted', video, onEncrypted, test);
- waitForEventAndRunStep('playing', video, onPlaying, test);
-
- video.src = content;
- return video.setMediaKeys(mediaKeys);
- }).then(function(result) {
- video.play();
- }).catch(function(error) {
- forceTestFailureFromPromise(test, error);
- });
- }, 'Playback using Clear Key key system, calling setMediaKeys() after setting src attribute.');
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-playback-setmediakeys-before-src.html b/testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-playback-setmediakeys-before-src.html
deleted file mode 100644
index 84100570c..000000000
--- a/testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-playback-setmediakeys-before-src.html
+++ /dev/null
@@ -1,96 +0,0 @@
-<!DOCTYPE html>
-<!-- Copyright © 2016 Chromium authors and World Wide Web Consortium, (Massachusetts Institute of Technology, ERCIM, Keio University, Beihang). -->
-<html>
- <head>
- <title>Clear Key Playback</title>
- <script src="encrypted-media-utils.js"></script>
-<!--
- Test has been migrated to the root directory and is being disabled here.
- <script src="/resources/testharness.js"></script>
- <script src="/resources/testharnessreport.js"></script>
--->
- </head>
- <body>
- <video id="testVideo"></video>
- <div id="log"></div>
- <script>
- async_test(function(test)
- {
- var video = document.getElementById('testVideo');
- var content = 'webm/test-encrypted.webm';
- var isUpdatePromiseResolved = false;
- var encryptedEventCount = 0;
-
- var rawKey = new Uint8Array([0xeb, 0xdd, 0x62, 0xf1, 0x68, 0x14, 0xd2, 0x7b,
- 0x68, 0xef, 0x12, 0x2a, 0xfc, 0xe4, 0xae, 0x3c]);
-
- function onEncrypted(event)
- {
- assert_equals(event.target, video);
- assert_true(event instanceof window.MediaEncryptedEvent);
- assert_equals(event.type, 'encrypted');
-
- // The same decryption key is used by both the audio and
- // the video streams so only create a session once. To
- // avoid issues when comparing the expected.txt file
- // (which logs the events in the order they occur), create
- // the session on the second event. This also ensures we
- // see both events.
- if (++encryptedEventCount != 2)
- return;
-
- var mediaKeySession = video.mediaKeys.createSession();
- waitForEventAndRunStep('message', mediaKeySession, onMessage, test);
- mediaKeySession.generateRequest(event.initDataType, event.initData).catch(function(error) {
- forceTestFailureFromPromise(test, error);
- });
- }
-
- function onMessage(event)
- {
- assert_true(event instanceof window.MediaKeyMessageEvent);
- assert_equals(event.type, 'message');
- assert_equals(event.messageType, 'license-request');
-
- var keyId = extractSingleKeyIdFromMessage(event.message);
- var jwkSet = stringToUint8Array(createJWKSet(createJWK(keyId, rawKey)));
- event.target.update(jwkSet).then(function(result) {
- isUpdatePromiseResolved = true;
- }).catch(function(error) {
- forceTestFailureFromPromise(test, error);
- });
- }
-
- function onPlaying(event)
- {
- // Not using waitForEventAndRunStep() to avoid too many
- // EVENT(onTimeUpdate) logs.
- video.addEventListener('timeupdate', onTimeUpdate, true);
- }
-
- function onTimeUpdate(event)
- {
- if (event.target.currentTime < 0.2 || !isUpdatePromiseResolved)
- return;
-
- test.done();
- }
-
- navigator.requestMediaKeySystemAccess('org.w3.clearkey', getConfigurationForFile(content)).then(function(access) {
- return access.createMediaKeys();
- }).then(function(mediaKeys) {
-
- waitForEventAndRunStep('encrypted', video, onEncrypted, test);
- waitForEventAndRunStep('playing', video, onPlaying, test);
-
- return video.setMediaKeys(mediaKeys);
- }).then(function(result) {
- video.src = content;
- video.play();
- }).catch(function(error) {
- forceTestFailureFromPromise(test, error);
- });
- }, 'Playback using Clear Key key system, calling setMediaKeys() before setting src attribute.');
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-playback-two-videos.html b/testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-playback-two-videos.html
deleted file mode 100644
index 0bdc7757b..000000000
--- a/testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-playback-two-videos.html
+++ /dev/null
@@ -1,90 +0,0 @@
-<!DOCTYPE html>
-<!-- Copyright © 2016 Chromium authors and World Wide Web Consortium, (Massachusetts Institute of Technology, ERCIM, Keio University, Beihang). -->
-<html>
- <head>
- <title>Clear Key Play Two Videos At Same Time</title>
- <script src="encrypted-media-utils.js"></script>
-<!--
- Test has been migrated to the root directory and is being disabled here.
- <script src="/resources/testharness.js"></script>
- <script src="/resources/testharnessreport.js"></script>
--->
- </head>
- <body>
- <video id="testVideo"></video>
- <video id="secondVideo"></video>
- <div id="log"></div>
- <script>
- // As this code doesn't wait for the 'message' event to simplify
- // the code, specify the key ID and key used by the encrypted
- // content.
- var keyId = stringToUint8Array('0123456789012345');
- var rawKey = new Uint8Array([0xeb, 0xdd, 0x62, 0xf1, 0x68, 0x14, 0xd2, 0x7b,
- 0x68, 0xef, 0x12, 0x2a, 0xfc, 0xe4, 0xae, 0x3c]);
- var content = 'webm/test-encrypted.webm';
-
- promise_test(function(test)
- {
- var promises = [
- play_video_as_promise(document.getElementById('testVideo'), content),
- play_video_as_promise(document.getElementById('secondVideo'), content)
- ];
- return Promise.all(promises);
- }, 'Play two videos at the same time.');
-
- function play_video_as_promise(video, content)
- {
- return navigator.requestMediaKeySystemAccess('org.w3.clearkey', getConfigurationForFile(content)).then(function(access) {
- return access.createMediaKeys();
- }).then(function(mediaKeys) {
- return video.setMediaKeys(mediaKeys);
- }).then(function(result) {
- video.src = content;
- video.play();
- return wait_for_encrypted_message(video);
- }).then(function(result) {
- return wait_for_timeupdate_message(video);
- });
- };
-
- function wait_for_encrypted_message(video)
- {
- var encryptedEventCount = 0;
- return new Promise(function(resolve) {
- video.addEventListener('encrypted', function listener(e) {
- // The same decryption key is used by both the audio
- // and the video streams so only create a session once.
- // Create the session on the second event. This also
- // ensures we see both events.
- if (++encryptedEventCount != 2)
- return;
- video.removeEventListener('encrypted', listener);
-
- var mediaKeySession = video.mediaKeys.createSession();
- mediaKeySession.generateRequest(e.initDataType, e.initData).then(function(result) {
- // Don't bother waiting for the 'message' event.
- // Just call update() since we know the keyId
- // needed.
- var jwkSet = stringToUint8Array(createJWKSet(createJWK(keyId, rawKey)));
- return mediaKeySession.update(jwkSet);
- }).then(function(result) {
- resolve(result);
- });
- });
- });
- };
-
- function wait_for_timeupdate_message(video)
- {
- return new Promise(function(resolve) {
- video.addEventListener('timeupdate', function listener(e) {
- if (e.target.currentTime < 0.2)
- return;
- video.removeEventListener('timeupdate', listener);
- resolve(e);
- });
- });
- };
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-requestmediakeysystemaccess.html b/testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-requestmediakeysystemaccess.html
deleted file mode 100644
index 456f37f57..000000000
--- a/testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-requestmediakeysystemaccess.html
+++ /dev/null
@@ -1,322 +0,0 @@
-<!DOCTYPE html>
-<!-- Copyright © 2016 Chromium authors and World Wide Web Consortium, (Massachusetts Institute of Technology, ERCIM, Keio University, Beihang). -->
-<html>
- <head>
- <title>Test navigator.requestMediaKeySystemAccess()</title>
- <script src="encrypted-media-utils.js"></script>
-<!--
- Test has been migrated to the root directory and is being disabled here.
- <script src="/resources/testharness.js"></script>
- <script src="/resources/testharnessreport.js"></script>
--->
- </head>
- <body>
- <div id="log"></div>
- <script>
- function expect_error(keySystem, configurations, expectedError, testName) {
- promise_test(function(test) {
- return navigator.requestMediaKeySystemAccess(keySystem, configurations).then(function(a) {
- assert_unreached('Unexpected requestMediaKeySystemAccess() success.');
- }, function(e) {
- assert_equals(e.name, expectedError);
- });
- }, testName);
- }
-
- function assert_subset(actual, expected, path) {
- if (typeof expected == 'string') {
- assert_equals(actual, expected, path);
- } else {
- if (expected.hasOwnProperty('length'))
- assert_equals(actual.length, expected.length, path + '.length');
- for (property in expected)
- assert_subset(actual[property], expected[property], path + '.' + property);
- }
- }
-
- function expect_config(keySystem, configurations, expectedConfiguration, testName) {
- promise_test(function(test) {
- return navigator.requestMediaKeySystemAccess(keySystem, configurations).then(function(a) {
- assert_subset(a.getConfiguration(), expectedConfiguration, 'getConfiguration()');
- });
- }, testName);
- }
-
- // Tests for keySystem.
- expect_error('', [{}], 'InvalidAccessError', 'Empty keySystem');
- expect_error('com.example.unsupported', [{}], 'NotSupportedError', 'Unsupported keySystem');
- expect_error('org.w3.clearkey.', [{}], 'NotSupportedError', 'keySystem ends with "."');
- expect_error('org.w3.ClearKey', [{}], 'NotSupportedError', 'Capitalized keySystem');
- expect_error('org.w3.clearke\u028F', [{}], 'NotSupportedError', 'Non-ASCII keySystem');
-
- // Parent of Clear Key not supported.
- expect_error('org', [{}], 'NotSupportedError', 'Parent of Clear Key (org)');
- expect_error('org.', [{}], 'NotSupportedError', 'Parent of Clear Key (org.)');
- expect_error('org.w3', [{}], 'NotSupportedError', 'Parent of Clear Key (org.w3)');
- expect_error('org.w3.', [{}], 'NotSupportedError', 'Parent of Clear Key (org.w3.)');
-
- // Child of Clear Key not supported.
- expect_error('org.w3.clearkey.foo', [{}], 'NotSupportedError', 'Child of Clear Key');
-
- // Prefixed Clear Key not supported.
- expect_error('webkit-org.w3.clearkey', [{}], 'NotSupportedError', 'Prefixed Clear Key');
-
- // Incomplete names.
- expect_error('org.w3.learkey', [{}], 'NotSupportedError', 'Incomplete name org.w3.learkey');
- expect_error('org.w3.clearke', [{}], 'NotSupportedError', 'Incomplete name org.w3.clearke');
- expect_error('or.w3.clearkey', [{}], 'NotSupportedError', 'Incomplete name or.w3.clearkey');
-
- // Spaces in key system name not supported.
- expect_error(' org.w3.clearkey', [{}], 'NotSupportedError', 'Leading space in key system name');
- expect_error('org.w3. clearkey', [{}], 'NotSupportedError', 'Extra space in key system name');
- expect_error('org.w3.clearkey ', [{}], 'NotSupportedError', 'Trailing space in key system name');
-
- // Extra dots in key systems names not supported.
- expect_error('.org.w3.clearkey', [{}], 'NotSupportedError', 'Leading dot in key systems name');
- expect_error('org.w3.clearkey.', [{}], 'NotSupportedError', 'Trailing dot in key systems name');
- expect_error('org.w3..clearkey', [{}], 'NotSupportedError', 'Double dot in key systems name');
- expect_error('org.w3.clear.key', [{}], 'NotSupportedError', 'Extra dot in key systems name');
-
- // Key system name is case sensitive.
- expect_error('org.w3.Clearkey', [{}], 'NotSupportedError', 'Key system name is case sensitive');
- expect_error('Org.w3.clearkey', [{}], 'NotSupportedError', 'Key system name is case sensitive');
-
- // Tests for trivial configurations.
- expect_error('org.w3.clearkey', [], 'InvalidAccessError', 'Empty supportedConfigurations');
- expect_config('org.w3.clearkey', [{}], {}, 'Empty configuration');
-
- // Various combinations of supportedConfigurations.
- // TODO(jrummell): Specifying contentType without codecs is
- // deprecated, so this test should fail. http://crbug.com/605661.
- expect_config('org.w3.clearkey', [{
- initDataTypes: ['webm'],
- audioCapabilities: [{contentType: 'audio/webm'}],
- videoCapabilities: [{contentType: 'video/webm'}],
- }], {
- initDataTypes: ['webm'],
- audioCapabilities: [{contentType: 'audio/webm'}],
- videoCapabilities: [{contentType: 'video/webm'}],
- }, 'Basic supported configuration');
-
- // TODO(jrummell): Specifying contentType without codecs is
- // deprecated, so this test should fail. http://crbug.com/605661.
- expect_config('org.w3.clearkey', [{
- initDataTypes: ['fakeidt', 'webm'],
- audioCapabilities: [{contentType: 'audio/fake'}, {contentType: 'audio/webm'}],
- videoCapabilities: [{contentType: 'video/fake'}, {contentType: 'video/webm'}],
- }], {
- initDataTypes: ['webm'],
- audioCapabilities: [{contentType: 'audio/webm'}],
- videoCapabilities: [{contentType: 'video/webm'}],
- }, 'Partially supported configuration');
-
- expect_config('org.w3.clearkey', [{
- audioCapabilities: [{contentType: 'audio/webm; codecs=vorbis'}],
- }], {
- audioCapabilities: [{contentType: 'audio/webm; codecs=vorbis'}],
- }, 'Supported audio codec');
-
- expect_config('org.w3.clearkey', [{
- audioCapabilities: [{contentType: 'audio/webm; codecs="vorbis"'}],
- }], {
- audioCapabilities: [{contentType: 'audio/webm; codecs="vorbis"'}],
- }, 'ContentType formatting must be preserved');
-
- expect_error('org.w3.clearkey', [{
- audioCapabilities: [{contentType: 'audio/webm; codecs=fake'}],
- }], 'NotSupportedError', 'Unsupported audio codec');
-
- expect_error('org.w3.clearkey', [{
- audioCapabilities: [
- {contentType: 'audio/webm; codecs=mp4a'},
- {contentType: 'audio/webm; codecs=mp4a.40.2'}
- ],
- }], 'NotSupportedError', 'Mismatched audio container/codec');
-
- expect_config('org.w3.clearkey', [{
- videoCapabilities: [{contentType: 'video/webm; codecs=vp8'}],
- }], {
- videoCapabilities: [{contentType: 'video/webm; codecs=vp8'}],
- }, 'Supported video codec');
-
- expect_error('org.w3.clearkey', [{
- audioCapabilities: [{contentType: 'video/webm; codecs=vp8'}],
- }], 'NotSupportedError', 'Video codec specified in audio field');
-
- expect_error('org.w3.clearkey', [{
- videoCapabilities: [{contentType: 'audio/webm; codecs=vorbis'}],
- }], 'NotSupportedError', 'Audio codec specified in video field');
-
- expect_error('org.w3.clearkey', [{
- audioCapabilities: [{contentType: 'video/webm; codecs=fake'}],
- }], 'NotSupportedError', 'Unsupported video codec');
-
- expect_error('org.w3.clearkey', [{
- audioCapabilities: [
- {contentType: 'audio/webm; codecs=avc1'},
- {contentType: 'audio/webm; codecs=avc1.42e01e'}
- ],
- }], 'NotSupportedError', 'Mismatched video container/codec');
-
- expect_config('org.w3.clearkey', [
- {initDataTypes: ['fakeidt']},
- {initDataTypes: ['webm']}
- ], {initDataTypes: ['webm']}, 'Two configurations, one supported');
-
- expect_config('org.w3.clearkey', [
- {initDataTypes: ['webm']},
- {}
- ], {initDataTypes: ['webm']}, 'Two configurations, both supported');
-
- // Audio MIME type does not support video codecs.
- expect_error('org.w3.clearkey', [{
- audioCapabilities: [
- {contentType: 'audio/webm; codecs="vp8,vorbis"'},
- {contentType: 'audio/webm; codecs="vorbis, vp8"'},
- {contentType: 'audio/webm; codecs="vp8"'}
- ],
- }], 'NotSupportedError', 'Audio MIME type does not support video codecs.');
-
- // Video MIME type does not support audio codecs.
- expect_error('org.w3.clearkey', [{
- videoCapabilities: [
- {contentType: 'video/webm; codecs="vp8,vorbis"'},
- {contentType: 'video/webm; codecs="vorbis, vp8"'},
- {contentType: 'video/webm; codecs="vorbis"'}
- ],
- }], 'NotSupportedError', 'Video MIME type does not support audio codecs.');
-
- // WebM does not support AVC1/AAC.
- expect_error('org.w3.clearkey', [{
- audioCapabilities: [
- {contentType: 'audio/webm; codecs="aac"'},
- {contentType: 'audio/webm; codecs="avc1"'},
- {contentType: 'audio/webm; codecs="vp8,aac"'}
- ],
- }], 'NotSupportedError', 'WebM audio does not support AVC1/AAC.');
-
- expect_error('org.w3.clearkey', [{
- videoCapabilities: [
- {contentType: 'video/webm; codecs="aac"'},
- {contentType: 'video/webm; codecs="avc1"'},
- {contentType: 'video/webm; codecs="vp8,aac"'}
- ],
- }], 'NotSupportedError', 'WebM video does not support AVC1/AAC.');
-
- // Extra space is allowed in contentType.
- expect_config('org.w3.clearkey', [{
- videoCapabilities: [{contentType: ' video/webm; codecs="vp8"'}],
- }], {
- videoCapabilities: [{contentType: ' video/webm; codecs="vp8"'}],
- }, 'Leading space in contentType');
-
- expect_config('org.w3.clearkey', [{
- videoCapabilities: [{contentType: 'video/webm ; codecs="vp8"'}],
- }], {
- videoCapabilities: [{contentType: 'video/webm ; codecs="vp8"'}],
- }, 'Space before ; in contentType');
-
- expect_config('org.w3.clearkey', [{
- videoCapabilities: [{contentType: 'video/webm; codecs="vp8"'}],
- }], {
- videoCapabilities: [{contentType: 'video/webm; codecs="vp8"'}],
- }, 'Extra spaces after ; in contentType');
-
- // TODO(jrummell): contentType should allow white space at the
- // end of the string. http://crbug.com/487392
-// expect_config('org.w3.clearkey', [{
-// videoCapabilities: [{contentType: 'video/webm; codecs="vp8" '}],
-// }], {
-// videoCapabilities: [{contentType: 'video/webm; codecs="vp8" '}],
-// }, 'Trailing space in contentType');
-
- expect_config('org.w3.clearkey', [{
- videoCapabilities: [{contentType: 'video/webm; codecs=" vp8"'}],
- }], {
- videoCapabilities: [{contentType: 'video/webm; codecs=" vp8"'}],
- }, 'Space at start of codecs parameter');
-
- expect_config('org.w3.clearkey', [{
- videoCapabilities: [{contentType: 'video/webm; codecs="vp8 "'}],
- }], {
- videoCapabilities: [{contentType: 'video/webm; codecs="vp8 "'}],
- }, 'Space at end of codecs parameter');
-
- // contentType is not case sensitive (except the codec names).
- expect_config('org.w3.clearkey', [{
- videoCapabilities: [{contentType: 'Video/webm; codecs="vp8"'}],
- }], {
- videoCapabilities: [{contentType: 'Video/webm; codecs="vp8"'}],
- }, 'Video/webm');
-
- expect_config('org.w3.clearkey', [{
- videoCapabilities: [{contentType: 'video/Webm; codecs="vp8"'}],
- }], {
- videoCapabilities: [{contentType: 'video/Webm; codecs="vp8"'}],
- }, 'video/Webm');
-
- expect_config('org.w3.clearkey', [{
- videoCapabilities: [{contentType: 'video/webm; Codecs="vp8"'}],
- }], {
- videoCapabilities: [{contentType: 'video/webm; Codecs="vp8"'}],
- }, 'Codecs=');
-
- expect_config('org.w3.clearkey', [{
- videoCapabilities: [{contentType: 'VIDEO/WEBM; codecs="vp8"'}],
- }], {
- videoCapabilities: [{contentType: 'VIDEO/WEBM; codecs="vp8"'}],
- }, 'VIDEO/WEBM');
-
- expect_config('org.w3.clearkey', [{
- videoCapabilities: [{contentType: 'video/webm; CODECS="vp8"'}],
- }], {
- videoCapabilities: [{contentType: 'video/webm; CODECS="vp8"'}],
- }, 'CODECS=');
-
- // Unrecognized attributes are not allowed.
- // TODO(jrummell): Unrecognized attributes are ignored currently.
- // http://crbug.com/449690
-// expect_error('org.w3.clearkey', [{
-// videoCapabilities: [{contentType: 'video/webm; foo="bar"'}],
-// }], 'NotSupportedError', 'Unrecognized foo');
-// expect_error('org.w3.clearkey', [{
-// videoCapabilities: [{contentType: 'video/webm; foo="bar"; codecs="vp8"'}],
-// }], 'NotSupportedError', 'Unrecognized foo with codecs');
-
- // Invalid contentTypes.
- expect_error('org.w3.clearkey', [{
- videoCapabilities: [{contentType: 'fake'}],
- }], 'NotSupportedError', 'contentType fake');
-
- expect_error('org.w3.clearkey', [{
- audioCapabilities: [{contentType: 'audio/fake'}],
- }], 'NotSupportedError', 'contentType audio/fake');
-
- expect_error('org.w3.clearkey', [{
- videoCapabilities: [{contentType: 'video/fake'}],
- }], 'NotSupportedError', 'contentType video/fake');
-
- // The actual codec names are case sensitive.
- expect_error('org.w3.clearkey', [{
- videoCapabilities: [{contentType: 'video/webm; codecs="Vp8"'}],
- }], 'NotSupportedError', 'codecs Vp8');
-
- expect_error('org.w3.clearkey', [{
- videoCapabilities: [{contentType: 'video/webm; codecs="VP8"'}],
- }], 'NotSupportedError', 'codecs VP8');
-
- // Extra comma is not allowed in codecs.
- expect_error('org.w3.clearkey', [{
- videoCapabilities: [{contentType: 'video/webm; codecs=",vp8"'}],
- }], 'NotSupportedError', 'Leading , in codecs');
-
- expect_error('org.w3.clearkey', [{
- videoCapabilities: [{contentType: 'video/webm; codecs="vp8,"'}],
- }], 'NotSupportedError', 'Trailing , in codecs');
-
- expect_error('org.w3.clearkey', [{
- videoCapabilities: [{contentType: 'video/webm; codecs=",vp8,"'}],
- }], 'NotSupportedError', 'Leading and trailing , in codecs');
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-reset-src-after-setmediakeys.html b/testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-reset-src-after-setmediakeys.html
deleted file mode 100644
index 15c91a001..000000000
--- a/testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-reset-src-after-setmediakeys.html
+++ /dev/null
@@ -1,67 +0,0 @@
-<!DOCTYPE html>
-<!-- Copyright © 2016 Chromium authors and World Wide Web Consortium, (Massachusetts Institute of Technology, ERCIM, Keio University, Beihang). -->
-<html>
- <head>
- <title>Reset src after setMediaKeys()</title>
- <script src="encrypted-media-utils.js"></script>
-<!--
- Test has been migrated to the root directory and is being disabled here.
- <script src="/resources/testharness.js"></script>
- <script src="/resources/testharnessreport.js"></script>
--->
- </head>
- <body>
- <video id="testVideo"></video>
- <div id="log"></div>
- <script>
- async_test(function(test)
- {
- var mediaKeys;
- var encryptedEventIndex = 0;
- var video = document.getElementById('testVideo');
- assert_not_equals(video, null);
-
- // Content to be played. These files must be the same format.
- var content = 'webm/test-encrypted.webm';
- var alternateContent = 'webm/test-encrypted-different-av-keys.webm';
-
- var onEncrypted = function(event)
- {
- ++encryptedEventIndex;
- assert_not_equals(video.mediaKeys, null);
- assert_true(video.mediaKeys === mediaKeys);
-
- // This event is fired once for the audio stream and once
- // for the video stream each time .src is set.
- if (encryptedEventIndex == 2) {
- // Finished first video; set src to a different video.
- video.src = alternateContent;
- } else if (encryptedEventIndex == 4) {
- // Finished second video.
- test.done();
- }
- };
-
- // Create a MediaKeys object and assign it to video.
- navigator.requestMediaKeySystemAccess('org.w3.clearkey', getConfigurationForFile(content))
- .then(function(access) {
- assert_equals(access.keySystem, 'org.w3.clearkey');
- return access.createMediaKeys();
- }).then(function(result) {
- mediaKeys = result;
- assert_not_equals(mediaKeys, null);
- return video.setMediaKeys(mediaKeys);
- }).then(function(result) {
- assert_not_equals(video.mediaKeys, null, 'not set initially');
- assert_true(video.mediaKeys === mediaKeys);
-
- // Set src to a video.
- waitForEventAndRunStep('encrypted', video, onEncrypted, test);
- video.src = content;
- }).catch(function(error) {
- forceTestFailureFromPromise(test, error);
- });
- }, 'Reset src after setMediaKeys().');
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-session-closed-event.html b/testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-session-closed-event.html
deleted file mode 100644
index 577047a25..000000000
--- a/testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-session-closed-event.html
+++ /dev/null
@@ -1,51 +0,0 @@
-<!DOCTYPE html>
-<!-- Copyright © 2016 Chromium authors and World Wide Web Consortium, (Massachusetts Institute of Technology, ERCIM, Keio University, Beihang). -->
-<html>
- <head>
- <title>Test MediaKeySession closed event</title>
- <script src="encrypted-media-utils.js"></script>
-<!--
- Test has been migrated to the root directory and is being disabled here.
- <script src="/resources/testharness.js"></script>
- <script src="/resources/testharnessreport.js"></script>
--->
- </head>
- <body>
- <div id="log"></div>
- <script>
- async_test(function(test)
- {
- var initDataType;
- var initData;
- var mediaKeySession;
-
- navigator.requestMediaKeySystemAccess('org.w3.clearkey', getSimpleConfiguration()).then(function(access) {
- initDataType = access.getConfiguration().initDataTypes[0];
- initData = getInitData(initDataType);
- return access.createMediaKeys();
- }).then(function(mediaKeys) {
- mediaKeySession = mediaKeys.createSession();
- return mediaKeySession.generateRequest(initDataType, initData);
- }).then(function() {
- // Wait for the session to be closed.
- mediaKeySession.closed.then(function(result) {
- assert_equals(result, undefined);
- // Now that the session is closed, verify that the
- // closed attribute immediately returns a fulfilled
- // promise.
- return mediaKeySession.closed;
- }).then(function(result) {
- assert_equals(result, undefined);
- test.done();
- });
-
- // release() should result in the closed promise being
- // fulfilled.
- return mediaKeySession.close();
- }).catch(function(error) {
- forceTestFailureFromPromise(test, error);
- });
- }, 'Test MediaKeySession closed event.');
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-setmediakeys-again-after-playback.html b/testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-setmediakeys-again-after-playback.html
deleted file mode 100644
index 29f53b31d..000000000
--- a/testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-setmediakeys-again-after-playback.html
+++ /dev/null
@@ -1,48 +0,0 @@
-<!DOCTYPE html>
-<!-- Copyright © 2016 Chromium authors and World Wide Web Consortium, (Massachusetts Institute of Technology, ERCIM, Keio University, Beihang). -->
-<html>
- <head>
- <title>setMediaKeys() again after playback</title>
- <script src="encrypted-media-utils.js"></script>
-<!--
- Test has been migrated to the root directory and is being disabled here.
- <script src="/resources/testharness.js"></script>
- <script src="/resources/testharnessreport.js"></script>
--->
- </head>
- <body>
- <video id="testVideo"></video>
- <div id="log"></div>
- <script>
- promise_test(function(test)
- {
- var video = document.getElementById('testVideo');
- var keyId = stringToUint8Array('0123456789012345');
- var rawKey = new Uint8Array([0xeb, 0xdd, 0x62, 0xf1, 0x68, 0x14, 0xd2, 0x7b,
- 0x68, 0xef, 0x12, 0x2a, 0xfc, 0xe4, 0xae, 0x3c]);
- var content = 'webm/test-encrypted.webm';
- var duration = 0.2;
-
- return createMediaKeys(keyId, rawKey).then(function(mediaKeys) {
- return video.setMediaKeys(mediaKeys);
- }).then(function() {
- return playVideoAndWaitForTimeupdate(video, content, duration);
- }).then(function() {
- // Now create a second MediaKeys.
- return createMediaKeys(keyId, rawKey);
- }).then(function(mediaKeys) {
- // video is currently playing, so should not be able to
- // change MediaKeys now.
- assert_false(video.ended);
- return video.setMediaKeys(mediaKeys);
- }).then(function() {
- assert_unreached('Able to change MediaKeys while playing.');
- }, function(error) {
- // Error expected.
- assert_equals(error.name, 'InvalidStateError');
- return Promise.resolve('success');
- });
- }, 'setMediaKeys() again after playback');
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-setmediakeys-again-after-resetting-src.html b/testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-setmediakeys-again-after-resetting-src.html
deleted file mode 100644
index 8f6891b79..000000000
--- a/testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-setmediakeys-again-after-resetting-src.html
+++ /dev/null
@@ -1,44 +0,0 @@
-<!DOCTYPE html>
-<!-- Copyright © 2016 Chromium authors and World Wide Web Consortium, (Massachusetts Institute of Technology, ERCIM, Keio University, Beihang). -->
-<html>
- <head>
- <title>setMediaKeys() again after resetting src</title>
- <script src="encrypted-media-utils.js"></script>
-<!--
- Test has been migrated to the root directory and is being disabled here.
- <script src="/resources/testharness.js"></script>
- <script src="/resources/testharnessreport.js"></script>
--->
- </head>
- <body>
- <video id="testVideo"></video>
- <div id="log"></div>
- <script>
- promise_test(function(test)
- {
- var video = document.getElementById('testVideo');
- var keyId = stringToUint8Array('0123456789012345');
- var rawKey = new Uint8Array([0xeb, 0xdd, 0x62, 0xf1, 0x68, 0x14, 0xd2, 0x7b,
- 0x68, 0xef, 0x12, 0x2a, 0xfc, 0xe4, 0xae, 0x3c]);
- var content = 'webm/test-encrypted.webm';
- var duration = 0.2;
-
- return createMediaKeys(keyId, rawKey).then(function(mediaKeys) {
- return video.setMediaKeys(mediaKeys);
- }).then(function() {
- return playVideoAndWaitForTimeupdate(video, content, duration);
- }).then(function() {
- // Now create a second MediaKeys and repeat.
- return createMediaKeys(keyId, rawKey);
- }).then(function(mediaKeys) {
- // MediaKeys is use by previous video, so clear .src
- // so that MediaKeys can be assigned.
- video.src = '';
- return video.setMediaKeys(mediaKeys);
- }).then(function() {
- return playVideoAndWaitForTimeupdate(video, content, duration);
- });
- }, 'setMediaKeys() again after resetting src');
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-setmediakeys-at-same-time.html b/testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-setmediakeys-at-same-time.html
deleted file mode 100644
index 01fd7b194..000000000
--- a/testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-setmediakeys-at-same-time.html
+++ /dev/null
@@ -1,109 +0,0 @@
-<!DOCTYPE html>
-<!-- Copyright © 2016 Chromium authors and World Wide Web Consortium, (Massachusetts Institute of Technology, ERCIM, Keio University, Beihang). -->
-<html>
- <head>
- <title>Set MediaKeys multiple times in parallel</title>
- <script src="encrypted-media-utils.js"></script>
-<!--
- Test has been migrated to the root directory and is being disabled here.
- <script src="/resources/testharness.js"></script>
- <script src="/resources/testharnessreport.js"></script>
--->
- </head>
- <body>
- <video id="video"></video>
- <div id="log"></div>
- <script>
- // Wait for an 'encrypted' event as a promise.
- function wait_for_encrypted_event(video)
- {
- return new Promise(function(resolve) {
- video.addEventListener('encrypted', function listener(e) {
- video.removeEventListener('encrypted', listener);
- resolve();
- });
- });
- };
-
- // Return a promise that calls setMediaKeys() and returns 1 if
- // resolved, 0 if rejected. If |must_succeed| is true, then
- // setMediaKeys() should not fail.
- function setMediaKeys_as_count(video, mediaKeys, must_succeed)
- {
- return video.setMediaKeys(mediaKeys).then(function() {
- return 1;
- }, function() {
- assert_false(must_succeed);
- return 0;
- });
- };
-
- // Return the sum of the results from |promises|. Each promise
- // must return a number.
- function count_promise_results(promises)
- {
- var count = 0;
- var result = Promise.resolve(null);
-
- promises.forEach(function(promise) {
- result = result.then(function() {
- return promise;
- }).then(function(i) {
- count += i;
- });
- });
-
- return result.then(function() { return count; });
- };
-
- promise_test(function(test)
- {
- var video = document.getElementById('video');
- var content = 'webm/test-encrypted.webm';
- var access;
- var mediaKeys1;
- var mediaKeys2;
- var mediaKeys3;
- var mediaKeys4;
- var mediaKeys5;
-
- // Start a video now so that it is waiting for MediaKeys
- // in order to continue.
- video.src = content;
- video.play();
- return wait_for_encrypted_event(video).then(function() {
- return navigator.requestMediaKeySystemAccess('org.w3.clearkey', getConfigurationForFile(content));
- }).then(function(result) {
- access = result;
- return access.createMediaKeys();
- }).then(function(result) {
- mediaKeys1 = result;
- return access.createMediaKeys();
- }).then(function(result) {
- mediaKeys2 = result;
- return access.createMediaKeys();
- }).then(function(result) {
- mediaKeys3 = result;
- return access.createMediaKeys();
- }).then(function(result) {
- mediaKeys4 = result;
- return access.createMediaKeys();
- }).then(function(result) {
- mediaKeys5 = result;
- // Create 5 calls to setMediaKeys(). The first one must
- // succeed, the others are optional.
- var p1 = setMediaKeys_as_count(video, mediaKeys1, true);
- var p2 = setMediaKeys_as_count(video, mediaKeys2, false);
- var p3 = setMediaKeys_as_count(video, mediaKeys3, false);
- var p4 = setMediaKeys_as_count(video, mediaKeys4, false);
- var p5 = setMediaKeys_as_count(video, mediaKeys5, false);
- return count_promise_results([p1, p2, p3, p4, p5]);
- }).then(function(count) {
- // At least one of the setMediaKeys() calls should have
- // succeeded.
- assert_greater_than(count, 0);
- });
- }, 'Set MediaKeys multiple times in parallel.');
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-setmediakeys-multiple-times-with-different-mediakeys.html b/testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-setmediakeys-multiple-times-with-different-mediakeys.html
deleted file mode 100644
index 31cc61079..000000000
--- a/testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-setmediakeys-multiple-times-with-different-mediakeys.html
+++ /dev/null
@@ -1,83 +0,0 @@
-<!DOCTYPE html>
-<!-- Copyright © 2016 Chromium authors and World Wide Web Consortium, (Massachusetts Institute of Technology, ERCIM, Keio University, Beihang). -->
-<html>
- <head>
- <title>setMediaKeys() multiple times with different MediaKeys.</title>
- <script src="encrypted-media-utils.js"></script>
-<!--
- Test has been migrated to the root directory and is being disabled here.
- <script src="/resources/testharness.js"></script>
- <script src="/resources/testharnessreport.js"></script>
--->
- </head>
- <body>
- <video id="video"></video>
- <div id="log"></div>
- <script>
- promise_test(function(test)
- {
- var video = document.getElementById('video');
- var content = 'webm/test-encrypted.webm';
- var keySystemAccess;
- var mediaKeys1;
- var mediaKeys2;
-
- assert_equals(video.mediaKeys, null);
-
- return navigator.requestMediaKeySystemAccess('org.w3.clearkey', getConfigurationForFile(content)).then(function(access) {
- keySystemAccess = access;
- // Create a mediaKeys.
- return keySystemAccess.createMediaKeys();
- }).then(function(result) {
- mediaKeys1 = result;
- assert_not_equals(mediaKeys1, null);
- // Create a second mediaKeys.
- return keySystemAccess.createMediaKeys();
- }).then(function(result) {
- mediaKeys2 = result;
- assert_not_equals(mediaKeys2, null);
- // Set mediaKeys1 on video.
- return video.setMediaKeys(mediaKeys1);
- }).then(function() {
- assert_true(video.mediaKeys === mediaKeys1);
- // Set mediaKeys2 on video (switching MediaKeys).
- return video.setMediaKeys(mediaKeys2);
- }).then(function() {
- assert_true(video.mediaKeys === mediaKeys2);
- // Clear mediaKeys from video.
- return video.setMediaKeys(null);
- }).then(function() {
- assert_equals(video.mediaKeys, null);
- // Set mediaKeys1 on video again.
- return video.setMediaKeys(mediaKeys1);
- }).then(function() {
- assert_true(video.mediaKeys === mediaKeys1);
- // Load the media element to create the WebMediaPlayer.
- video.src = content;
- // Set mediaKeys2 on video (switching MediaKeys) not
- // supported after WebMediaPlayer is created.
- return video.setMediaKeys(mediaKeys2);
- }).then(function() {
- assert_unreached('Switching mediaKeys after setting src should have failed.');
- }, function(error) {
- assert_true(video.mediaKeys === mediaKeys1);
- assert_equals(error.name, 'InvalidStateError');
- assert_not_equals(error.message, '');
- // Return something so the promise resolves properly.
- return Promise.resolve();
- }).then(function() {
- // Set null mediaKeys on video (clearing MediaKeys) not
- // supported after WebMediaPlayer is created.
- return video.setMediaKeys(null);
- }).then(function() {
- assert_unreached('Clearing mediaKeys after setting src should have failed.');
- }, function(error) {
- assert_true(video.mediaKeys === mediaKeys1);
- assert_equals(error.name, 'InvalidStateError');
- assert_not_equals(error.message, '');
- return Promise.resolve();
- });
- }, 'setMediaKeys() multiple times with different MediaKeys.');
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-setmediakeys-multiple-times-with-the-same-mediakeys.html b/testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-setmediakeys-multiple-times-with-the-same-mediakeys.html
deleted file mode 100644
index 64ed315e0..000000000
--- a/testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-setmediakeys-multiple-times-with-the-same-mediakeys.html
+++ /dev/null
@@ -1,50 +0,0 @@
-<!DOCTYPE html>
-<!-- Copyright © 2016 Chromium authors and World Wide Web Consortium, (Massachusetts Institute of Technology, ERCIM, Keio University, Beihang). -->
-<html>
- <head>
- <title>setMediaKeys() multiple times with the same MediaKeys.</title>
- <script src="encrypted-media-utils.js"></script>
-<!--
- Test has been migrated to the root directory and is being disabled here.
- <script src="/resources/testharness.js"></script>
- <script src="/resources/testharnessreport.js"></script>
--->
- </head>
- <body>
- <video id="video"></video>
- <div id="log"></div>
- <script>
- promise_test(function(test)
- {
- var video = document.getElementById('video');
- var content = 'webm/test-encrypted.webm';
- var mediaKeys;
-
- assert_equals(video.mediaKeys, null);
-
- return navigator.requestMediaKeySystemAccess('org.w3.clearkey', getConfigurationForFile(content)).then(function(access) {
- return access.createMediaKeys();
- }).then(function(result) {
- mediaKeys = result;
- assert_not_equals(mediaKeys, null);
- // Set mediaKeys on video should work.
- return video.setMediaKeys(mediaKeys);
- }).then(function() {
- assert_true(video.mediaKeys === mediaKeys);
- // Set mediaKeys on video again should return a resolved
- // promise.
- return video.setMediaKeys(mediaKeys);
- }).then(function() {
- assert_true(video.mediaKeys === mediaKeys);
- // Load the media element to create the WebMediaPlayer.
- video.src = content;
- // Set mediaKeys again on video should still return a
- // resolved promise.
- return video.setMediaKeys(mediaKeys);
- }).then(function() {
- assert_true(video.mediaKeys === mediaKeys);
- });
- }, 'setMediaKeys() multiple times with the same MediaKeys.');
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-setmediakeys-to-multiple-video-elements.html b/testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-setmediakeys-to-multiple-video-elements.html
deleted file mode 100644
index fb8386e8c..000000000
--- a/testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-setmediakeys-to-multiple-video-elements.html
+++ /dev/null
@@ -1,50 +0,0 @@
-<!DOCTYPE html>
-<!-- Copyright © 2016 Chromium authors and World Wide Web Consortium, (Massachusetts Institute of Technology, ERCIM, Keio University, Beihang). -->
-<html>
- <head>
- <title>setMediaKeys() on multiple video elements.</title>
- <script src="encrypted-media-utils.js"></script>
-<!--
- Test has been migrated to the root directory and is being disabled here.
- <script src="/resources/testharness.js"></script>
- <script src="/resources/testharnessreport.js"></script>
--->
- </head>
- <body>
- <video id="video1"></video>
- <video id="video2"></video>
- <div id="log"></div>
- <script>
- promise_test(function(test)
- {
- var video1 = document.getElementById('video1');
- var video2 = document.getElementById('video2');
- var mediaKeys;
-
- return navigator.requestMediaKeySystemAccess('org.w3.clearkey', getSimpleConfiguration()).then(function(access) {
- return access.createMediaKeys();
- }).then(function(result) {
- mediaKeys = result;
- // Assignment to video1 should work.
- return video1.setMediaKeys(mediaKeys);
- }).then(function() {
- // Assignment to video2 should fail.
- return video2.setMediaKeys(mediaKeys);
- }).then(function() {
- assert_unreached('Second setMediaKeys should have failed.');
- }, function(error) {
- assert_equals(error.name, 'QuotaExceededError');
- assert_not_equals(error.message, '');
- // Return something so the promise resolves properly.
- return Promise.resolve();
- }).then(function() {
- // Now clear it from video1.
- return video1.setMediaKeys(null);
- }).then(function() {
- // Should be assignable to video2.
- return video2.setMediaKeys(mediaKeys);
- });
- }, 'setMediaKeys() on multiple video elements.');
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-setmediakeys.html b/testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-setmediakeys.html
deleted file mode 100644
index 96b0fed97..000000000
--- a/testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-setmediakeys.html
+++ /dev/null
@@ -1,59 +0,0 @@
-<!DOCTYPE html>
-<!-- Copyright © 2016 Chromium authors and World Wide Web Consortium, (Massachusetts Institute of Technology, ERCIM, Keio University, Beihang). -->
-<html>
- <head>
- <title>setMediaKeys</title>
- <script src="encrypted-media-utils.js"></script>
-<!--
- Test has been migrated to the root directory and is being disabled here.
- <script src="/resources/testharness.js"></script>
- <script src="/resources/testharnessreport.js"></script>
--->
- </head>
- <body>
- <video id="video"></video>
- <div id="log"></div>
- <script>
- async_test(function(test)
- {
- var mediaKeys;
- var video = document.getElementById('video');
- assert_not_equals(video, null);
-
- // Test MediaKeys assignment.
- assert_equals(video.mediaKeys, null);
- assert_equals(typeof video.setMediaKeys, 'function');
-
- // Try setting mediaKeys to null.
- video.setMediaKeys(null).then(function(result) {
- assert_equals(video.mediaKeys, null);
-
- // Try setting mediaKeys to the wrong type of object.
- return video.setMediaKeys(new Date());
- }).then(function(result) {
- assert_unreached('setMediaKeys did not fail when setting to Date()');
- }, function(error) {
- // TypeError expected.
- assert_equals(error.name, 'TypeError');
-
- // Create a MediaKeys object and assign it to video.
- return navigator.requestMediaKeySystemAccess('org.w3.clearkey', getSimpleConfiguration());
- }).then(function(access) {
- assert_equals(access.keySystem, 'org.w3.clearkey');
- return access.createMediaKeys();
- }).then(function(result) {
- mediaKeys = result;
- assert_not_equals(mediaKeys, null);
- assert_equals(typeof mediaKeys.createSession, 'function');
- return video.setMediaKeys(mediaKeys);
- }).then(function(result) {
- assert_not_equals(video.mediaKeys, null);
- assert_true(video.mediaKeys === mediaKeys);
- test.done();
- }).catch(function(error) {
- forceTestFailureFromPromise(test, error);
- });
- }, 'Setting MediaKeys on a video object.');
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-syntax.html b/testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-syntax.html
deleted file mode 100644
index 5c4c667cb..000000000
--- a/testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-syntax.html
+++ /dev/null
@@ -1,1017 +0,0 @@
-<!DOCTYPE html>
-<!-- Copyright © 2016 Chromium authors and World Wide Web Consortium, (Massachusetts Institute of Technology, ERCIM, Keio University, Beihang). -->
-<html>
- <head>
- <title>Test EME syntax</title>
- <script src="encrypted-media-utils.js"></script>
-<!--
- Test has been migrated to the root directory and is being disabled here.
- <script src="/resources/testharness.js"></script>
- <script src="/resources/testharnessreport.js"></script>
--->
- </head>
- <body>
- <script>
- // Since promises catch any exception and convert it into a
- // rejected Promise, there is no current way to have the W3C
- // test framework report a failed test. For now, simply force
- // a timeout to indicate failure.
- // FIXME: Once W3C test framework handles Promises, fix this.
-
- // This function checks that calling |testCase.func| returns a
- // rejected Promise with the error.name equal to
- // |testCase.exception|.
- function test_exception(testCase /*...*/)
- {
- var func = testCase.func;
- var exception = testCase.exception;
- var args = Array.prototype.slice.call(arguments, 1);
-
- // Currently blink throws for TypeErrors rather than returning
- // a rejected promise (http://crbug.com/359386).
- // FIXME: Remove try/catch once they become failed promises.
- try {
- return func.apply(null, args).then(
- function(result)
- {
- assert_unreached(format_value(func));
- },
- function(error)
- {
- assert_equals(error.name, exception, format_value(func));
- assert_not_equals(error.message, "", format_value(func));
- }
- );
- } catch (e) {
- // Only allow 'TypeError' exceptions to be thrown.
- // Everything else should be a failed promise.
- assert_equals('TypeError', exception, format_value(func));
- assert_equals(e.name, exception, format_value(func));
- }
- }
-
- var kRequestMediaKeySystemAccessExceptionsTestCases = [
- // Too few parameters.
- {
- exception: 'TypeError',
- func: function() { return navigator.requestMediaKeySystemAccess(); }
- },
- {
- exception: 'TypeError',
- func: function() { return navigator.requestMediaKeySystemAccess('org.w3.clearkey'); }
- },
- // Invalid key systems. Note that JavaScript converts all these
- // values into strings by calling toString(), so they fail due
- // to the key system not being supported, not due to the type.
- {
- exception: 'NotSupportedError',
- func: function() { return navigator.requestMediaKeySystemAccess(null, [{}]); }
- },
- {
- exception: 'NotSupportedError',
- func: function() { return navigator.requestMediaKeySystemAccess(undefined, [{}]); }
- },
- {
- exception: 'NotSupportedError',
- func: function() { return navigator.requestMediaKeySystemAccess(1, [{}]); }
- },
- {
- exception: 'InvalidAccessError',
- func: function() { return navigator.requestMediaKeySystemAccess(new Uint8Array(0), [{}]); }
- },
- {
- exception: 'InvalidAccessError',
- func: function() { return navigator.requestMediaKeySystemAccess('', [{}]); }
- },
- {
- exception: 'NotSupportedError',
- func: function() { return navigator.requestMediaKeySystemAccess('unsupported', [{}]); }
- },
- // Non-ASCII names.
- {
- exception: 'NotSupportedError',
- func: function() { return navigator.requestMediaKeySystemAccess('org.w3\u263A.clearkey', [{}]); }
- },
- // Empty sequence of MediaKeySystemConfiguration.
- {
- exception: 'InvalidAccessError',
- func: function() { return navigator.requestMediaKeySystemAccess('org.w3.clearkey', []); }
- },
- // Invalid sequences of MediaKeySystemConfigurations.
- {
- exception: 'TypeError',
- func: function() { return navigator.requestMediaKeySystemAccess('org.w3.clearkey', {}); }
- },
- {
- exception: 'TypeError',
- func: function() { return navigator.requestMediaKeySystemAccess('org.w3.clearkey', "invalid"); }
- },
- {
- exception: 'TypeError',
- func: function() { return navigator.requestMediaKeySystemAccess('org.w3.clearkey', [{}, 6]); }
- },
- {
- exception: 'TypeError',
- func: function() { return navigator.requestMediaKeySystemAccess('org.w3.clearkey', ["invalid", "upsupported"]); }
- }
- ];
-
- async_test(function(test)
- {
- var createPromises = kRequestMediaKeySystemAccessExceptionsTestCases.map(function(testCase) {
- return test_exception(testCase);
- });
-
- Promise.all(createPromises).then(function(result) {
- test.done();
- }).catch(function(error) {
- forceTestFailureFromPromise(test, error, 'requestMediaKeySystemAccess() tests failed');
- });
- }, 'Test Navigator.requestMediaKeySystemAccess() exceptions.');
-
- async_test(function(test)
- {
- assert_equals(typeof navigator.requestMediaKeySystemAccess, 'function');
- navigator.requestMediaKeySystemAccess('org.w3.clearkey', [{}]).then(function(access) {
- assert_not_equals(access, null);
- assert_equals(typeof access, 'object');
- assert_equals(access.keySystem, 'org.w3.clearkey');
- assert_equals(typeof access.getConfiguration, 'function');
- assert_equals(typeof access.createMediaKeys, 'function');
- test.done();
- }).catch(function(error) {
- forceTestFailureFromPromise(test, error, 'requestMediaKeySystemAccess() tests failed');
- });
- }, 'Test Navigator.requestMediaKeySystemAccess().');
-
- async_test(function(test)
- {
- var access;
-
- navigator.requestMediaKeySystemAccess('org.w3.clearkey', [{}]).then(function(result) {
- access = result;
- assert_equals(access.keySystem, 'org.w3.clearkey');
- return access.createMediaKeys();
- }).then(function(mediaKeys) {
- assert_not_equals(mediaKeys, null);
- assert_equals(typeof mediaKeys, 'object');
- assert_equals(typeof mediaKeys.createSession, 'function');
- assert_equals(typeof mediaKeys.setServerCertificate, 'function');
-
- // Test creation of a second MediaKeys.
- // The extra parameter is ignored.
- return access.createMediaKeys('extra');
- }).then(function(mediaKeys) {
- assert_not_equals(mediaKeys, null);
- assert_equals(typeof mediaKeys, 'object');
- assert_equals(typeof mediaKeys.createSession, 'function');
- assert_equals(typeof mediaKeys.setServerCertificate, 'function');
- test.done();
- }).catch(function(error) {
- forceTestFailureFromPromise(test, error, 'create() tests failed');
- });
- }, 'Test MediaKeySystemAccess createMediaKeys().');
-
- var kCreateSessionExceptionsTestCases = [
- // Tests in this set use a shortened parameter name due to
- // format_value() only returning the first 60 characters as the
- // result. With a longer name the first 60 characters is not
- // enough to determine which test failed.
-
- // Invalid parameters.
- {
- exception: 'TypeError',
- func: function(mk) { return mk.createSession(); }
- },
- {
- exception: 'TypeError',
- func: function(mk) { return mk.createSession(''); }
- },
- {
- exception: 'TypeError',
- func: function(mk) { return mk.createSession(null); }
- },
- {
- exception: 'TypeError',
- func: function(mk) { return mk.createSession(undefined); }
- },
- {
- exception: 'TypeError',
- func: function(mk) { return mk.createSession(1); }
- },
- {
- exception: 'TypeError',
- func: function(mk) { return mk.createSession(new Uint8Array(0)); }
- },
- {
- exception: 'TypeError',
- func: function(mk) { return mk.createSession('TEMPORARY'); }
- }
- ];
-
- // This function checks that calling createSession() with an
- // unsupported session type doesn't create a MediaKeySession object.
- // Since requestMediaKeySystemAccess() is called without specifying
- // persistent sessions, only temporary sessions will be allowed.
- function test_unsupported_sessionType(mediaKeys)
- {
- var mediaKeySession = 'test';
-
- try {
- mediaKeySession = mediaKeys.createSession('persistent-license');
- assert_unreached('Session should not be created.');
- } catch (error) {
- assert_equals(error.name, 'NotSupportedError');
- assert_not_equals(error.message, "");
-
- // Since createSession() failed, |mediaKeySession| is not
- // touched.
- assert_equals(mediaKeySession, 'test');
- }
- }
-
- async_test(function(test)
- {
- navigator.requestMediaKeySystemAccess('org.w3.clearkey', [{}]).then(function(access) {
- return access.createMediaKeys();
- }).then(function(mediaKeys) {
- var sessionPromises = kCreateSessionExceptionsTestCases.map(function(testCase) {
- return test_exception(testCase, mediaKeys);
- });
- sessionPromises = sessionPromises.concat(test_unsupported_sessionType(mediaKeys));
-
- assert_not_equals(sessionPromises.length, 0);
- return Promise.all(sessionPromises);
- }).then(function(result) {
- test.done();
- }).catch(function(error) {
- forceTestFailureFromPromise(test, error, 'createSession() tests failed');
- });
- }, 'Test MediaKeys createSession() exceptions.');
-
- var kGenerateRequestExceptionsTestCases = [
- // Tests in this set use a shortened parameter name due to
- // format_value() only returning the first 60 characters as the
- // result. With a longer name the first 60 characters is not
- // enough to determine which test failed. Even with the
- // shortened name, the error message for the last couple of
- // tests is the same.
- // Too few parameters.
- {
- exception: 'TypeError',
- func: function(mk1) { return mk1.createSession().generateRequest(); }
- },
- {
- exception: 'TypeError',
- func: function(mk2) { return mk2.createSession().generateRequest(''); }
- },
- {
- exception: 'TypeError',
- func: function(mk3) { return mk3.createSession().generateRequest(null); }
- },
- {
- exception: 'TypeError',
- func: function(mk4) { return mk4.createSession().generateRequest(undefined); }
- },
- {
- exception: 'TypeError',
- func: function(mk5) { return mk5.createSession().generateRequest(1); }
- },
- {
- exception: 'TypeError',
- func: function(mk6) { return mk6.createSession().generateRequest(new Uint8Array(0)); }
- },
- {
- exception: 'TypeError',
- func: function(mk7, _, initData) { return mk7.createSession().generateRequest(initData); }
- },
- // Invalid parameters.
- {
- exception: 'InvalidAccessError',
- func: function(mk8, _, initData) { return mk8.createSession().generateRequest('', initData); }
- },
- // Not supported initDataTypes.
- {
- exception: 'NotSupportedError',
- func: function(mk9, _, initData) { return mk9.createSession().generateRequest(null, initData); }
- },
- {
- exception: 'NotSupportedError',
- func: function(mk10, _, initData) { return mk10.createSession().generateRequest(undefined, initData); }
- },
- {
- exception: 'NotSupportedError',
- func: function(mk11, _, initData) { return mk11.createSession().generateRequest(1, initData); }
- },
- {
- exception: 'InvalidAccessError',
- func: function(mk12, _, initData) { return mk12.createSession().generateRequest(new Uint8Array(0), initData); }
- },
- {
- exception: 'NotSupportedError',
- func: function(mk13, _, initData) { return mk13.createSession().generateRequest('unsupported', initData); }
- },
- {
- exception: 'NotSupportedError',
- func: function(mk14, _, initData) { return mk14.createSession().generateRequest('video/webm', initData); }
- },
- {
- exception: 'NotSupportedError',
- func: function(mk15, _, initData) { return mk15.createSession().generateRequest('video/mp4', initData); }
- },
- {
- exception: 'NotSupportedError',
- func: function(mk16, _, initData) { return mk16.createSession().generateRequest('video/cenc', initData); }
- },
- {
- exception: 'NotSupportedError',
- func: function(mk17, _, initData) { return mk17.createSession().generateRequest('web\u263A', initData); }
- }
- ];
-
- var kTypeSpecificGenerateRequestExceptionsTestCases = [
- // Tests in this set use a shortened parameter name due to
- // format_value() only returning the first 60 characters as the
- // result. With a longer name the first 60 characters is not
- // enough to determine which test failed. Even with the
- // shortened name, the error message for the last couple of
- // tests is the same.
-
- // Too few parameters.
- {
- exception: 'TypeError',
- func: function(mk1, type) { return mk1.createSession().generateRequest(type); }
- },
- // Invalid parameters.
- {
- exception: 'TypeError',
- func: function(mk2, type) { return mk2.createSession().generateRequest(type, ''); }
- },
- {
- exception: 'TypeError',
- func: function(mk3, type) { return mk3.createSession().generateRequest(type, null); }
- },
- {
- exception: 'TypeError',
- func: function(mk4, type) { return mk4.createSession().generateRequest(type, undefined); }
- },
- {
- exception: 'TypeError',
- func: function(mk5, type) { return mk5.createSession().generateRequest(type, 1); }
- },
- {
- exception: 'InvalidAccessError',
- func: function(mk6, type) { return mk6.createSession().generateRequest(type, new Uint8Array(0)); }
- }
- ];
-
- async_test(function(test)
- {
- var isWebmSupported;
- var isCencSupported;
-
- isInitDataTypeSupported('webm').then(function(result) {
- isWebmSupported = result;
- return isInitDataTypeSupported('cenc');
- }).then(function(result) {
- isCencSupported = result;
- return navigator.requestMediaKeySystemAccess('org.w3.clearkey', [{}]);
- }).then(function(access) {
- return access.createMediaKeys();
- }).then(function(mediaKeys) {
- var initData = stringToUint8Array('init data');
- var sessionPromises = kGenerateRequestExceptionsTestCases.map(function(testCase) {
- return test_exception(testCase, mediaKeys, '', initData);
- });
-
- // Test that WebM sessions generate the expected error, if
- // supported.
- if (isWebmSupported) {
- var WebmSessionPromises = kTypeSpecificGenerateRequestExceptionsTestCases.map(function(testCase) {
- return test_exception(testCase, mediaKeys, 'webm', getInitData('webm'));
- });
- sessionPromises = sessionPromises.concat(WebmSessionPromises);
- }
-
- // Repeat for MP4, if supported.
- if (isCencSupported) {
- var mp4SessionPromises = kTypeSpecificGenerateRequestExceptionsTestCases.map(function(testCase) {
- return test_exception(testCase, mediaKeys, 'cenc', getInitData('cenc'));
- });
- sessionPromises = sessionPromises.concat(mp4SessionPromises);
- }
-
- assert_not_equals(sessionPromises.length, 0);
- return Promise.all(sessionPromises);
- }).then(function(result) {
- test.done();
- }).catch(function(error) {
- forceTestFailureFromPromise(test, error, 'generateRequest() tests failed');
- });
- }, 'Test MediaKeys generateRequest() exceptions.');
-
- var kLoadExceptionsTestCases = [
- // Too few parameters.
- {
- exception: 'TypeError',
- func: function(mk1) { return mk1.createSession('temporary').load(); }
- },
- // 'temporary' sessions are never allowed, so always return
- // 'InvalidAccessError'.
- {
- exception: 'InvalidAccessError',
- func: function(mk3) { return mk3.createSession('temporary').load(''); }
- },
- {
- exception: 'InvalidAccessError',
- func: function(mk4) { return mk4.createSession('temporary').load(1); }
- },
- {
- exception: 'InvalidAccessError',
- func: function(mk5) { return mk5.createSession('temporary').load('!@#$%^&*()'); }
- },
- {
- exception: 'InvalidAccessError',
- func: function(mk6) { return mk6.createSession('temporary').load('1234'); }
- }
- ];
-
- async_test(function(test)
- {
- navigator.requestMediaKeySystemAccess('org.w3.clearkey', [{}]).then(function(access) {
- return access.createMediaKeys();
- }).then(function(mediaKeys) {
- var initData = stringToUint8Array('init data');
- var sessionPromises = kLoadExceptionsTestCases.map(function(testCase) {
- return test_exception(testCase, mediaKeys);
- });
-
- assert_not_equals(sessionPromises.length, 0);
- return Promise.all(sessionPromises);
- }).then(function(result) {
- test.done();
- }).catch(function(error) {
- forceTestFailureFromPromise(test, error, 'load() tests failed');
- });
- }, 'Test MediaKeys load() exceptions.');
-
- // All calls to |func| in this group are supposed to succeed.
- // However, the spec notes that some things are optional for
- // Clear Key. In particular, support for persistent sessions
- // is optional. Since some implementations won't support some
- // features, a NotSupportedError is treated as a success
- // if |isNotSupportedAllowed| is true.
- var kCreateSessionTestCases = [
- // Use the default sessionType.
- {
- func: function(mk) { return mk.createSession(); },
- isNotSupportedAllowed: false
- },
- // Try variations of sessionType.
- {
- func: function(mk) { return mk.createSession('temporary'); },
- isNotSupportedAllowed: false
- },
- {
- func: function(mk) { return mk.createSession(undefined); },
- isNotSupportedAllowed: false
- },
- {
- // Since this is optional, some Clear Key implementations
- // will succeed, others will return a "NotSupportedError".
- // Both are allowed results.
- func: function(mk) { return mk.createSession('persistent-license'); },
- isNotSupportedAllowed: true
- },
- // Try additional parameter, which should be ignored.
- {
- func: function(mk) { return mk.createSession('temporary', 'extra'); },
- isNotSupportedAllowed: false
- }
- ];
-
- // This function checks that calling |testCase.func| creates a
- // MediaKeySession object with some default values. It also
- // allows for an NotSupportedError to be generated and treated as a
- // success, if allowed. See comment above kCreateSessionTestCases.
- function test_createSession(testCase, mediaKeys)
- {
- var mediaKeySession;
- try {
- mediaKeySession = testCase.func.call(null, mediaKeys);
- } catch (e) {
- assert_true(testCase.isNotSupportedAllowed);
- return;
- }
-
- assert_equals(typeof mediaKeySession, 'object');
- assert_equals(typeof mediaKeySession.addEventListener, 'function');
- assert_equals(typeof mediaKeySession.sessionId, 'string');
- assert_equals(typeof mediaKeySession.expiration, 'number');
- assert_equals(typeof mediaKeySession.closed, 'object');
- assert_equals(typeof mediaKeySession.keyStatuses, 'object');
- assert_equals(typeof mediaKeySession.onkeystatuseschange, 'object');
- assert_equals(typeof mediaKeySession.onmessage, 'object');
- assert_equals(typeof mediaKeySession.generateRequest, 'function');
- assert_equals(typeof mediaKeySession.load, 'function');
- assert_equals(typeof mediaKeySession.update, 'function');
- assert_equals(typeof mediaKeySession.close, 'function');
- assert_equals(typeof mediaKeySession.remove, 'function');
- assert_equals(mediaKeySession.sessionId, '');
- assert_equals(typeof mediaKeySession.onopen, 'undefined');
- assert_equals(typeof mediaKeySession.onclose, 'undefined');
- assert_equals(typeof mediaKeySession.onerror, 'undefined');
- }
-
- async_test(function(test)
- {
- navigator.requestMediaKeySystemAccess('org.w3.clearkey', [{}]).then(function(access) {
- return access.createMediaKeys();
- }).then(function(mediaKeys) {
- kCreateSessionTestCases.map(function(testCase) {
- test_createSession(testCase, mediaKeys);
- });
- test.done();
- }).catch(function(error) {
- forceTestFailureFromPromise(test, error, 'createSession() tests failed');
- });
- }, 'Test MediaKeys createSession().');
-
- // This function checks that calling generateRequest() works for
- // various sessions. |testCase.func| creates a MediaKeySession
- // object, and then generateRequest() is called on that object. It
- // allows for an NotSupportedError to be generated and treated as a
- // success, if allowed. See comment above kCreateSessionTestCases.
- function test_generateRequest(testCase, mediaKeys, type, initData)
- {
- try {
- var mediaKeySession = testCase.func.call(null, mediaKeys);
- return mediaKeySession.generateRequest(type, initData);
- } catch (e) {
- assert_true(testCase.isNotSupportedAllowed);
- }
- }
-
- async_test(function(test)
- {
- var isWebmSupported;
- var isCencSupported;
-
- isInitDataTypeSupported('webm').then(function(result) {
- isWebmSupported = result;
- return isInitDataTypeSupported('cenc');
- }).then(function(result) {
- isCencSupported = result;
- return navigator.requestMediaKeySystemAccess('org.w3.clearkey', [{}]);
- }).then(function(access) {
- return access.createMediaKeys();
- }).then(function(mediaKeys) {
- var sessionPromises = [];
-
- // Test that WebM sessions generate the expected error, if
- // supported.
- if (isWebmSupported) {
- var WebmSessionPromises = kCreateSessionTestCases.map(function(testCase) {
- return test_generateRequest(testCase, mediaKeys, 'webm', getInitData('webm'));
- });
- sessionPromises = sessionPromises.concat(WebmSessionPromises);
- }
-
- // Repeat for MP4, if supported.
- if (isCencSupported) {
- var mp4SessionPromises = kCreateSessionTestCases.map(function(testCase) {
- return test_generateRequest(testCase, mediaKeys, 'cenc', getInitData('cenc'));
- });
- sessionPromises = sessionPromises.concat(mp4SessionPromises);
- }
-
- assert_not_equals(sessionPromises.length, 0);
- return Promise.all(sessionPromises);
- }).then(function(result) {
- test.done();
- }).catch(function(error) {
- forceTestFailureFromPromise(test, error, 'generateRequest() tests failed');
- });
- }, 'Test MediaKeys generateRequest().');
-
- var kUpdateSessionExceptionsTestCases = [
- // Tests in this set use a shortened parameter name due to
- // format_value() only returning the first 60 characters as the
- // result. With a longer name (mediaKeySession) the first 60
- // characters is not enough to determine which test failed.
-
- // Too few parameters.
- {
- exception: 'TypeError',
- func: function(s) { return s.update(); }
- },
- // Invalid parameters.
- {
- exception: 'TypeError',
- func: function(s) { return s.update(''); }
- },
- {
- exception: 'TypeError',
- func: function(s) { return s.update(null); }
- },
- {
- exception: 'TypeError',
- func: function(s) { return s.update(undefined); }
- },
- {
- exception: 'TypeError',
- func: function(s) { return s.update(1); }
- },
- {
- exception: 'InvalidAccessError',
- func: function(s) { return s.update(new Uint8Array(0)); }
- }
- ];
-
- async_test(function(test)
- {
- var isWebmSupported;
- var isCencSupported;
-
- isInitDataTypeSupported('webm').then(function(result) {
- isWebmSupported = result;
- return isInitDataTypeSupported('cenc');
- }).then(function(result) {
- isCencSupported = result;
- return navigator.requestMediaKeySystemAccess('org.w3.clearkey', [{}]);
- }).then(function(access) {
- return access.createMediaKeys();
- }).then(function(mediaKeys) {
- var promises = [];
-
- if (isWebmSupported) {
- var WebmSessionPromises = kUpdateSessionExceptionsTestCases.map(function(testCase) {
- var mediaKeySession = mediaKeys.createSession();
- return mediaKeySession.generateRequest('webm', getInitData('webm')).then(function(result) {
- return test_exception(testCase, mediaKeySession);
- });
- });
- promises = promises.concat(WebmSessionPromises);
- }
-
- if (isCencSupported) {
- var mp4SessionPromises = kUpdateSessionExceptionsTestCases.map(function(testCase) {
- var mediaKeySession = mediaKeys.createSession();
- return mediaKeySession.generateRequest('cenc', getInitData('cenc')).then(function(result) {
- return test_exception(testCase, mediaKeySession);
- });
- });
- promises = promises.concat(mp4SessionPromises);
- }
-
- assert_not_equals(promises.length, 0);
- return Promise.all(promises);
- }).then(function(result) {
- test.done();
- }).catch(function(error) {
- forceTestFailureFromPromise(test, error, 'update() tests failed');
- });
- }, 'Test MediaKeySession update() exceptions.');
-
- function create_update_test(mediaKeys, type, initData)
- {
- var mediaKeySession = mediaKeys.createSession();
- var promise = mediaKeySession.generateRequest(type, initData).then(function(result) {
- var validLicense = stringToUint8Array(createJWKSet(createJWK(stringToUint8Array('123'), stringToUint8Array('1234567890abcdef'))));
- return mediaKeySession.update(validLicense);
- }).then(function(result) {
- // Call update() with a different license and an extra
- // parameter. The extra parameter is ignored.
- var validLicense = stringToUint8Array(createJWKSet(createJWK(stringToUint8Array('4567890'), stringToUint8Array('01234567890abcde'))));
- return mediaKeySession.update(validLicense, 'extra');
- });
- return promise;
- }
-
- async_test(function(test)
- {
- var isWebmSupported;
- var isCencSupported;
-
- isInitDataTypeSupported('webm').then(function(result) {
- isWebmSupported = result;
- return isInitDataTypeSupported('cenc');
- }).then(function(result) {
- isCencSupported = result;
- return navigator.requestMediaKeySystemAccess('org.w3.clearkey', [{}]);
- }).then(function(access) {
- return access.createMediaKeys();
- }).then(function(mediaKeys) {
- var promises = [];
-
- if (isWebmSupported) {
- promises.push(create_update_test(mediaKeys, 'webm', getInitData('webm')));
- }
-
- if (isCencSupported) {
- promises.push(create_update_test(mediaKeys, 'cenc', getInitData('cenc')));
- }
-
- assert_not_equals(promises.length, 0);
- return Promise.all(promises);
- }).then(function(result) {
- test.done();
- }).catch(function(error) {
- forceTestFailureFromPromise(test, error, 'update() tests failed');
- });
- }, 'Test MediaKeySession update().');
-
- function create_close_exception_test(mediaKeys, type, initData)
- {
- var mediaKeySession = mediaKeys.createSession();
- return mediaKeySession.close().then(function(result) {
- assert_unreached('close() should not succeed if session uninitialized');
- }).catch(function(error) {
- assert_equals(error.name, 'InvalidStateError');
- // Return something so the promise resolves.
- return Promise.resolve();
- });
- }
-
- async_test(function(test)
- {
- var isWebmSupported;
- var isCencSupported;
-
- isInitDataTypeSupported('webm').then(function(result) {
- isWebmSupported = result;
- return isInitDataTypeSupported('cenc');
- }).then(function(result) {
- isCencSupported = result;
- return navigator.requestMediaKeySystemAccess('org.w3.clearkey', [{}]);
- }).then(function(access) {
- return access.createMediaKeys();
- }).then(function(mediaKeys) {
- var promises = [];
-
- if (isWebmSupported) {
- promises.push(create_close_exception_test(mediaKeys, 'webm', getInitData('webm')));
- }
-
- if (isCencSupported) {
- promises.push(create_close_exception_test(mediaKeys, 'cenc', getInitData('cenc')));
- }
-
- assert_not_equals(promises.length, 0);
- return Promise.all(promises);
- }).then(function(result) {
- test.done();
- }).catch(function(error) {
- forceTestFailureFromPromise(test, error, 'close() exception tests failed');
- });
- }, 'Test MediaKeySession close() exceptions.');
-
-
- function create_close_test(mediaKeys, type, initData)
- {
- var mediaKeySession = mediaKeys.createSession();
- var promise = mediaKeySession.generateRequest(type, initData).then(function(result) {
- return mediaKeySession.close();
- }).then(function(result) {
- // Call close() again with an extra parameter. The extra
- // parameter is ignored.
- return mediaKeySession.close('extra');
- });
- return promise;
- }
-
- async_test(function(test)
- {
- var isWebmSupported;
- var isCencSupported;
-
- isInitDataTypeSupported('webm').then(function(result) {
- isWebmSupported = result;
- return isInitDataTypeSupported('cenc');
- }).then(function(result) {
- isCencSupported = result;
- return navigator.requestMediaKeySystemAccess('org.w3.clearkey', [{}]);
- }).then(function(access) {
- return access.createMediaKeys();
- }).then(function(mediaKeys) {
- var promises = [];
-
- if (isWebmSupported) {
- promises.push(create_close_test(mediaKeys, 'webm', getInitData('webm')));
- }
-
- if (isCencSupported) {
- promises.push(create_close_test(mediaKeys, 'cenc', getInitData('cenc')));
- }
-
- assert_not_equals(promises.length, 0);
- return Promise.all(promises);
- }).then(function(result) {
- test.done();
- }).catch(function(error) {
- forceTestFailureFromPromise(test, error, 'close() tests failed');
- });
- }, 'Test MediaKeySession close().');
-
- function create_remove_exception_test(mediaKeys, type, initData)
- {
- // remove() on an uninitialized session should fail.
- var mediaKeySession = mediaKeys.createSession('temporary');
- return mediaKeySession.remove().then(function(result) {
- assert_unreached('remove() should not succeed if session uninitialized');
- }, function(error) {
- assert_equals(error.name, 'InvalidStateError');
-
- // remove() on a temporary session should fail.
- return mediaKeySession.generateRequest(type, initData);
- }).then(function(result) {
- return mediaKeySession.remove();
- }).then(function(result) {
- assert_unreached('remove() should not succeed for temporary sessions');
- }, function(error) {
- assert_equals(error.name, 'InvalidAccessError');
- });
- }
-
- async_test(function(test)
- {
- var isWebmSupported;
- var isCencSupported;
-
- isInitDataTypeSupported('webm').then(function(result) {
- isWebmSupported = result;
- return isInitDataTypeSupported('cenc');
- }).then(function(result) {
- isCencSupported = result;
- return navigator.requestMediaKeySystemAccess('org.w3.clearkey', [{}]);
- }).then(function(access) {
- return access.createMediaKeys();
- }).then(function(mediaKeys) {
- var promises = [];
-
- if (isWebmSupported) {
- promises.push(create_remove_exception_test(mediaKeys, 'webm', getInitData('webm')));
- }
-
- if (isCencSupported) {
- promises.push(create_remove_exception_test(mediaKeys, 'cenc', getInitData('cenc')));
- }
-
- assert_not_equals(promises.length, 0);
- return Promise.all(promises);
- }).then(function(result) {
- test.done();
- }).catch(function(error) {
- forceTestFailureFromPromise(test, error, 'remove() exception tests failed');
- });
- }, 'Test MediaKeySession remove() exceptions.');
-
- function create_remove_test(mediaKeys, type, initData)
- {
- // Clear Key may not support persistent-license sessions.
- var mediaKeySession;
- try {
- mediaKeySession = mediaKeys.createSession('persistent-license');
- } catch (error) {
- // Not supported, so return a resolved promise.
- assert_equals(error.name, 'NotSupportedError');
- return Promise.resolve();
- }
- return mediaKeySession.generateRequest(type, initData).then(function(result) {
- return mediaKeySession.remove();
- });
- }
-
- async_test(function(test)
- {
- var isWebmSupported;
- var isCencSupported;
-
- isInitDataTypeSupported('webm').then(function(result) {
- isWebmSupported = result;
- return isInitDataTypeSupported('cenc');
- }).then(function(result) {
- isCencSupported = result;
- return navigator.requestMediaKeySystemAccess('org.w3.clearkey', [{}]);
- }).then(function(access) {
- return access.createMediaKeys();
- }).then(function(mediaKeys) {
- var promises = [];
-
- if (isWebmSupported) {
- promises.push(create_remove_test(mediaKeys, 'webm', getInitData('webm')));
- }
-
- if (isCencSupported) {
- promises.push(create_remove_test(mediaKeys, 'cenc', getInitData('cenc')));
- }
-
- assert_not_equals(promises.length, 0);
- return Promise.all(promises);
- }).then(function(result) {
- test.done();
- }).catch(function(error) {
- forceTestFailureFromPromise(test, error, 'remove() tests failed');
- });
- }, 'Test MediaKeySession remove().');
-
- var kSetServerCertificateExceptionsTestCases = [
- // Too few parameters.
- {
- exception: 'TypeError',
- func: function(mk) { return mk.setServerCertificate(); }
- },
- // Invalid parameters.
- {
- exception: 'TypeError',
- func: function(mk) { return mk.setServerCertificate(''); }
- },
- {
- exception: 'TypeError',
- func: function(mk) { return mk.setServerCertificate(null); }
- },
- {
- exception: 'TypeError',
- func: function(mk) { return mk.setServerCertificate(undefined); }
- },
- {
- exception: 'TypeError',
- func: function(mk) { return mk.setServerCertificate(1); }
- },
- // Empty array.
- {
- exception: 'InvalidAccessError',
- func: function(mk) { return mk.setServerCertificate(new Uint8Array(0)); }
- }
- ];
-
- async_test(function(test)
- {
- navigator.requestMediaKeySystemAccess('org.w3.clearkey', [{}]).then(function(access) {
- return access.createMediaKeys();
- }).then(function(mediaKeys) {
- var promises = kSetServerCertificateExceptionsTestCases.map(function(testCase) {
- return test_exception(testCase, mediaKeys);
- });
-
- assert_not_equals(promises.length, 0);
- return Promise.all(promises);
- }).then(function(result) {
- test.done();
- }).catch(function(error) {
- forceTestFailureFromPromise(test, error, 'setServerCertificate() exception tests failed');
- });
- }, 'Test MediaKeys setServerCertificate() exceptions.');
-
- // All calls to |func| in this group are expected to resolve.
- var kSetServerCertificateTestCases = [
- {
- // Pass in ArrayBufferView
- func: function(mk) {
- var cert = new Uint8Array(200);
- assert_true(ArrayBuffer.isView(cert));
- return mk.setServerCertificate(cert);
- },
- expected: false,
- },
- {
- // Pass in ArrayBuffer
- func: function(mk) {
- var buffer = new ArrayBuffer(200);
- assert_false(ArrayBuffer.isView(buffer));
- return mk.setServerCertificate(buffer);
- },
- expected: false,
- }
- ];
-
- async_test(function(test)
- {
- var expected_result;
- navigator.requestMediaKeySystemAccess('org.w3.clearkey', [{}]).then(function(access) {
- return access.createMediaKeys();
- }).then(function(mediaKeys) {
- var promises = kSetServerCertificateTestCases.map(function(testCase) {
- return testCase.func.call(null, mediaKeys);
- });
- expected_result = kSetServerCertificateTestCases.map(function(testCase) {
- return testCase.expected;
- });
-
- assert_not_equals(promises.length, 0);
- return Promise.all(promises);
- }).then(function(result) {
- assert_array_equals(result, expected_result);
- test.done();
- }).catch(function(error) {
- forceTestFailureFromPromise(test, error, 'setServerCertificate() test failed');
- });
- }, 'Test MediaKeys setServerCertificate().');
-
-
- // FIXME: Add syntax checks for MediaKeys.IsTypeSupported().
- // FIXME: Add syntax checks for MediaKeyError and MediaKeySession events.
- // FIXME: Add HTMLMediaElement syntax checks, e.g. setMediaKeys, mediakeys, onencrypted.
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-unique-origin.html b/testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-unique-origin.html
deleted file mode 100644
index ffb67679f..000000000
--- a/testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-unique-origin.html
+++ /dev/null
@@ -1,79 +0,0 @@
-<!DOCTYPE html>
-<!-- Copyright © 2016 Chromium authors and World Wide Web Consortium, (Massachusetts Institute of Technology, ERCIM, Keio University, Beihang). -->
-<html>
- <head>
- <title>Unique origin is unable to create MediaKeys</title>
-<!--
- Test has been migrated to the root directory and is being disabled here.
- <script src="/resources/testharness.js"></script>
- <script src="/resources/testharnessreport.js"></script>
--->
- </head>
- <body>
- <div id="log"></div>
- <script>
- // When the sandbox attribute is present on an iframe, it will
- // treat the content as being from a unique origin. So try to
- // call createMediaKeys() inside an iframe and it should fail.
-
- function load_iframe(src, sandbox) {
- return new Promise(function(resolve) {
- var iframe = document.createElement('iframe');
- iframe.onload = function() { resolve(iframe); };
- iframe.sandbox = sandbox;
- iframe.src = src;
- document.documentElement.appendChild(iframe);
- });
- }
-
- function wait_for_message() {
- return new Promise(function(resolve) {
- self.addEventListener('message', function listener(e) {
- resolve(e.data);
- self.removeEventListener('message', listener);
- });
- });
- }
-
- promise_test(function(test) {
- var script = 'data:text/html,' +
- '<script>' +
- ' window.onmessage = function(e) {' +
- ' navigator.requestMediaKeySystemAccess(\'org.w3.clearkey\', [{' +
- ' initDataTypes: [ \'keyids\' ],' +
- ' audioCapabilities: [' +
- ' { contentType: \'audio/mp4; codecs="mp4a.40.2"\' },' +
- ' { contentType: \'audio/webm; codecs="opus"\' }' +
- ' ]' +
- ' }]).then(function(access) {' +
- ' return access.createMediaKeys();' +
- ' }).then(function(mediaKeys) {' +
- ' window.parent.postMessage({result: \'allowed\'}, \'*\');' +
- ' }, function(error) {' +
- ' window.parent.postMessage({result: \'failed\'}, \'*\');' +
- ' });' +
- ' };' +
- '<\/script>';
-
- // Verify that this page can create a MediaKeys first.
- navigator.requestMediaKeySystemAccess('org.w3.clearkey', [{
- initDataTypes: [ 'keyids' ],
- audioCapabilities: [
- { contentType: 'audio/mp4; codecs="mp4a.40.2"' },
- { contentType: 'audio/webm; codecs="opus"' }
- ]
- }]).then(function(access) {
- return access.createMediaKeys();
- }).then(function(mediaKeys) {
- // Success, so now create the iframe and try there.
- return load_iframe(script, 'allow-scripts')
- }).then(function(iframe) {
- iframe.contentWindow.postMessage({}, '*');
- return wait_for_message();
- }).then(function(message) {
- assert_equals(message.result, 'failed');
- });
- }, 'Unique origin is unable to create MediaKeys');
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-update-disallowed-input.html b/testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-update-disallowed-input.html
deleted file mode 100644
index e829a885c..000000000
--- a/testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-update-disallowed-input.html
+++ /dev/null
@@ -1,73 +0,0 @@
-<!DOCTYPE html>
-<!-- Copyright © 2016 Chromium authors and World Wide Web Consortium, (Massachusetts Institute of Technology, ERCIM, Keio University, Beihang). -->
-<html>
- <head>
- <title>Test handling of invalid responses for update().</title>
- <script src="encrypted-media-utils.js"></script>
-<!--
- Test has been migrated to the root directory and is being disabled here.
- <script src="/resources/testharness.js"></script>
- <script src="/resources/testharnessreport.js"></script>
--->
- </head>
- <body>
- <div id="log"></div>
- <script>
- // This test passes |response| to update() as a JSON Web Key Set.
- // CDMs other than Clear Key won't expect |response| in this format.
-
- async_test(function(test)
- {
- var initDataType;
- var initData;
- var mediaKeySession;
-
- function repeat(pattern, count) {
- var result = '';
- while (count > 1) {
- if (count & 1) result += pattern;
- count >>= 1;
- pattern += pattern;
- }
- return result + pattern;
- }
-
- function createReallyLongJWKSet()
- {
- // This is just a standard JWKSet with a lot of
- // extra items added to the end. Key ID and key
- // doesn't really matter.
- var jwkSet = '{"keys":[{'
- + '"kty":"oct",'
- + '"k":"MDEyMzQ1Njc4OTAxMjM0NQ",'
- + '"kid":"MDEyMzQ1Njc4OTAxMjM0NQ"'
- + '}]';
- return jwkSet + repeat(',"test":"unknown"', 4000) + '}';
- }
-
- function processMessage(event)
- {
- var jwkSet = createReallyLongJWKSet();
- assert_greater_than(jwkSet.length, 65536);
- var jwkSetArray = stringToUint8Array(jwkSet);
- mediaKeySession.update(jwkSetArray).then(function() {
- forceTestFailureFromPromise(test, 'Error: update() succeeded');
- }, function(error) {
- assert_equals(error.name, 'InvalidAccessError');
- test.done();
- });
- }
-
- navigator.requestMediaKeySystemAccess('org.w3.clearkey', getSimpleConfiguration()).then(function(access) {
- initDataType = access.getConfiguration().initDataTypes[0];
- initData = getInitData(initDataType);
- return access.createMediaKeys();
- }).then(function(mediaKeys) {
- mediaKeySession = mediaKeys.createSession();
- waitForEventAndRunStep('message', mediaKeySession, processMessage, test);
- return mediaKeySession.generateRequest(initDataType, initData);
- });
- }, 'update() with response longer than 64Kb characters.');
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-utils.js b/testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-utils.js
deleted file mode 100644
index 5fbcdf689..000000000
--- a/testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-utils.js
+++ /dev/null
@@ -1,333 +0,0 @@
-<!-- Copyright © 2016 Chromium authors and World Wide Web Consortium, (Massachusetts Institute of Technology, ERCIM, Keio University, Beihang). -->
-
-var consoleDiv = null;
-
-function consoleWrite(text)
-{
- if (!consoleDiv && document.body) {
- consoleDiv = document.createElement('div');
- document.body.appendChild(consoleDiv);
- }
- var span = document.createElement('span');
- span.appendChild(document.createTextNode(text));
- span.appendChild(document.createElement('br'));
- consoleDiv.appendChild(span);
-}
-
-// Returns a promise that is fulfilled with true if |initDataType| is supported,
-// or false if not.
-function isInitDataTypeSupported(initDataType)
-{
- return navigator.requestMediaKeySystemAccess(
- "org.w3.clearkey", getSimpleConfigurationForInitDataType(initDataType))
- .then(function() { return true; }, function() { return false; });
-}
-
-function getInitData(initDataType)
-{
- if (initDataType == 'webm') {
- return new Uint8Array([
- 0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07,
- 0x08, 0x09, 0x0A, 0x0B, 0x0C, 0x0D, 0x0E, 0x0F
- ]);
- }
-
- if (initDataType == 'cenc') {
- return new Uint8Array([
- 0x00, 0x00, 0x00, 0x34, // size = 52
- 0x70, 0x73, 0x73, 0x68, // 'pssh'
- 0x01, // version = 1
- 0x00, 0x00, 0x00, // flags
- 0x10, 0x77, 0xEF, 0xEC, 0xC0, 0xB2, 0x4D, 0x02, // Common SystemID
- 0xAC, 0xE3, 0x3C, 0x1E, 0x52, 0xE2, 0xFB, 0x4B,
- 0x00, 0x00, 0x00, 0x01, // key count
- 0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, // key
- 0x08, 0x09, 0x0A, 0x0B, 0x0C, 0x0D, 0x0E, 0x0F,
- 0x00, 0x00, 0x00, 0x00 // datasize
- ]);
- }
-
- if (initDataType == 'keyids') {
- var keyId = new Uint8Array([
- 0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07,
- 0x08, 0x09, 0x0A, 0x0B, 0x0C, 0x0D, 0x0E, 0x0F
- ]);
- return stringToUint8Array(createKeyIDs(keyId));
- }
-
- throw 'initDataType ' + initDataType + ' not supported.';
-}
-
-// Returns an array of audioCapabilities that includes entries for a set of
-// codecs that should cover all user agents.
-function getPossibleAudioCapabilities()
-{
- return [
- { contentType: 'audio/mp4; codecs="mp4a.40.2"' },
- { contentType: 'audio/webm; codecs="opus"' },
- ];
-}
-
-// Returns a trivial MediaKeySystemConfiguration that should be accepted,
-// possibly as a subset of the specified capabilities, by all user agents.
-function getSimpleConfiguration()
-{
- return [ {
- initDataTypes : [ 'webm', 'cenc', 'keyids' ],
- audioCapabilities: getPossibleAudioCapabilities()
- } ];
-}
-
-// Returns a MediaKeySystemConfiguration for |initDataType| that should be
-// accepted, possibly as a subset of the specified capabilities, by all
-// user agents.
-function getSimpleConfigurationForInitDataType(initDataType)
-{
- return [ {
- initDataTypes: [ initDataType ],
- audioCapabilities: getPossibleAudioCapabilities()
- } ];
-}
-
-// Returns a MediaKeySystemConfiguration for |mediaFile| that specifies
-// both audio and video capabilities for the specified file..
-function getConfigurationForFile(mediaFile)
-{
- if (mediaFile.toLowerCase().endsWith('webm')) {
- return [ {
- initDataTypes: [ 'webm' ],
- audioCapabilities: [ { contentType: 'audio/webm; codecs="opus"' } ],
- videoCapabilities: [ { contentType: 'video/webm; codecs="vp8"' } ]
- } ];
- }
-
- // NOTE: Supporting other mediaFormats is not currently implemented as
- // Chromium only tests with WebM files.
- throw 'mediaFile ' + mediaFile + ' not supported.';
-}
-
-function waitForEventAndRunStep(eventName, element, func, stepTest)
-{
- var eventCallback = function(event) {
- if (func)
- func(event);
- }
- if (stepTest)
- eventCallback = stepTest.step_func(eventCallback);
-
- element.addEventListener(eventName, eventCallback, true);
-}
-
-// Copied from LayoutTests/resources/js-test.js.
-// See it for details of why this is necessary.
-function asyncGC(callback)
-{
- GCController.collectAll();
- setTimeout(callback, 0);
-}
-
-function createGCPromise()
-{
- // Run gc() as a promise.
- return new Promise(
- function(resolve, reject) {
- asyncGC(resolve);
- });
-}
-
-function delayToAllowEventProcessingPromise()
-{
- return new Promise(
- function(resolve, reject) {
- setTimeout(resolve, 0);
- });
-}
-
-function stringToUint8Array(str)
-{
- var result = new Uint8Array(str.length);
- for(var i = 0; i < str.length; i++) {
- result[i] = str.charCodeAt(i);
- }
- return result;
-}
-
-function arrayBufferAsString(buffer)
-{
- // MediaKeySession.keyStatuses iterators return an ArrayBuffer,
- // so convert it into a printable string.
- return String.fromCharCode.apply(null, new Uint8Array(buffer));
-}
-
-function dumpKeyStatuses(keyStatuses)
-{
- consoleWrite("for (var entry of keyStatuses)");
- for (var entry of keyStatuses) {
- consoleWrite(arrayBufferAsString(entry[0]) + ": " + entry[1]);
- }
- consoleWrite("for (var keyId of keyStatuses.keys())");
- for (var keyId of keyStatuses.keys()) {
- consoleWrite(arrayBufferAsString(keyId));
- }
- consoleWrite("for (var status of keyStatuses.values())");
- for (var status of keyStatuses.values()) {
- consoleWrite(status);
- }
- consoleWrite("for (var entry of keyStatuses.entries())");
- for (var entry of keyStatuses.entries()) {
- consoleWrite(arrayBufferAsString(entry[0]) + ": " + entry[1]);
- }
- consoleWrite("keyStatuses.forEach()");
- keyStatuses.forEach(function(status, keyId) {
- consoleWrite(arrayBufferAsString(keyId) + ": " + status);
- });
-}
-
-// Verify that |keyStatuses| contains just the keys in |keys.expected|
-// and none of the keys in |keys.unexpected|. All keys should have status
-// 'usable'. Example call: verifyKeyStatuses(mediaKeySession.keyStatuses,
-// { expected: [key1], unexpected: [key2] });
-function verifyKeyStatuses(keyStatuses, keys)
-{
- var expected = keys.expected || [];
- var unexpected = keys.unexpected || [];
-
- // |keyStatuses| should have same size as number of |keys.expected|.
- assert_equals(keyStatuses.size, expected.length);
-
- // All |keys.expected| should be found.
- expected.map(function(key) {
- assert_true(keyStatuses.has(key));
- assert_equals(keyStatuses.get(key), 'usable');
- });
-
- // All |keys.unexpected| should not be found.
- unexpected.map(function(key) {
- assert_false(keyStatuses.has(key));
- assert_equals(keyStatuses.get(key), undefined);
- });
-}
-
-// Encodes |data| into base64url string. There is no '=' padding, and the
-// characters '-' and '_' must be used instead of '+' and '/', respectively.
-function base64urlEncode(data)
-{
- var result = btoa(String.fromCharCode.apply(null, data));
- return result.replace(/=+$/g, '').replace(/\+/g, "-").replace(/\//g, "_");
-}
-
-// Decode |encoded| using base64url decoding.
-function base64urlDecode(encoded)
-{
- return atob(encoded.replace(/\-/g, "+").replace(/\_/g, "/"));
-}
-
-// For Clear Key, the License Format is a JSON Web Key (JWK) Set, which contains
-// a set of cryptographic keys represented by JSON. These helper functions help
-// wrap raw keys into a JWK set.
-// See:
-// https://w3c.github.io/encrypted-media/#clear-key-license-format
-// http://tools.ietf.org/html/draft-ietf-jose-json-web-key
-//
-// Creates a JWK from raw key ID and key.
-// |keyId| and |key| are expected to be ArrayBufferViews, not base64-encoded.
-function createJWK(keyId, key)
-{
- var jwk = '{"kty":"oct","alg":"A128KW","kid":"';
- jwk += base64urlEncode(keyId);
- jwk += '","k":"';
- jwk += base64urlEncode(key);
- jwk += '"}';
- return jwk;
-}
-
-// Creates a JWK Set from multiple JWKs.
-function createJWKSet()
-{
- var jwkSet = '{"keys":[';
- for (var i = 0; i < arguments.length; i++) {
- if (i != 0)
- jwkSet += ',';
- jwkSet += arguments[i];
- }
- jwkSet += ']}';
- return jwkSet;
-}
-
-// Clear Key can also support Key IDs Initialization Data.
-// ref: http://w3c.github.io/encrypted-media/keyids-format.html
-// Each parameter is expected to be a key id in an Uint8Array.
-function createKeyIDs()
-{
- var keyIds = '{"kids":["';
- for (var i = 0; i < arguments.length; i++) {
- if (i != 0)
- keyIds += '","';
- keyIds += base64urlEncode(arguments[i]);
- }
- keyIds += '"]}';
- return keyIds;
-}
-
-function forceTestFailureFromPromise(test, error, message)
-{
- // Promises convert exceptions into rejected Promises. Since there is
- // currently no way to report a failed test in the test harness, errors
- // are reported using force_timeout().
- if (message)
- consoleWrite(message + ': ' + error.message);
- else if (error)
- consoleWrite(error);
-
- test.force_timeout();
- test.done();
-}
-
-function extractSingleKeyIdFromMessage(message)
-{
- var json = JSON.parse(String.fromCharCode.apply(null, new Uint8Array(message)));
- // Decode the first element of 'kids'.
- assert_equals(1, json.kids.length);
- var decoded_key = base64urlDecode(json.kids[0]);
- // Convert to an Uint8Array and return it.
- return stringToUint8Array(decoded_key);
-}
-
-// Create a MediaKeys object for Clear Key with 1 session. KeyId and key
-// required for the video are already known and provided. Returns a promise
-// that resolves to the MediaKeys object created.
-function createMediaKeys(keyId, key)
-{
- var mediaKeys;
- var mediaKeySession;
- var request = stringToUint8Array(createKeyIDs(keyId));
- var jwkSet = stringToUint8Array(createJWKSet(createJWK(keyId, key)));
-
- return navigator.requestMediaKeySystemAccess('org.w3.clearkey', getSimpleConfigurationForInitDataType('keyids')).then(function(access) {
- return access.createMediaKeys();
- }).then(function(result) {
- mediaKeys = result;
- mediaKeySession = mediaKeys.createSession();
- return mediaKeySession.generateRequest('keyids', request);
- }).then(function() {
- return mediaKeySession.update(jwkSet);
- }).then(function() {
- return Promise.resolve(mediaKeys);
- });
-}
-
-// Play the specified |content| on |video|. Returns a promise that is resolved
-// after the video plays for |duration| seconds.
-function playVideoAndWaitForTimeupdate(video, content, duration)
-{
- video.src = content;
- video.play();
- return new Promise(function(resolve) {
- video.addEventListener('timeupdate', function listener(event) {
- if (event.target.currentTime < duration)
- return;
- video.removeEventListener('timeupdate', listener);
- resolve('success');
- });
- });
-}
diff --git a/testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-waiting-for-a-key.html b/testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-waiting-for-a-key.html
deleted file mode 100644
index 2af37cfb9..000000000
--- a/testing/web-platform/tests/encrypted-media/Google/migrated_to_root_disabled/encrypted-media-waiting-for-a-key.html
+++ /dev/null
@@ -1,168 +0,0 @@
-<!DOCTYPE html>
-<!-- Copyright © 2016 Chromium authors and World Wide Web Consortium, (Massachusetts Institute of Technology, ERCIM, Keio University, Beihang). -->
-<html>
- <head>
- <title>Waiting for a key.</title>
- <script src="encrypted-media-utils.js"></script>
-<!--
- Test has been migrated to the root directory and is being disabled here.
- <script src="/resources/testharness.js"></script>
- <script src="/resources/testharnessreport.js"></script>
--->
- </head>
- <body>
- <video id="testVideo"></video>
- <div id="log"></div>
- <script>
- // For debugging timeouts, keep track of the number of the
- // various events received.
- var debugEncryptedEventCount = 0;
- var debugWaitingForKeyEventCount = 0;
- var debugTimeUpdateEventCount = 0;
- var debugMessage = '';
-
- promise_test(function(test)
- {
- var video = document.getElementById('testVideo');
- var content = 'webm/test-encrypted.webm';
- var initData;
- var initDataType;
- var mediaKeySession;
-
- test.timeout = function()
- {
- var message = 'timeout. message = ' + debugMessage
- + ', encrypted: ' + debugEncryptedEventCount
- + ', waitingforkey: ' + debugWaitingForKeyEventCount
- + ', timeupdate: ' + debugTimeUpdateEventCount;
- test.force_timeout();
- test.timeout_id = null;
- test.set_status(2, message);
- test.done();
- };
-
- // As this code doesn't wait for the 'message' event to avoid
- // race conditions with 'waitingforkey', specify the key ID and
- // key used by the encrypted content.
- var keyId = stringToUint8Array('0123456789012345');
- var rawKey = new Uint8Array([0xeb, 0xdd, 0x62, 0xf1, 0x68, 0x14, 0xd2, 0x7b,
- 0x68, 0xef, 0x12, 0x2a, 0xfc, 0xe4, 0xae, 0x3c]);
-
- return navigator.requestMediaKeySystemAccess('org.w3.clearkey', getConfigurationForFile(content)).then(function(access) {
- debugMessage = 'createMediaKeys()';
- return access.createMediaKeys();
- }).then(function(mediaKeys) {
- debugMessage = 'setMediaKeys()';
- return video.setMediaKeys(mediaKeys);
- }).then(function() {
- video.src = content;
- video.play();
- debugMessage = 'wait_for_encrypted_event()';
- return wait_for_encrypted_event(video);
- }).then(function(e) {
- // Received the 'encrypted' event(s), so keep a copy of
- // the initdata for use when creating the session later.
- initData = e.initData;
- initDataType = e.initDataType;
-
- // Wait until the video indicates that it needs a key to
- // continue.
- debugMessage = 'wait_for_waitingforkey_event()';
- return wait_for_waitingforkey_event(video);
- }).then(function() {
- // Make sure the video is NOT paused and not progressing
- // before a key is provided. This requires the video
- // to NOT have a clear lead.
- assert_false(video.paused);
- assert_equals(video.currentTime, 0);
-
- // Create a session.
- mediaKeySession = video.mediaKeys.createSession();
- debugMessage = 'generateRequest()';
- return mediaKeySession.generateRequest(initDataType, initData);
- }).then(function() {
- // generateRequest() will cause a 'message' event to
- // occur specifying the keyId that is needed, but we
- // ignore it since we already know what keyId is needed.
- // Add the key needed to decrypt.
- var jwkSet = stringToUint8Array(createJWKSet(createJWK(keyId, rawKey)));
- debugMessage = 'update()';
- return mediaKeySession.update(jwkSet);
- }).then(function() {
- // Video should start playing now that it can decrypt the
- // streams, so wait until a little bit of the video has
- // played.
- debugMessage = 'wait_for_timeupdate_event()';
- return wait_for_timeupdate_event(video);
- });
-
- // Typical test duration is 6 seconds on release builds
- // (12 seconds on debug). Since the test is timing out anyway,
- // make the duration 5 seconds so that the timeout function
- // is actually called (instead of simply aborting the test).
- }, 'Waiting for a key.', { timeout: 5000 });
-
- // Wait for a pair of 'encrypted' events. Promise resolved on
- // second event.
- function wait_for_encrypted_event(video)
- {
- var encryptedEventCount = 0;
- return new Promise(function(resolve) {
- video.addEventListener('encrypted', function listener(e) {
- assert_equals(e.target, video);
- assert_true(e instanceof window.MediaEncryptedEvent);
- assert_equals(e.type, 'encrypted');
-
- // The same decryption key is used by both the audio
- // and the video streams so wait for the second event
- // to ensure we see both events.
- ++debugEncryptedEventCount;
- if (++encryptedEventCount != 2)
- return;
-
- video.removeEventListener('encrypted', listener);
- resolve(e);
- });
- });
- };
-
- // Wait for a 'waitingforkey' event. Promise resolved when the
- // event is received.
- function wait_for_waitingforkey_event(video)
- {
- var waitingForKeyEventCount = 0;
- return new Promise(function(resolve) {
- video.addEventListener('waitingforkey', function listener(e) {
- assert_equals(e.target, video);
- assert_equals(e.type, 'waitingforkey');
-
- ++debugWaitingForKeyEventCount;
- ++waitingForKeyEventCount;
- // TODO(jrummell): waitingforkey event should only
- // occur once. http://crbug.com/461903
-// assert_equals(waitingForKeyEventCount, 1, 'Multiple waitingforkey events');
-
- video.removeEventListener('waitingforkey', listener);
- resolve(e);
- });
- });
- };
-
- // Wait for a 'timeupdate' event. Promise resolved if |video| has
- // played for more than 0.2 seconds.
- function wait_for_timeupdate_event(video)
- {
- return new Promise(function(resolve) {
- video.addEventListener('timeupdate', function listener(e) {
- assert_equals(e.target, video);
- ++debugTimeUpdateEventCount;
- if (video.currentTime < 0.2)
- return;
- video.removeEventListener('timeupdate', listener);
- resolve(e);
- });
- });
- };
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/Google/webm/test-encrypted-different-av-keys.webm b/testing/web-platform/tests/encrypted-media/Google/webm/test-encrypted-different-av-keys.webm
deleted file mode 100644
index 5a29f659b..000000000
--- a/testing/web-platform/tests/encrypted-media/Google/webm/test-encrypted-different-av-keys.webm
+++ /dev/null
Binary files differ
diff --git a/testing/web-platform/tests/encrypted-media/Google/webm/test-encrypted.webm b/testing/web-platform/tests/encrypted-media/Google/webm/test-encrypted.webm
deleted file mode 100644
index 8d44931e8..000000000
--- a/testing/web-platform/tests/encrypted-media/Google/webm/test-encrypted.webm
+++ /dev/null
Binary files differ
diff --git a/testing/web-platform/tests/encrypted-media/Google/webm/test.webm b/testing/web-platform/tests/encrypted-media/Google/webm/test.webm
deleted file mode 100644
index 6c2138d4e..000000000
--- a/testing/web-platform/tests/encrypted-media/Google/webm/test.webm
+++ /dev/null
Binary files differ
diff --git a/testing/web-platform/tests/encrypted-media/OWNERS b/testing/web-platform/tests/encrypted-media/OWNERS
deleted file mode 100644
index 63b5fe290..000000000
--- a/testing/web-platform/tests/encrypted-media/OWNERS
+++ /dev/null
@@ -1 +0,0 @@
-@ddorwin
diff --git a/testing/web-platform/tests/encrypted-media/README.md b/testing/web-platform/tests/encrypted-media/README.md
deleted file mode 100644
index 932c9962d..000000000
--- a/testing/web-platform/tests/encrypted-media/README.md
+++ /dev/null
@@ -1,7 +0,0 @@
-## Preparing to run tests
-The following steps may be necessary when running test from a new server/origin for the first time.
-* Some implementations and/or tests may require consent.
- When running on such clients, manually run a test to trigger the consent request and choose to persist the consent.
-* Some of the tests, such as *-retrieve-*, use pop-ups.
- It may be necessary to run these tests manually and choose to always allow pop-ups on the origin.
- Related test failures may appear as: "Cannot set property 'onload' of undefined"
diff --git a/testing/web-platform/tests/encrypted-media/clearkey-check-initdata-type.html b/testing/web-platform/tests/encrypted-media/clearkey-check-initdata-type.html
deleted file mode 100644
index 00894338a..000000000
--- a/testing/web-platform/tests/encrypted-media/clearkey-check-initdata-type.html
+++ /dev/null
@@ -1,32 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <title>Encrypted Media Extensions: Successful Playback, Temporary session with Clear Key, mp4</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
-
- <!-- Content metadata -->
- <!--<script src=/encrypted-media/content/content-metadata.js></script>-->
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/check-initdata-type.js></script>
-
- </head>
- <body>
- <div id='log'></div>
-
- <script>
- var config = { keysystem: 'org.w3.clearkey' }
-
- runTest(config);
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/clearkey-events-session-closed-event.html b/testing/web-platform/tests/encrypted-media/clearkey-events-session-closed-event.html
deleted file mode 100644
index ddf3ecbbb..000000000
--- a/testing/web-platform/tests/encrypted-media/clearkey-events-session-closed-event.html
+++ /dev/null
@@ -1,40 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <title>Encrypted Media Extensions - Test MediaKeySession closed event with Clear Key, mp4</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
-
- <!-- Content metadata -->
- <script src=/encrypted-media/content/content-metadata.js></script>
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/events-session-closed-event.js></script>
-
- </head>
- <body>
- <div id='log'></div>
-
- <script>
- var keysystem = 'org.w3.clearkey',
- contentItem = content['mp4-basic'],
- config = {
- keysystem: keysystem,
- content: contentItem,
- initDataType: 'keyids',
- initData: getInitData(contentItem,'keyids'),
- audioType: contentItem.audio.type,
- videoType: contentItem.video.type
- };
- runTest(config);
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/clearkey-events.html b/testing/web-platform/tests/encrypted-media/clearkey-events.html
deleted file mode 100644
index 4f3b6222b..000000000
--- a/testing/web-platform/tests/encrypted-media/clearkey-events.html
+++ /dev/null
@@ -1,44 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <title>Encrypted Media Extensions: Events with Clear Key</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
-
- <!-- Content metadata -->
- <script src=/encrypted-media/content/content-metadata.js></script>
-
- <!-- Message handler for Clear Key -->
- <script src=/encrypted-media/util/clearkey-messagehandler.js></script>
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/events.js></script>
-
- </head>
- <body>
- <div id='log'></div>
-
- <script>
- getSupportedContent( 'org.w3.clearkey' )
- .then( function( contents )
- {
- var content = contents.filter(function(content) { return content.keys; })[0],
- handler = new MessageHandler( 'org.w3.clearkey', content );
-
- runTest( { keysystem: 'org.w3.clearkey',
- content: content,
- messagehandler: handler.messagehandler,
- } );
- } );
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/clearkey-generate-request-disallowed-input.html b/testing/web-platform/tests/encrypted-media/clearkey-generate-request-disallowed-input.html
deleted file mode 100644
index af6e76c2b..000000000
--- a/testing/web-platform/tests/encrypted-media/clearkey-generate-request-disallowed-input.html
+++ /dev/null
@@ -1,32 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <title>Encrypted Media Extensions: Test handling of invalid initData for generateRequest()</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/generate-request-disallowed-input.js></script>
-
- </head>
- <body>
- <div id='log'></div>
-
- <script>
- var config = { keysystem: 'org.w3.clearkey'
- };
-
- runTest(config);
-
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/clearkey-invalid-license.html b/testing/web-platform/tests/encrypted-media/clearkey-invalid-license.html
deleted file mode 100644
index 09ff934a0..000000000
--- a/testing/web-platform/tests/encrypted-media/clearkey-invalid-license.html
+++ /dev/null
@@ -1,31 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <title>Encrypted Media Extensions: Test handling of invalid Clear Key license</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/invalid-license.js></script>
-
- </head>
- <body>
- <div id='log'></div>
-
- <script>
- var config = {
- keysystem: 'org.w3.clearkey'
- };
- runTest(config);
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/clearkey-keystatuses-multiple-sessions.html b/testing/web-platform/tests/encrypted-media/clearkey-keystatuses-multiple-sessions.html
deleted file mode 100644
index 3474f9d51..000000000
--- a/testing/web-platform/tests/encrypted-media/clearkey-keystatuses-multiple-sessions.html
+++ /dev/null
@@ -1,51 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <title>Encrypted Media Extensions: Verify MediaKeySession.keyStatuses with multiple sessions, Clear Key</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
- <script src=/encrypted-media/util/testmediasource.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
-
- <!-- Content metadata -->
- <script src=/encrypted-media/content/content-metadata.js></script>
-
- <!-- Message handler for Clear Key keysystem -->
- <script src=/encrypted-media/util/clearkey-messagehandler.js></script>
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/keystatuses-multiple-sessions.js></script>
-
- </head>
- <body>
- <div id='log'></div>
-
- <script>
- getSupportedContent( 'org.w3.clearkey' )
- .then( function( contents ) {
-
- // Select a content item with multiple keys
- var contentitem = contents.filter( function( item ) { return item.keys && item.keys.length > 1; } )[ 0 ],
- handler = new MessageHandler( 'org.w3.clearkey', contentitem );
-
- var config = { keysystem: 'org.w3.clearkey',
- content: contentitem,
- messagehandler: handler.messagehandler,
- initDataType: 'keyids',
- initData: getMultikeyInitDatas(contentitem,'keyids')
- };
-
- runTest(config);
-
- } );
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/clearkey-keystatuses.html b/testing/web-platform/tests/encrypted-media/clearkey-keystatuses.html
deleted file mode 100644
index 6edec35cd..000000000
--- a/testing/web-platform/tests/encrypted-media/clearkey-keystatuses.html
+++ /dev/null
@@ -1,50 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <title>Encrypted Media Extensions: Verify MediaKeySession.keyStatuses with multiple sessions, Clear Key</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
- <script src=/encrypted-media/util/testmediasource.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
-
- <!-- Content metadata -->
- <script src=/encrypted-media/content/content-metadata.js></script>
-
- <!-- Message handler for Clear Key keysystem -->
- <script src=/encrypted-media/util/clearkey-messagehandler.js></script>
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/keystatuses.js></script>
-
- </head>
- <body>
- <div id='log'></div>
-
- <script>
- getSupportedContent( 'org.w3.clearkey' )
- .then( function( contents ) {
-
- // Select a content item with multiple keys
- var contentitem = contents.filter( function( item ) { return item.keys && item.keys.length > 1; } )[ 0 ];
- var handler = new MessageHandler( 'org.w3.clearkey', contentitem );
- var config = { keysystem: 'org.w3.clearkey',
- content: contentitem,
- messagehandler: handler.messagehandler,
- initDataType: 'keyids',
- initData: getInitData(contentitem,'keyids')
- };
-
- runTest(config);
-
- } );
- </script>
- </body>
-</html> \ No newline at end of file
diff --git a/testing/web-platform/tests/encrypted-media/clearkey-mp4-playback-destroy-persistent-license.html b/testing/web-platform/tests/encrypted-media/clearkey-mp4-playback-destroy-persistent-license.html
deleted file mode 100644
index 547f01b36..000000000
--- a/testing/web-platform/tests/encrypted-media/clearkey-mp4-playback-destroy-persistent-license.html
+++ /dev/null
@@ -1,52 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <title>Encrypted Media Extensions: persistent-license, playback, destroy license with Clear Key, mp4</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
- <script src=/encrypted-media/util/testmediasource.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
-
- <!-- Content metadata -->
- <script src=/encrypted-media/content/content-metadata.js></script>
-
- <!-- Message handler for Clear Key keysystem -->
- <script src=/encrypted-media/util/clearkey-messagehandler.js></script>
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/playback-destroy-persistent-license.js></script>
-
- </head>
- <body>
- <div id='log'></div>
-
- <div id='video'>
- <video id="videoelement" width="200px"></video>
- </div>
-
- <script>
- var contentitem = content['mp4-basic'],
- handler = new MessageHandler( 'org.w3.clearkey', contentitem ),
- config = { video: document.getElementById('videoelement'),
- keysystem: 'org.w3.clearkey',
- messagehandler: handler.messagehandler,
- audioPath: contentitem.audio.path,
- videoPath: contentitem.video.path,
- audioType: contentitem.audio.type,
- videoType: contentitem.video.type,
- initDataType: 'keyids',
- initData: getInitData(contentitem,'keyids')
- };
-
- runTest(config);
- </script>
- </body>
-</html> \ No newline at end of file
diff --git a/testing/web-platform/tests/encrypted-media/clearkey-mp4-playback-persistent-license-events.html b/testing/web-platform/tests/encrypted-media/clearkey-mp4-playback-persistent-license-events.html
deleted file mode 100644
index 99aba6386..000000000
--- a/testing/web-platform/tests/encrypted-media/clearkey-mp4-playback-persistent-license-events.html
+++ /dev/null
@@ -1,52 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <title>Encrypted Media Extensions: Successful Playback, persistent-license session with Clear Key, mp4, event sequence</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
- <script src=/encrypted-media/util/testmediasource.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
-
- <!-- Content metadata -->
- <script src=/encrypted-media/content/content-metadata.js></script>
-
- <!-- Message handler for Clear Key keysystem -->
- <script src=/encrypted-media/util/clearkey-messagehandler.js></script>
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/playback-persistent-license-events.js></script>
-
- </head>
- <body>
- <div id='log'></div>
-
- <div id='video'>
- <video id="videoelement" width="200px"></video>
- </div>
-
- <script>
- var contentitem = content['mp4-basic'],
- handler = new MessageHandler( 'org.w3.clearkey', contentitem ),
- config = { video: document.getElementById('videoelement'),
- keysystem: 'org.w3.clearkey',
- messagehandler: handler.messagehandler,
- audioPath: contentitem.audio.path,
- videoPath: contentitem.video.path,
- audioType: contentitem.audio.type,
- videoType: contentitem.video.type,
- initDataType: 'keyids',
- initData: getInitData(contentitem,'keyids')
- };
-
- runTest(config);
- </script>
- </body>
-</html> \ No newline at end of file
diff --git a/testing/web-platform/tests/encrypted-media/clearkey-mp4-playback-persistent-license.html b/testing/web-platform/tests/encrypted-media/clearkey-mp4-playback-persistent-license.html
deleted file mode 100644
index 352a2a7b0..000000000
--- a/testing/web-platform/tests/encrypted-media/clearkey-mp4-playback-persistent-license.html
+++ /dev/null
@@ -1,52 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <title>Encrypted Media Extensions: Successful Playback, persistent-license session with Clear Key, mp4</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
- <script src=/encrypted-media/util/testmediasource.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
-
- <!-- Content metadata -->
- <script src=/encrypted-media/content/content-metadata.js></script>
-
- <!-- Message handler for Clear Key keysystem -->
- <script src=/encrypted-media/util/clearkey-messagehandler.js></script>
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/playback-persistent-license.js></script>
-
- </head>
- <body>
- <div id='log'></div>
-
- <div id='video'>
- <video id="videoelement" width="200px"></video>
- </div>
-
- <script>
- var contentitem = content['mp4-basic'],
- handler = new MessageHandler( 'org.w3.clearkey', contentitem ),
- config = { video: document.getElementById('videoelement'),
- keysystem: 'org.w3.clearkey',
- messagehandler: handler.messagehandler,
- audioPath: contentitem.audio.path,
- videoPath: contentitem.video.path,
- audioType: contentitem.audio.type,
- videoType: contentitem.video.type,
- initDataType: 'keyids',
- initData: getInitData(contentitem,'keyids')
- };
-
- runTest(config);
- </script>
- </body>
-</html> \ No newline at end of file
diff --git a/testing/web-platform/tests/encrypted-media/clearkey-mp4-playback-persistent-usage-record-events.html b/testing/web-platform/tests/encrypted-media/clearkey-mp4-playback-persistent-usage-record-events.html
deleted file mode 100644
index 795cf5b60..000000000
--- a/testing/web-platform/tests/encrypted-media/clearkey-mp4-playback-persistent-usage-record-events.html
+++ /dev/null
@@ -1,52 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <title>Encrypted Media Extensions: Successful Playback, persistent-usage-record session with Clear Key, mp4, event sequence</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
- <script src=/encrypted-media/util/testmediasource.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
-
- <!-- Content metadata -->
- <script src=/encrypted-media/content/content-metadata.js></script>
-
- <!-- Message handler for Clear Key keysystem -->
- <script src=/encrypted-media/util/clearkey-messagehandler.js></script>
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/playback-persistent-usage-record-events.js></script>
-
- </head>
- <body>
- <div id='log'></div>
-
- <div id='video'>
- <video id="videoelement" width="200px"></video>
- </div>
-
- <script>
- var contentitem = content['mp4-basic'],
- handler = new MessageHandler( 'org.w3.clearkey', contentitem ),
- config = { video: document.getElementById('videoelement'),
- keysystem: 'org.w3.clearkey',
- messagehandler: handler.messagehandler,
- audioPath: contentitem.audio.path,
- videoPath: contentitem.video.path,
- audioType: contentitem.audio.type,
- videoType: contentitem.video.type,
- initDataType: 'keyids',
- initData: getInitData(contentitem,'keyids')
- };
-
- runTest(config);
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/clearkey-mp4-playback-persistent-usage-record.html b/testing/web-platform/tests/encrypted-media/clearkey-mp4-playback-persistent-usage-record.html
deleted file mode 100644
index a2eb397d6..000000000
--- a/testing/web-platform/tests/encrypted-media/clearkey-mp4-playback-persistent-usage-record.html
+++ /dev/null
@@ -1,52 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <title>Encrypted Media Extensions: Successful Playback, persistent-usage-record session with Clear Key, mp4, event sequence</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
- <script src=/encrypted-media/util/testmediasource.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
-
- <!-- Content metadata -->
- <script src=/encrypted-media/content/content-metadata.js></script>
-
- <!-- Message handler for Clear Key keysystem -->
- <script src=/encrypted-media/util/clearkey-messagehandler.js></script>
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/playback-persistent-usage-record.js></script>
-
- </head>
- <body>
- <div id='log'></div>
-
- <div id='video'>
- <video id="videoelement" width="200px"></video>
- </div>
-
- <script>
- var contentitem = content['mp4-basic'],
- handler = new MessageHandler( 'org.w3.clearkey', contentitem ),
- config = { video: document.getElementById('videoelement'),
- keysystem: 'org.w3.clearkey',
- messagehandler: handler.messagehandler,
- audioPath: contentitem.audio.path,
- videoPath: contentitem.video.path,
- audioType: contentitem.audio.type,
- videoType: contentitem.video.type,
- initDataType: 'keyids',
- initData: getInitData(contentitem,'keyids')
- };
-
- runTest(config);
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/clearkey-mp4-playback-retrieve-destroy-persistent-license.html b/testing/web-platform/tests/encrypted-media/clearkey-mp4-playback-retrieve-destroy-persistent-license.html
deleted file mode 100644
index 85510b24b..000000000
--- a/testing/web-platform/tests/encrypted-media/clearkey-mp4-playback-retrieve-destroy-persistent-license.html
+++ /dev/null
@@ -1,53 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <title>Encrypted Media Extensions: persistent-license, playback, retrieve, playback and destroy with Clear Key, mp4</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
- <script src=/encrypted-media/util/testmediasource.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
-
- <!-- Content metadata -->
- <script src=/encrypted-media/content/content-metadata.js></script>
-
- <!-- Message handler for Clear Key keysystem -->
- <script src=/encrypted-media/util/clearkey-messagehandler.js></script>
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/playback-retrieve-persistent-license.js></script>
-
- </head>
- <body>
- <div id='log'></div>
-
- <div id='video'>
- <video id="videoelement" width="200px"></video>
- </div>
-
- <script>
- var contentitem = content['mp4-basic'],
- handler = new MessageHandler( 'org.w3.clearkey', contentitem ),
- config = { video: document.getElementById('videoelement'),
- keysystem: 'org.w3.clearkey',
- messagehandler: handler.messagehandler,
- audioPath: contentitem.audio.path,
- videoPath: contentitem.video.path,
- audioType: contentitem.audio.type,
- videoType: contentitem.video.type,
- initDataType: 'keyids',
- initData: getInitData(contentitem,'keyids'),
- windowscript: 'resources/clearkey-retrieve-destroy-persistent-license.html',
- testcase: 'playback, retrieve, playback and destroy' };
-
- runTest(config);
- </script>
- </body>
-</html> \ No newline at end of file
diff --git a/testing/web-platform/tests/encrypted-media/clearkey-mp4-playback-retrieve-persistent-license.html b/testing/web-platform/tests/encrypted-media/clearkey-mp4-playback-retrieve-persistent-license.html
deleted file mode 100644
index 7d8fe57ff..000000000
--- a/testing/web-platform/tests/encrypted-media/clearkey-mp4-playback-retrieve-persistent-license.html
+++ /dev/null
@@ -1,53 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <title>Encrypted Media Extensions: persistent-license playback, retrieve and playback with Clear Key, mp4</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
- <script src=/encrypted-media/util/testmediasource.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
-
- <!-- Content metadata -->
- <script src=/encrypted-media/content/content-metadata.js></script>
-
- <!-- Message handler for Clear Key keysystem -->
- <script src=/encrypted-media/util/clearkey-messagehandler.js></script>
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/playback-retrieve-persistent-license.js></script>
-
- </head>
- <body>
- <div id='log'></div>
-
- <div id='video'>
- <video id="videoelement" width="200px"></video>
- </div>
-
- <script>
- var contentitem = content['mp4-basic'],
- handler = new MessageHandler( 'org.w3.clearkey', contentitem ),
- config = { video: document.getElementById('videoelement'),
- keysystem: 'org.w3.clearkey',
- messagehandler: handler.messagehandler,
- audioPath: contentitem.audio.path,
- videoPath: contentitem.video.path,
- audioType: contentitem.audio.type,
- videoType: contentitem.video.type,
- initDataType: 'keyids',
- initData: getInitData(contentitem,'keyids'),
- windowscript: 'resources/clearkey-retrieve-persistent-license.html',
- testcase: 'playback, retrieve and playback' };
-
- runTest(config);
- </script>
- </body>
-</html> \ No newline at end of file
diff --git a/testing/web-platform/tests/encrypted-media/clearkey-mp4-playback-retrieve-persistent-usage-record.html b/testing/web-platform/tests/encrypted-media/clearkey-mp4-playback-retrieve-persistent-usage-record.html
deleted file mode 100644
index c612b8cd9..000000000
--- a/testing/web-platform/tests/encrypted-media/clearkey-mp4-playback-retrieve-persistent-usage-record.html
+++ /dev/null
@@ -1,52 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <title>Encrypted Media Extensions: persistent-usage-record, playback and retrieve record in new window, Clear Key, mp4</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
- <script src=/encrypted-media/util/testmediasource.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
-
- <!-- Content metadata -->
- <script src=/encrypted-media/content/content-metadata.js></script>
-
- <!-- Message handler for Clear Key keysystem -->
- <script src=/encrypted-media/util/clearkey-messagehandler.js></script>
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/playback-retrieve-persistent-usage-record.js></script>
-
- </head>
- <body>
- <div id='log'></div>
-
- <div id='video'>
- <video id="videoelement" width="200px"></video>
- </div>
-
- <script>
- var contentitem = content['mp4-basic'],
- handler = new MessageHandler( 'org.w3.clearkey', contentitem ),
- config = { video: document.getElementById('videoelement'),
- keysystem: 'org.w3.clearkey',
- messagehandler: handler.messagehandler,
- audioPath: contentitem.audio.path,
- videoPath: contentitem.video.path,
- audioType: contentitem.audio.type,
- videoType: contentitem.video.type,
- initDataType: 'keyids',
- initData: getInitData(contentitem,'keyids'),
- windowscript: 'resources/retrieve-persistent-usage-record.html' };
-
- runTest(config);
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/clearkey-mp4-playback-temporary-clear-encrypted.html b/testing/web-platform/tests/encrypted-media/clearkey-mp4-playback-temporary-clear-encrypted.html
deleted file mode 100644
index 9eca41cc0..000000000
--- a/testing/web-platform/tests/encrypted-media/clearkey-mp4-playback-temporary-clear-encrypted.html
+++ /dev/null
@@ -1,53 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <title>Encrypted Media Extensions: Successful Playback, Temporary session with Clear Key, mp4, clear then encrypted</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
- <script src=/encrypted-media/util/testmediasource.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
-
- <!-- Content metadata -->
- <script src=/encrypted-media/content/content-metadata.js></script>
-
- <!-- Message handler for Clear Key keysystem -->
- <script src=/encrypted-media/util/clearkey-messagehandler.js></script>
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/playback-temporary.js></script>
-
- </head>
- <body>
- <div id='log'></div>
-
- <div id='video'>
- <video id="videoelement" width="200px"></video>
- </div>
-
- <script>
- var contentitem = content['mp4-clear-encrypted'],
- handler = new MessageHandler('org.w3.clearkey', contentitem),
- config = { video: document.getElementById('videoelement'),
- keysystem: 'org.w3.clearkey',
- messagehandler: handler.messagehandler,
- audioPath: contentitem.audio.path,
- videoPath: contentitem.video.path,
- audioType: contentitem.audio.type,
- videoType: contentitem.video.type,
- initDataType: 'keyids',
- initData: getInitData(contentitem, 'keyids'),
- duration: 4,
- testcase: 'single key, clear then encrypted content' };
-
- runTest(config);
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/clearkey-mp4-playback-temporary-encrypted-clear-sources.html b/testing/web-platform/tests/encrypted-media/clearkey-mp4-playback-temporary-encrypted-clear-sources.html
deleted file mode 100644
index 04ffe0ccd..000000000
--- a/testing/web-platform/tests/encrypted-media/clearkey-mp4-playback-temporary-encrypted-clear-sources.html
+++ /dev/null
@@ -1,58 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <title>Encrypted Media Extensions: Successful Playback, alternate Encrypted and Clear playbacks, Temporary, mp4, Clear Key</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
- <script src=/encrypted-media/util/testmediasource.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
-
- <!-- Content metadata -->
- <script src=/encrypted-media/content/content-metadata.js></script>
-
- <!-- Message handler for Clear Key keysystem -->
- <script src=/encrypted-media/util/clearkey-messagehandler.js></script>
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/playback-temporary-encrypted-clear-sources.js></script>
-
- </head>
- <body>
- <div id='log'></div>
-
- <div id='video'>
- <video id="videoelement" width="200px"></video>
- </div>
-
- <script>
- var encryptedcontentitem = content['mp4-basic'],
- clearcontentitem = content['mp4-clear'],
- handler = new MessageHandler('org.w3.clearkey', encryptedcontentitem),
- configEncrypted = { video: document.getElementById('videoelement'),
- keysystem: 'org.w3.clearkey',
- messagehandler: handler.messagehandler,
- audioPath: encryptedcontentitem.audio.path,
- videoPath: encryptedcontentitem.video.path,
- audioType: encryptedcontentitem.audio.type,
- videoType: encryptedcontentitem.video.type,
- initDataType: 'keyids',
- initData: getInitData(encryptedcontentitem, 'keyids'),
- },
- configClear = { audioPath: clearcontentitem.audio.path,
- videoPath: clearcontentitem.video.path,
- audioType: clearcontentitem.audio.type,
- videoType: clearcontentitem.video.type,
- };
-
- runTest(configEncrypted,configClear);
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/clearkey-mp4-playback-temporary-encrypted-clear.html b/testing/web-platform/tests/encrypted-media/clearkey-mp4-playback-temporary-encrypted-clear.html
deleted file mode 100644
index 1e1902463..000000000
--- a/testing/web-platform/tests/encrypted-media/clearkey-mp4-playback-temporary-encrypted-clear.html
+++ /dev/null
@@ -1,53 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <title>Encrypted Media Extensions: Successful Playback, Temporary session with Clear Key, mp4, encrypted then clear</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
- <script src=/encrypted-media/util/testmediasource.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
-
- <!-- Content metadata -->
- <script src=/encrypted-media/content/content-metadata.js></script>
-
- <!-- Message handler for Clear Key keysystem -->
- <script src=/encrypted-media/util/clearkey-messagehandler.js></script>
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/playback-temporary.js></script>
-
- </head>
- <body>
- <div id='log'></div>
-
- <div id='video'>
- <video id="videoelement" width="200px"></video>
- </div>
-
- <script>
- var contentitem = content['mp4-encrypted-clear'],
- handler = new MessageHandler('org.w3.clearkey', contentitem),
- config = { video: document.getElementById('videoelement'),
- keysystem: 'org.w3.clearkey',
- messagehandler: handler.messagehandler,
- audioPath: contentitem.audio.path,
- videoPath: contentitem.video.path,
- audioType: contentitem.audio.type,
- videoType: contentitem.video.type,
- initDataType: 'keyids',
- initData: getInitData(contentitem, 'keyids'),
- duration: 4,
- testcase: 'single key, encrypted then clear content' };
-
- runTest(config);
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/clearkey-mp4-playback-temporary-events.html b/testing/web-platform/tests/encrypted-media/clearkey-mp4-playback-temporary-events.html
deleted file mode 100644
index c4d4ea37d..000000000
--- a/testing/web-platform/tests/encrypted-media/clearkey-mp4-playback-temporary-events.html
+++ /dev/null
@@ -1,52 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <title>Encrypted Media Extensions: Successful playback, Temporary session with Clear Key, mp4, validating events</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
- <script src=/encrypted-media/util/testmediasource.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
-
- <!-- Content metadata -->
- <script src=/encrypted-media/content/content-metadata.js></script>
-
- <!-- Message handler for Clear Key keysystem -->
- <script src=/encrypted-media/util/clearkey-messagehandler.js></script>
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/playback-temporary-events.js></script>
-
- </head>
- <body>
- <div id='log'></div>
-
- <div id='video'>
- <video id="videoelement" width="200px"></video>
- </div>
-
- <script>
- var contentitem = content['mp4-basic'],
- handler = new MessageHandler( 'org.w3.clearkey', contentitem ),
- config = { video: document.getElementById('videoelement'),
- keysystem: 'org.w3.clearkey',
- messagehandler: handler.messagehandler,
- audioPath: contentitem.audio.path,
- videoPath: contentitem.video.path,
- audioType: contentitem.audio.type,
- videoType: contentitem.video.type,
- initDataType: 'keyids',
- initData: getInitData(contentitem,'keyids')
- };
-
- runTest(config);
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/clearkey-mp4-playback-temporary-multikey-sequential-readyState.html b/testing/web-platform/tests/encrypted-media/clearkey-mp4-playback-temporary-multikey-sequential-readyState.html
deleted file mode 100644
index 66313e727..000000000
--- a/testing/web-platform/tests/encrypted-media/clearkey-mp4-playback-temporary-multikey-sequential-readyState.html
+++ /dev/null
@@ -1,55 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <meta name="timeout" content="long">
- <title>Encrypted Media Extensions: Successful Playback, Temporary session with Clear Key, mp4, multiple keys in sequence, check readyState</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
- <script src=/encrypted-media/util/testmediasource.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
-
- <!-- Content metadata -->
- <script src=/encrypted-media/content/content-metadata.js></script>
-
- <!-- Message handler for Clear Key keysystem -->
- <script src=/encrypted-media/util/clearkey-messagehandler.js></script>
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/playback-temporary-multikey-sequential.js></script>
-
- </head>
- <body>
- <div id='log'></div>
-
- <div id='video'>
- <video id="videoelement" width="200px"></video>
- </div>
-
- <script>
- var contentitem = content['mp4-multikey-sequential'],
- handler = new MessageHandler('org.w3.clearkey', contentitem),
- config = { video: document.getElementById('videoelement'),
- keysystem: 'org.w3.clearkey',
- messagehandler: handler.messagehandler,
- audioPath: contentitem.audio.path,
- videoPath: contentitem.video.path,
- audioType: contentitem.audio.type,
- videoType: contentitem.video.type,
- initDataType: 'keyids',
- initData: getMultikeyInitDatas(contentitem, 'keyids'),
- duration: 5,
- checkReadyState: true
- };
-
- runTest(config);
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/clearkey-mp4-playback-temporary-multikey-sequential.html b/testing/web-platform/tests/encrypted-media/clearkey-mp4-playback-temporary-multikey-sequential.html
deleted file mode 100644
index 64b00cd29..000000000
--- a/testing/web-platform/tests/encrypted-media/clearkey-mp4-playback-temporary-multikey-sequential.html
+++ /dev/null
@@ -1,54 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <meta name="timeout" content="long">
- <title>Encrypted Media Extensions: Successful Playback, Temporary session with Clear Key, mp4, multiple keys in sequence</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
- <script src=/encrypted-media/util/testmediasource.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
-
- <!-- Content metadata -->
- <script src=/encrypted-media/content/content-metadata.js></script>
-
- <!-- Message handler for Clear Key keysystem -->
- <script src=/encrypted-media/util/clearkey-messagehandler.js></script>
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/playback-temporary-multikey-sequential.js></script>
-
- </head>
- <body>
- <div id='log'></div>
-
- <div id='video'>
- <video id="videoelement" width="200px"></video>
- </div>
-
- <script>
- var contentitem = content['mp4-multikey-sequential'],
- handler = new MessageHandler( 'org.w3.clearkey', contentitem ),
- config = { video: document.getElementById('videoelement'),
- keysystem: 'org.w3.clearkey',
- messagehandler: handler.messagehandler,
- audioPath: contentitem.audio.path,
- videoPath: contentitem.video.path,
- audioType: contentitem.audio.type,
- videoType: contentitem.video.type,
- initDataType: 'keyids',
- initData: getMultikeyInitDatas(contentitem,'keyids'),
- duration: 5
- };
-
- runTest(config);
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/clearkey-mp4-playback-temporary-multikey.html b/testing/web-platform/tests/encrypted-media/clearkey-mp4-playback-temporary-multikey.html
deleted file mode 100644
index 29d1a2eed..000000000
--- a/testing/web-platform/tests/encrypted-media/clearkey-mp4-playback-temporary-multikey.html
+++ /dev/null
@@ -1,53 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <title>Encrypted Media Extensions: Successful Playback, Temporary session with Clear Key, mp4, multiple keys for audio/video</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
- <script src=/encrypted-media/util/testmediasource.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
-
- <!-- Content metadata -->
- <script src=/encrypted-media/content/content-metadata.js></script>
-
- <!-- Message handler for Clear Key keysystem -->
- <script src=/encrypted-media/util/clearkey-messagehandler.js></script>
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/playback-temporary.js></script>
-
- </head>
- <body>
- <div id='log'></div>
-
- <div id='video'>
- <video id="videoelement" width="200px"></video>
- </div>
-
- <script>
- var contentitem = content['mp4-av-multikey'],
- handler = new MessageHandler( 'org.w3.clearkey', contentitem ),
- config = { video: document.getElementById('videoelement'),
- keysystem: 'org.w3.clearkey',
- messagehandler: handler.messagehandler,
- audioPath: contentitem.audio.path,
- videoPath: contentitem.video.path,
- audioType: contentitem.audio.type,
- videoType: contentitem.video.type,
- initDataType: 'keyids',
- initData: getInitData(contentitem,'keyids'),
- testcase: 'multikey audio/video' };
-
-
- runTest(config);
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/clearkey-mp4-playback-temporary-multisession.html b/testing/web-platform/tests/encrypted-media/clearkey-mp4-playback-temporary-multisession.html
deleted file mode 100644
index 8f32120f1..000000000
--- a/testing/web-platform/tests/encrypted-media/clearkey-mp4-playback-temporary-multisession.html
+++ /dev/null
@@ -1,52 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <title>Encrypted Media Extensions: Successful Playback, Temporary session with Clear Key, mp4, multiple keys in sequence</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
- <script src=/encrypted-media/util/testmediasource.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
-
- <!-- Content metadata -->
- <script src=/encrypted-media/content/content-metadata.js></script>
-
- <!-- Message handler for Clear Key keysystem -->
- <script src=/encrypted-media/util/clearkey-messagehandler.js></script>
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/playback-temporary-multisession.js></script>
-
- </head>
- <body>
- <div id='log'></div>
-
- <div id='video'>
- <video id="videoelement" width="200px"></video>
- </div>
-
- <script>
- var contentitem = content['mp4-multikey'],
- handler = new MessageHandler( 'org.w3.clearkey', contentitem ),
- config = { video: document.getElementById('videoelement'),
- keysystem: 'org.w3.clearkey',
- messagehandler: handler.messagehandler,
- audioPath: contentitem.audio.path,
- videoPath: contentitem.video.path,
- audioType: contentitem.audio.type,
- videoType: contentitem.video.type,
- initDataType: 'keyids',
- initData: getMultikeyInitDatas(contentitem,'keyids'),
- testcase: 'multikey video' };
-
- runTest(config);
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/clearkey-mp4-playback-temporary-setMediaKeys-after-src.html b/testing/web-platform/tests/encrypted-media/clearkey-mp4-playback-temporary-setMediaKeys-after-src.html
deleted file mode 100644
index bade71626..000000000
--- a/testing/web-platform/tests/encrypted-media/clearkey-mp4-playback-temporary-setMediaKeys-after-src.html
+++ /dev/null
@@ -1,52 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <title>Encrypted Media Extensions: Successful Playback, Temporary session with Clear Key, mp4</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
- <script src=/encrypted-media/util/testmediasource.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
-
- <!-- Content metadata -->
- <script src=/encrypted-media/content/content-metadata.js></script>
-
- <!-- Message handler for Clear Key keysystem -->
- <script src=/encrypted-media/util/clearkey-messagehandler.js></script>
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/playback-temporary-setMediaKeys.js></script>
-
- </head>
- <body>
- <div id='log'></div>
-
- <div id='video'>
- <video id="videoelement" width="200px"></video>
- </div>
-
- <script>
- var contentitem = content['mp4-basic'],
- handler = new MessageHandler( 'org.w3.clearkey', contentitem ),
- config = { video: document.getElementById('videoelement'),
- keysystem: 'org.w3.clearkey',
- messagehandler: handler.messagehandler,
- audioPath: contentitem.audio.path,
- videoPath: contentitem.video.path,
- audioType: contentitem.audio.type,
- videoType: contentitem.video.type,
- initDataType: 'keyids',
- initData: getInitData(contentitem,'keyids'),
- testcase: SETMEDIAKEYS_AFTER_SRC };
-
- runTest(config);
- </script>
- </body>
-</html> \ No newline at end of file
diff --git a/testing/web-platform/tests/encrypted-media/clearkey-mp4-playback-temporary-setMediaKeys-after-update.html b/testing/web-platform/tests/encrypted-media/clearkey-mp4-playback-temporary-setMediaKeys-after-update.html
deleted file mode 100644
index 1085ce4e7..000000000
--- a/testing/web-platform/tests/encrypted-media/clearkey-mp4-playback-temporary-setMediaKeys-after-update.html
+++ /dev/null
@@ -1,52 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <title>Encrypted Media Extensions: Successful Playback, Temporary session with Clear Key, mp4</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
- <script src=/encrypted-media/util/testmediasource.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
-
- <!-- Content metadata -->
- <script src=/encrypted-media/content/content-metadata.js></script>
-
- <!-- Message handler for Clear Key keysystem -->
- <script src=/encrypted-media/util/clearkey-messagehandler.js></script>
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/playback-temporary-setMediaKeys.js></script>
-
- </head>
- <body>
- <div id='log'></div>
-
- <div id='video'>
- <video id="videoelement" width="200px"></video>
- </div>
-
- <script>
- var contentitem = content['mp4-basic'],
- handler = new MessageHandler( 'org.w3.clearkey', contentitem ),
- config = { video: document.getElementById('videoelement'),
- keysystem: 'org.w3.clearkey',
- messagehandler: handler.messagehandler,
- audioPath: contentitem.audio.path,
- videoPath: contentitem.video.path,
- audioType: contentitem.audio.type,
- videoType: contentitem.video.type,
- initDataType: 'keyids',
- initData: getInitData(contentitem,'keyids'),
- testcase: SETMEDIAKEYS_AFTER_UPDATE };
-
- runTest(config);
- </script>
- </body>
-</html> \ No newline at end of file
diff --git a/testing/web-platform/tests/encrypted-media/clearkey-mp4-playback-temporary-setMediaKeys-immediately.html b/testing/web-platform/tests/encrypted-media/clearkey-mp4-playback-temporary-setMediaKeys-immediately.html
deleted file mode 100644
index 7f362f442..000000000
--- a/testing/web-platform/tests/encrypted-media/clearkey-mp4-playback-temporary-setMediaKeys-immediately.html
+++ /dev/null
@@ -1,52 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <title>Encrypted Media Extensions: Successful Playback, Temporary session with Clear Key, mp4</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
- <script src=/encrypted-media/util/testmediasource.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
-
- <!-- Content metadata -->
- <script src=/encrypted-media/content/content-metadata.js></script>
-
- <!-- Message handler for Clear Key keysystem -->
- <script src=/encrypted-media/util/clearkey-messagehandler.js></script>
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/playback-temporary-setMediaKeys.js></script>
-
- </head>
- <body>
- <div id='log'></div>
-
- <div id='video'>
- <video id="videoelement" width="200px"></video>
- </div>
-
- <script>
- var contentitem = content['mp4-basic'],
- handler = new MessageHandler( 'org.w3.clearkey', contentitem ),
- config = { video: document.getElementById('videoelement'),
- keysystem: 'org.w3.clearkey',
- messagehandler: handler.messagehandler,
- audioPath: contentitem.audio.path,
- videoPath: contentitem.video.path,
- audioType: contentitem.audio.type,
- videoType: contentitem.video.type,
- initDataType: 'keyids',
- initData: getInitData(contentitem,'keyids'),
- testcase: SETMEDIAKEYS_IMMEDIATELY };
-
- runTest(config);
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/clearkey-mp4-playback-temporary-setMediaKeys-onencrypted.html b/testing/web-platform/tests/encrypted-media/clearkey-mp4-playback-temporary-setMediaKeys-onencrypted.html
deleted file mode 100644
index a49bc28d3..000000000
--- a/testing/web-platform/tests/encrypted-media/clearkey-mp4-playback-temporary-setMediaKeys-onencrypted.html
+++ /dev/null
@@ -1,52 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <title>Encrypted Media Extensions: Successful Playback, Temporary session with Clear Key, mp4</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
- <script src=/encrypted-media/util/testmediasource.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
-
- <!-- Content metadata -->
- <script src=/encrypted-media/content/content-metadata.js></script>
-
- <!-- Message handler for Clear Key keysystem -->
- <script src=/encrypted-media/util/clearkey-messagehandler.js></script>
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/playback-temporary-setMediaKeys.js></script>
-
- </head>
- <body>
- <div id='log'></div>
-
- <div id='video'>
- <video id="videoelement" width="200px"></video>
- </div>
-
- <script>
- var contentitem = content['mp4-basic'],
- handler = new MessageHandler( 'org.w3.clearkey', contentitem ),
- config = { video: document.getElementById('videoelement'),
- keysystem: 'org.w3.clearkey',
- messagehandler: handler.messagehandler,
- audioPath: contentitem.audio.path,
- videoPath: contentitem.video.path,
- audioType: contentitem.audio.type,
- videoType: contentitem.video.type,
- initDataType: 'keyids',
- initData: getInitData(contentitem,'keyids'),
- testcase: SETMEDIAKEYS_ONENCRYPTED };
-
- runTest(config);
- </script>
- </body>
-</html> \ No newline at end of file
diff --git a/testing/web-platform/tests/encrypted-media/clearkey-mp4-playback-temporary-two-videos.html b/testing/web-platform/tests/encrypted-media/clearkey-mp4-playback-temporary-two-videos.html
deleted file mode 100644
index 95de680e4..000000000
--- a/testing/web-platform/tests/encrypted-media/clearkey-mp4-playback-temporary-two-videos.html
+++ /dev/null
@@ -1,55 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <meta name="timeout" content="long">
- <title>Encrypted Media Extensions: Successful Playback, Temporary session with Clear Key, mp4, two videos</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
- <script src=/encrypted-media/util/testmediasource.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
-
- <!-- Content metadata -->
- <script src=/encrypted-media/content/content-metadata.js></script>
-
- <!-- Message handler for Clear Key keysystem -->
- <script src=/encrypted-media/util/clearkey-messagehandler.js></script>
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/playback-temporary-two-videos.js></script>
-
- </head>
- <body>
- <div id='log'></div>
-
- <div id='video'>
- <video id="videoelement1" width="200px"></video>
- <video id="videoelement2" width="200px"></video>
- </div>
-
- <script>
- var contentitem = content['mp4-basic'],
- handler = new MessageHandler( 'org.w3.clearkey', contentitem ),
- config = { video: [ document.getElementById( 'videoelement1' ),
- document.getElementById( 'videoelement2' ) ],
- keysystem: 'org.w3.clearkey',
- messagehandler: handler.messagehandler,
- audioPath: contentitem.audio.path,
- videoPath: contentitem.video.path,
- audioType: contentitem.audio.type,
- videoType: contentitem.video.type,
- initDataType: 'keyids',
- initData: getInitData(contentitem,'keyids'),
- };
-
- runTest(config);
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/clearkey-mp4-playback-temporary-waitingforkey.html b/testing/web-platform/tests/encrypted-media/clearkey-mp4-playback-temporary-waitingforkey.html
deleted file mode 100644
index 94d35daa5..000000000
--- a/testing/web-platform/tests/encrypted-media/clearkey-mp4-playback-temporary-waitingforkey.html
+++ /dev/null
@@ -1,52 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <title>Encrypted Media Extensions: Successful Playback, Temporary session with Clear Key, mp4, play, wait for key, continue play</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
- <script src=/encrypted-media/util/testmediasource.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
-
- <!-- Content metadata -->
- <script src=/encrypted-media/content/content-metadata.js></script>
-
- <!-- Message handler for Clear Key keysystem -->
- <script src=/encrypted-media/util/clearkey-messagehandler.js></script>
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/playback-temporary-waitingforkey.js></script>
-
- </head>
- <body>
- <div id='log'></div>
-
- <div id='video'>
- <video id="videoelement" width="200px"></video>
- </div>
-
- <script>
- var contentitem = content['mp4-basic'],
- handler = new MessageHandler( 'org.w3.clearkey', contentitem ),
- config = { video: document.getElementById('videoelement'),
- keysystem: 'org.w3.clearkey',
- messagehandler: handler.messagehandler,
- audioPath: contentitem.audio.path,
- videoPath: contentitem.video.path,
- audioType: contentitem.audio.type,
- videoType: contentitem.video.type,
- initDataType: 'keyids',
- initData: getMultikeyInitDatas(contentitem,'keyids')
- };
-
- runTest(config);
- </script>
- </body>
-</html> \ No newline at end of file
diff --git a/testing/web-platform/tests/encrypted-media/clearkey-mp4-playback-temporary.html b/testing/web-platform/tests/encrypted-media/clearkey-mp4-playback-temporary.html
deleted file mode 100644
index 909f2af64..000000000
--- a/testing/web-platform/tests/encrypted-media/clearkey-mp4-playback-temporary.html
+++ /dev/null
@@ -1,52 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <title>Encrypted Media Extensions: Successful Playback, Temporary session with Clear Key, mp4</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
- <script src=/encrypted-media/util/testmediasource.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
-
- <!-- Content metadata -->
- <script src=/encrypted-media/content/content-metadata.js></script>
-
- <!-- Message handler for Clear Key keysystem -->
- <script src=/encrypted-media/util/clearkey-messagehandler.js></script>
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/playback-temporary.js></script>
-
- </head>
- <body>
- <div id='log'></div>
-
- <div id='video'>
- <video id="videoelement" width="200px"></video>
- </div>
-
- <script>
- var contentitem = content['mp4-basic'],
- handler = new MessageHandler( 'org.w3.clearkey', contentitem ),
- config = { video: document.getElementById('videoelement'),
- keysystem: 'org.w3.clearkey',
- messagehandler: handler.messagehandler,
- audioPath: contentitem.audio.path,
- videoPath: contentitem.video.path,
- audioType: contentitem.audio.type,
- videoType: contentitem.video.type,
- initDataType: 'keyids',
- initData: getInitData(contentitem,'keyids'),
- testcase: 'single key' };
-
- runTest(config);
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/clearkey-mp4-requestmediakeysystemaccess.html b/testing/web-platform/tests/encrypted-media/clearkey-mp4-requestmediakeysystemaccess.html
deleted file mode 100644
index f8402c99a..000000000
--- a/testing/web-platform/tests/encrypted-media/clearkey-mp4-requestmediakeysystemaccess.html
+++ /dev/null
@@ -1,40 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <meta name="timeout" content="long">
- <title>Encrypted Media Extensions: requestMediaKeySystemAccess tests, Clear Key</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
- <script src=/encrypted-media/util/testmediasource.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
-
- <!-- Content metadata -->
- <script src=/encrypted-media/content/content-metadata.js></script>
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/requestmediakeysystemaccess.js></script>
-
- </head>
- <body>
- <div id='log'></div>
-
- <script>
- var contentitem = content['mp4-basic'],
- config = { keysystem: 'org.w3.clearkey',
- audioType: contentitem.audio.type,
- videoType: contentitem.video.type,
- initDataType: 'keyids'
- };
-
- runTest(config);
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/clearkey-mp4-reset-src-after-setmediakeys.html b/testing/web-platform/tests/encrypted-media/clearkey-mp4-reset-src-after-setmediakeys.html
deleted file mode 100644
index 61da9d867..000000000
--- a/testing/web-platform/tests/encrypted-media/clearkey-mp4-reset-src-after-setmediakeys.html
+++ /dev/null
@@ -1,47 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <title>Encrypted Media Extensions - Reset MediaSource after setMediaKeys for Clear Key, mp4</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
- <script src=/encrypted-media/util/testmediasource.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
-
- <!-- Content metadata -->
- <script src=/encrypted-media/content/content-metadata.js></script>
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/reset-src-after-setmediakeys.js></script>
-
- </head>
- <body>
- <div id='log'></div>
- <div id='video'>
- <video id="videoelement" width="200px"></video>
- </div>
-
- <script>
- var contentItem = content['mp4-av-multikey'],
- config = {
- video: document.getElementById('videoelement'),
- keysystem: 'org.w3.clearkey',
- content: contentItem,
- initDataType: 'keyids',
- initData: getInitData(contentItem,'keyids'),
- audioType: contentItem.audio.type,
- videoType: contentItem.video.type,
- audioPath: contentItem.audio.path,
- videoPath: contentItem.video.path,
- };
- runTest(config);
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/clearkey-mp4-setmediakeys-again-after-playback.html b/testing/web-platform/tests/encrypted-media/clearkey-mp4-setmediakeys-again-after-playback.html
deleted file mode 100644
index 697cf207c..000000000
--- a/testing/web-platform/tests/encrypted-media/clearkey-mp4-setmediakeys-again-after-playback.html
+++ /dev/null
@@ -1,53 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <title>Encrypted Media Extensions: setMediaKeys again after playback with Clear Key</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
- <script src=/encrypted-media/util/testmediasource.js></script>
-
- <!-- Content metadata -->
- <script src=/encrypted-media/content/content-metadata.js></script>
-
- <!-- Message handler for Clear Key -->
- <script src=/encrypted-media/util/clearkey-messagehandler.js></script>
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/setmediakeys-again-after-playback.js></script>
-
- </head>
- <body>
- <div id='log'></div>
-
- <div id='video'>
- <video id="videoelement" width="200px"></video>
- </div>
-
- <script>
- var contentitem = content['mp4-basic'],
- handler = new MessageHandler('org.w3.clearkey', contentitem);
- getSupportedContent('org.w3.clearkey').then( function(contents) {
- runTest( { video: document.getElementById('videoelement'),
- keysystem: 'org.w3.clearkey',
- messagehandler: handler.messagehandler,
- content: contentitem,
- audioPath: contentitem.audio.path,
- videoPath: contentitem.video.path,
- audioType: contentitem.audio.type,
- videoType: contentitem.video.type,
- initDataType: 'keyids',
- initData: getInitData(contentitem, 'keyids')
- } );
- } );
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/clearkey-mp4-setmediakeys-again-after-resetting-src.html b/testing/web-platform/tests/encrypted-media/clearkey-mp4-setmediakeys-again-after-resetting-src.html
deleted file mode 100644
index d695445ef..000000000
--- a/testing/web-platform/tests/encrypted-media/clearkey-mp4-setmediakeys-again-after-resetting-src.html
+++ /dev/null
@@ -1,53 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <title>Encrypted Media Extensions: setMediaKeys again after resetting src attribute on video element with Clear Key</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
- <script src=/encrypted-media/util/testmediasource.js></script>
-
- <!-- Content metadata -->
- <script src=/encrypted-media/content/content-metadata.js></script>
-
- <!-- Message handler for Clear Key -->
- <script src=/encrypted-media/util/clearkey-messagehandler.js></script>
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/setmediakeys-again-after-resetting-src.js></script>
-
- </head>
- <body>
- <div id='log'></div>
-
- <div id='video'>
- <video id="videoelement" width="200px"></video>
- </div>
-
- <script>
- var contentitem = content['mp4-basic'],
- handler = new MessageHandler('org.w3.clearkey', contentitem );
- getSupportedContent( 'org.w3.clearkey' ).then( function( contents ) {
- runTest( { video: document.getElementById('videoelement'),
- keysystem: 'org.w3.clearkey',
- messagehandler: handler.messagehandler,
- content: contentitem,
- audioPath: contentitem.audio.path,
- videoPath: contentitem.video.path,
- audioType: contentitem.audio.type,
- videoType: contentitem.video.type,
- initDataType: 'keyids',
- initData: getInitData(contentitem,'keyids')
- } );
- } );
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/clearkey-mp4-setmediakeys-at-same-time.html b/testing/web-platform/tests/encrypted-media/clearkey-mp4-setmediakeys-at-same-time.html
deleted file mode 100644
index 91e6b9ec3..000000000
--- a/testing/web-platform/tests/encrypted-media/clearkey-mp4-setmediakeys-at-same-time.html
+++ /dev/null
@@ -1,43 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <title>Encrypted Media Extensions: setMediaKeys multiple at same time with Clear Key</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
-
- <!-- Content metadata -->
- <script src=/encrypted-media/content/content-metadata.js></script>
-
- <!-- Message handler for Clear Key -->
- <script src=/encrypted-media/util/clearkey-messagehandler.js></script>
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/setmediakeys-at-same-time.js></script>
-
- </head>
- <body>
- <div id='log'></div>
-
- <div id='video'>
- <video id="videoelement" width="200px"></video>
- </div>
-
- <script>
- getSupportedContent( 'org.w3.clearkey' ).then( function( contents ) {
- runTest( { video: document.getElementById('videoelement'),
- keysystem: 'org.w3.clearkey',
- content: contents[ 0 ]
- } );
- } );
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/clearkey-mp4-setmediakeys-multiple-times-with-different-mediakeys.html b/testing/web-platform/tests/encrypted-media/clearkey-mp4-setmediakeys-multiple-times-with-different-mediakeys.html
deleted file mode 100644
index 064d7ed05..000000000
--- a/testing/web-platform/tests/encrypted-media/clearkey-mp4-setmediakeys-multiple-times-with-different-mediakeys.html
+++ /dev/null
@@ -1,49 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <title>Encrypted Media Extensions: setMediaKeys multiple times with different mediakeys with Clear Key</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
- <script src=/encrypted-media/util/testmediasource.js></script>
-
- <!-- Content metadata -->
- <script src=/encrypted-media/content/content-metadata.js></script>
-
- <!-- Message handler for Clear Key -->
- <script src=/encrypted-media/util/clearkey-messagehandler.js></script>
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/setmediakeys-multiple-times-with-different-mediakeys.js></script>
-
- </head>
- <body>
- <div id='log'></div>
-
- <div id='video'>
- <video id="videoelement" width="200px"></video>
- </div>
-
- <script>
- var contentitem = content['mp4-basic'];
- getSupportedContent( 'org.w3.clearkey' ).then( function( contents ) {
- runTest( { video: document.getElementById('videoelement'),
- keysystem: 'org.w3.clearkey',
- content: contentitem,
- audioPath: contentitem.audio.path,
- videoPath: contentitem.video.path,
- audioType: contentitem.audio.type,
- videoType: contentitem.video.type
- } );
- } );
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/clearkey-mp4-setmediakeys-multiple-times-with-the-same-mediakeys.html b/testing/web-platform/tests/encrypted-media/clearkey-mp4-setmediakeys-multiple-times-with-the-same-mediakeys.html
deleted file mode 100644
index 9e383afc3..000000000
--- a/testing/web-platform/tests/encrypted-media/clearkey-mp4-setmediakeys-multiple-times-with-the-same-mediakeys.html
+++ /dev/null
@@ -1,49 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <title>Encrypted Media Extensions: setMediaKeys multiple times with the same mediakeys with Clear Key</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
- <script src=/encrypted-media/util/testmediasource.js></script>
-
- <!-- Content metadata -->
- <script src=/encrypted-media/content/content-metadata.js></script>
-
- <!-- Message handler for Clear Key -->
- <script src=/encrypted-media/util/clearkey-messagehandler.js></script>
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/setmediakeys-multiple-times-with-the-same-mediakeys.js></script>
-
- </head>
- <body>
- <div id='log'></div>
-
- <div id='video'>
- <video id="videoelement" width="200px"></video>
- </div>
-
- <script>
- var contentitem = content['mp4-basic'];
- getSupportedContent( 'org.w3.clearkey' ).then( function( contents ) {
- runTest( { video: document.getElementById('videoelement'),
- keysystem: 'org.w3.clearkey',
- content: contentitem,
- audioPath: contentitem.audio.path,
- videoPath: contentitem.video.path,
- audioType: contentitem.audio.type,
- videoType: contentitem.video.type
- } );
- } );
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/clearkey-mp4-setmediakeys-to-multiple-video-elements.html b/testing/web-platform/tests/encrypted-media/clearkey-mp4-setmediakeys-to-multiple-video-elements.html
deleted file mode 100644
index cf73b8085..000000000
--- a/testing/web-platform/tests/encrypted-media/clearkey-mp4-setmediakeys-to-multiple-video-elements.html
+++ /dev/null
@@ -1,47 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <title>Encrypted Media Extensions: setMediaKeys to multiple video elements with Clear Key</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
-
- <!-- Content metadata -->
- <script src=/encrypted-media/content/content-metadata.js></script>
-
- <!-- Message handler for Clear Key -->
- <script src=/encrypted-media/util/clearkey-messagehandler.js></script>
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/setmediakeys-to-multiple-video-elements.js></script>
-
- </head>
- <body>
- <div id='log'></div>
-
- <div id='video1'>
- <video id="videoelement1" width="200px"></video>
- </div>
- <div id='video2'>
- <video id="videoelement2" width="200px"></video>
- </div>
-
- <script>
- getSupportedContent( 'org.w3.clearkey' ).then( function( contents ) {
- runTest( { video1: document.getElementById('videoelement1'),
- video2: document.getElementById('videoelement2'),
- keysystem: 'org.w3.clearkey',
- content: contents[ 0 ]
- } );
- } );
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/clearkey-mp4-setmediakeys.html b/testing/web-platform/tests/encrypted-media/clearkey-mp4-setmediakeys.html
deleted file mode 100644
index 2865052c6..000000000
--- a/testing/web-platform/tests/encrypted-media/clearkey-mp4-setmediakeys.html
+++ /dev/null
@@ -1,43 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <title>Encrypted Media Extensions: setMediaKeys with Clear Key</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
-
- <!-- Content metadata -->
- <script src=/encrypted-media/content/content-metadata.js></script>
-
- <!-- Message handler for Clear Key -->
- <script src=/encrypted-media/util/clearkey-messagehandler.js></script>
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/setmediakeys.js></script>
-
- </head>
- <body>
- <div id='log'></div>
-
- <div id='video'>
- <video id="videoelement" width="200px"></video>
- </div>
-
- <script>
- getSupportedContent( 'org.w3.clearkey' ).then( function( contents ) {
- runTest( { video: document.getElementById('videoelement'),
- keysystem: 'org.w3.clearkey',
- content: contents[ 0 ]
- } );
- } );
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/clearkey-mp4-syntax-mediakeys.html b/testing/web-platform/tests/encrypted-media/clearkey-mp4-syntax-mediakeys.html
deleted file mode 100644
index 6b4a08a91..000000000
--- a/testing/web-platform/tests/encrypted-media/clearkey-mp4-syntax-mediakeys.html
+++ /dev/null
@@ -1,42 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <title>Encrypted Media Extensions - Test MediaKeys attribute, setServerCertificate and setServerCertificate exception syntax for Clear Key, mp4</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
-
- <!-- Content metadata -->
- <script src=/encrypted-media/content/content-metadata.js></script>
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/syntax-mediakeys.js></script>
-
- </head>
- <body>
- <div id='log'></div>
- <div id='video'>
- <video id="videoelement" width="200px"></video>
- </div>
- <script>
- var contentItem = content['mp4-basic'],
- config = {
- keysystem: 'org.w3.clearkey',
- content: contentItem,
- initDataType: 'keyids',
- initData: getInitData(contentItem, 'keyids'),
- audioType: contentItem.audio.type,
- videoType: contentItem.video.type
- };
- runTest(config);
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/clearkey-mp4-syntax-mediakeysession.html b/testing/web-platform/tests/encrypted-media/clearkey-mp4-syntax-mediakeysession.html
deleted file mode 100644
index 2748c31a5..000000000
--- a/testing/web-platform/tests/encrypted-media/clearkey-mp4-syntax-mediakeysession.html
+++ /dev/null
@@ -1,42 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <title>Encrypted Media Extensions - Test MediaKeySession attribute and function syntax for Clear Key, mp4</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
-
- <!-- Content metadata -->
- <script src=/encrypted-media/content/content-metadata.js></script>
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/syntax-mediakeysession.js></script>
-
- </head>
- <body>
- <div id='log'></div>
- <div id='video'>
- <video id="videoelement" width="200px"></video>
- </div>
- <script>
- var contentItem = content['mp4-basic'],
- config = {
- keysystem: 'org.w3.clearkey',
- content: contentItem,
- initDataType: 'keyids',
- initData: getInitData(contentItem, 'keyids'),
- audioType: contentItem.audio.type,
- videoType: contentItem.video.type
- };
- runTest(config);
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/clearkey-mp4-syntax-mediakeysystemaccess.html b/testing/web-platform/tests/encrypted-media/clearkey-mp4-syntax-mediakeysystemaccess.html
deleted file mode 100644
index 22e72ccc8..000000000
--- a/testing/web-platform/tests/encrypted-media/clearkey-mp4-syntax-mediakeysystemaccess.html
+++ /dev/null
@@ -1,42 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <title>Encrypted Media Extensions - Test navigator.requestmediakeysystemaccess exception and MediaKeySystemAccess attribute syntax for Clear Key, mp4</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
-
- <!-- Content metadata -->
- <script src=/encrypted-media/content/content-metadata.js></script>
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/syntax-mediakeysystemaccess.js></script>
-
- </head>
- <body>
- <div id='log'></div>
- <div id='video'>
- <video id="videoelement" width="200px"></video>
- </div>
- <script>
- var contentItem = content['mp4-basic'],
- config = {
- keysystem: 'org.w3.clearkey',
- content: contentItem,
- initDataType: 'keyids',
- initData: getInitData(contentItem, 'keyids'),
- audioType: contentItem.audio.type,
- videoType: contentItem.video.type
- };
- runTest(config);
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/clearkey-mp4-unique-origin.html b/testing/web-platform/tests/encrypted-media/clearkey-mp4-unique-origin.html
deleted file mode 100644
index 2871862dd..000000000
--- a/testing/web-platform/tests/encrypted-media/clearkey-mp4-unique-origin.html
+++ /dev/null
@@ -1,43 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <title>Encrypted Media Extensions: Unique origin with Clear Key, mp4</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
-
- <!-- Content metadata -->
- <script src=/encrypted-media/content/content-metadata.js></script>
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/unique-origin.js></script>
-
- </head>
- <body>
- <div id='log'></div>
- <div id='video'>
- <video id="videoelement" width="200px"></video>
- </div>
-
- <script>
- var contentItem = content['mp4-av-multikey'],
- config = {
- video: document.getElementById('videoelement'),
- keysystem: 'org.w3.clearkey',
- initDataType: contentItem.initDataType,
- audioType: contentItem.audio.type,
- videoType: contentItem.video.type,
- audioPath: contentItem.audio.path,
- videoPath: contentItem.video.path
- };
- runTest(config);
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/clearkey-mp4-update-disallowed-input.html b/testing/web-platform/tests/encrypted-media/clearkey-mp4-update-disallowed-input.html
deleted file mode 100644
index e5061a765..000000000
--- a/testing/web-platform/tests/encrypted-media/clearkey-mp4-update-disallowed-input.html
+++ /dev/null
@@ -1,28 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <title>Encrypted Media Extensions - Test handling of invalid responses for update() for Clear Key, mp4</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src="/resources/testharness.js"></script>
- <script src="/resources/testharnessreport.js"></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/update-disallowed-input.js></script>
-
- </head>
- <body>
- <div id="log"></div>
- <script>
- var config = {
- keysystem: 'org.w3.clearkey',
- };
- runTest(config);
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/clearkey-mp4-waiting-for-a-key.html b/testing/web-platform/tests/encrypted-media/clearkey-mp4-waiting-for-a-key.html
deleted file mode 100644
index 2876a54a4..000000000
--- a/testing/web-platform/tests/encrypted-media/clearkey-mp4-waiting-for-a-key.html
+++ /dev/null
@@ -1,52 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <title>Encrypted Media Extensions - Waiting for a key for Clear Key, mp4</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
- <script src=/encrypted-media/util/testmediasource.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
-
- <!-- Message handler for DRM servers -->
- <script src=/encrypted-media/util/clearkey-messagehandler.js></script>
-
- <!-- Content metadata -->
- <script src=/encrypted-media/content/content-metadata.js></script>
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/waiting-for-a-key.js></script>
-
- </head>
- <body>
- <div id='log'></div>
- <div id='video'>
- <video id="videoelement" width="200px"></video>
- </div>
-
- <script>
- var contentItem = content['mp4-basic'],
- handler = new MessageHandler('org.w3.clearkey', contentItem),
- config = {
- video: document.getElementById('videoelement'),
- keysystem: 'org.w3.clearkey',
- content: contentItem,
- messageHandler: handler.messagehandler,
- initDataType: 'keyids',
- initData: getInitData(contentItem, 'keyids'),
- audioType: contentItem.audio.type,
- videoType: contentItem.video.type,
- audioPath: contentItem.audio.path,
- videoPath: contentItem.video.path,
- };
- runTest(config);
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/clearkey-not-callable-after-createsession.html b/testing/web-platform/tests/encrypted-media/clearkey-not-callable-after-createsession.html
deleted file mode 100644
index 29dc21492..000000000
--- a/testing/web-platform/tests/encrypted-media/clearkey-not-callable-after-createsession.html
+++ /dev/null
@@ -1,35 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <title>Encrypted Media Extensions: Test MediaKeySession not callable immediately after CreateSession().</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
-
- <!-- Message handler for Clear Key -->
- <script src=/encrypted-media/util/clearkey-messagehandler.js></script>
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/not-callable-after-createsession.js></script>
-
- </head>
- <body>
- <div id='log'></div>
-
- <script>
- var config = { keysystem: 'org.w3.clearkey'
- };
-
- runTest(config);
-
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/clearkey-update-non-ascii-input.html b/testing/web-platform/tests/encrypted-media/clearkey-update-non-ascii-input.html
deleted file mode 100644
index cc1347291..000000000
--- a/testing/web-platform/tests/encrypted-media/clearkey-update-non-ascii-input.html
+++ /dev/null
@@ -1,36 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <title>Encrypted Media Extensions: Test Clear Key handling of non-ASCII responses for update()</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
-
- <!-- Content metadata -->
- <script src=/encrypted-media/content/content-metadata.js></script>
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/clearkey-update-non-ascii-input.js></script>
-
- </head>
- <body>
- <div id='log'></div>
-
- <script>
- var contentItem = content['mp4-basic'],
- config = {
- keysystem: 'org.w3.clearkey',
- content: contentItem,
- initDataType: "keyids"
- };
- runTest(config);
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/content/audio_aac-lc_128k_2keys_2sess.mp4 b/testing/web-platform/tests/encrypted-media/content/audio_aac-lc_128k_2keys_2sess.mp4
deleted file mode 100644
index 526998d6a..000000000
--- a/testing/web-platform/tests/encrypted-media/content/audio_aac-lc_128k_2keys_2sess.mp4
+++ /dev/null
Binary files differ
diff --git a/testing/web-platform/tests/encrypted-media/content/audio_aac-lc_128k_dashinit.mp4 b/testing/web-platform/tests/encrypted-media/content/audio_aac-lc_128k_dashinit.mp4
deleted file mode 100644
index 4daf4d563..000000000
--- a/testing/web-platform/tests/encrypted-media/content/audio_aac-lc_128k_dashinit.mp4
+++ /dev/null
Binary files differ
diff --git a/testing/web-platform/tests/encrypted-media/content/audio_aac-lc_128k_enc_dashinit.mp4 b/testing/web-platform/tests/encrypted-media/content/audio_aac-lc_128k_enc_dashinit.mp4
deleted file mode 100644
index 77e869f80..000000000
--- a/testing/web-platform/tests/encrypted-media/content/audio_aac-lc_128k_enc_dashinit.mp4
+++ /dev/null
Binary files differ
diff --git a/testing/web-platform/tests/encrypted-media/content/content-metadata.js b/testing/web-platform/tests/encrypted-media/content/content-metadata.js
deleted file mode 100644
index 8ba5bcf06..000000000
--- a/testing/web-platform/tests/encrypted-media/content/content-metadata.js
+++ /dev/null
@@ -1,297 +0,0 @@
-content = addMemberListToObject( {
-
- 'mp4-clear' : { initDataType: 'cenc',
- audio : { type: 'audio/mp4;codecs="mp4a.40.2"',
- path: '/encrypted-media/content/audio_aac-lc_128k_dashinit.mp4' },
- video : { type: 'video/mp4;codecs="avc1.4d401e"',
- path: '/encrypted-media/content/video_512x288_h264-360k_clear_dashinit.mp4' }
- },
-
- 'mp4-basic' : { assetId: 'mp4-basic',
- initDataType: 'cenc',
- audio : { type: 'audio/mp4;codecs="mp4a.40.2"',
- path: '/encrypted-media/content/audio_aac-lc_128k_dashinit.mp4' },
- video : { type: 'video/mp4;codecs="avc1.4d401e"',
- path: '/encrypted-media/content/video_512x288_h264-360k_enc_dashinit.mp4' },
- keys : [ { kid: [ 0xad, 0x13, 0xf9, 0xea, 0x2b, 0xe6, 0x98, 0xb8, 0x75, 0xf5, 0x04, 0xa8, 0xe3, 0xcc, 0xea, 0x64 ],
- key: [ 0xbe, 0x7d, 0xf8, 0xa3, 0x66, 0x7a, 0x6a, 0x8f, 0xd5, 0x64, 0xd0, 0xed, 0x81, 0x33, 0x9a, 0x95 ],
- initDataType: 'cenc',
- initData: 'AAAAcXBzc2gAAAAA7e+LqXnWSs6jyCfc1R0h7QAAAFEIARIQrRP56ivmmLh19QSo48zqZBoIY2FzdGxhYnMiKGV5SmhjM05sZEVsa0lqb2laVzFsTFhSbGMzUXRjMmx1WjJ4bEluMD0yB2RlZmF1bHQAAAMacHNzaAAAAACaBPB5mEBChquS5lvgiF+VAAAC+voCAAABAAEA8AI8AFcAUgBNAEgARQBBAEQARQBSACAAeABtAGwAbgBzAD0AIgBoAHQAdABwADoALwAvAHMAYwBoAGUAbQBhAHMALgBtAGkAYwByAG8AcwBvAGYAdAAuAGMAbwBtAC8ARABSAE0ALwAyADAAMAA3AC8AMAAzAC8AUABsAGEAeQBSAGUAYQBkAHkASABlAGEAZABlAHIAIgAgAHYAZQByAHMAaQBvAG4APQAiADQALgAwAC4AMAAuADAAIgA+ADwARABBAFQAQQA+ADwAUABSAE8AVABFAEMAVABJAE4ARgBPAD4APABLAEUAWQBMAEUATgA+ADEANgA8AC8ASwBFAFkATABFAE4APgA8AEEATABHAEkARAA+AEEARQBTAEMAVABSADwALwBBAEwARwBJAEQAPgA8AC8AUABSAE8AVABFAEMAVABJAE4ARgBPAD4APABLAEkARAA+ADYAdgBrAFQAcgBlAFkAcgB1AEoAaAAxADkAUQBTAG8ANAA4AHoAcQBaAEEAPQA9ADwALwBLAEkARAA+ADwAQwBIAEUAQwBLAFMAVQBNAD4AagBZAEYATgBmADAAeQBmADQAaQBzAD0APAAvAEMASABFAEMASwBTAFUATQA+ADwATABBAF8AVQBSAEwAPgBoAHQAdABwADoALwAvAHAAbABhAHkAcgBlAGEAZAB5AC4AZABpAHIAZQBjAHQAdABhAHAAcwAuAG4AZQB0AC8AcAByAC8AcwB2AGMALwByAGkAZwBoAHQAcwBtAGEAbgBhAGcAZQByAC4AYQBzAG0AeAA/AFAAbABhAHkAUgBpAGcAaAB0AD0AMQAmAGEAbQBwADsAVQBzAGUAUwBpAG0AcABsAGUATgBvAG4AUABlAHIAcwBpAHMAdABlAG4AdABMAGkAYwBlAG4AcwBlAD0AMQA8AC8ATABBAF8AVQBSAEwAPgA8AC8ARABBAFQAQQA+ADwALwBXAFIATQBIAEUAQQBEAEUAUgA+AA==' } ]
- },
-
- 'mp4-clear-encrypted' : {
- assetId: 'mp4-basic',
- initDataType: 'cenc',
- audio : { type: 'audio/mp4;codecs="mp4a.40.2"',
- path: '/encrypted-media/content/audio_aac-lc_128k_dashinit.mp4' },
- video : { type: 'video/mp4;codecs="avc1.4d401e"',
- path: '/encrypted-media/content/video_512x288_h264-360k_clear_enc_dashinit.mp4' },
- keys : [ { kid: [ 0xad, 0x13, 0xf9, 0xea, 0x2b, 0xe6, 0x98, 0xb8, 0x75, 0xf5, 0x04, 0xa8, 0xe3, 0xcc, 0xea, 0x64 ],
- key: [ 0xbe, 0x7d, 0xf8, 0xa3, 0x66, 0x7a, 0x6a, 0x8f, 0xd5, 0x64, 0xd0, 0xed, 0x81, 0x33, 0x9a, 0x95 ],
- initDataType: 'cenc',
- initData: 'AAAAcXBzc2gAAAAA7e+LqXnWSs6jyCfc1R0h7QAAAFEIARIQrRP56ivmmLh19QSo48zqZBoIY2FzdGxhYnMiKGV5SmhjM05sZEVsa0lqb2laVzFsTFhSbGMzUXRjMmx1WjJ4bEluMD0yB2RlZmF1bHQAAAMacHNzaAAAAACaBPB5mEBChquS5lvgiF+VAAAC+voCAAABAAEA8AI8AFcAUgBNAEgARQBBAEQARQBSACAAeABtAGwAbgBzAD0AIgBoAHQAdABwADoALwAvAHMAYwBoAGUAbQBhAHMALgBtAGkAYwByAG8AcwBvAGYAdAAuAGMAbwBtAC8ARABSAE0ALwAyADAAMAA3AC8AMAAzAC8AUABsAGEAeQBSAGUAYQBkAHkASABlAGEAZABlAHIAIgAgAHYAZQByAHMAaQBvAG4APQAiADQALgAwAC4AMAAuADAAIgA+ADwARABBAFQAQQA+ADwAUABSAE8AVABFAEMAVABJAE4ARgBPAD4APABLAEUAWQBMAEUATgA+ADEANgA8AC8ASwBFAFkATABFAE4APgA8AEEATABHAEkARAA+AEEARQBTAEMAVABSADwALwBBAEwARwBJAEQAPgA8AC8AUABSAE8AVABFAEMAVABJAE4ARgBPAD4APABLAEkARAA+ADYAdgBrAFQAcgBlAFkAcgB1AEoAaAAxADkAUQBTAG8ANAA4AHoAcQBaAEEAPQA9ADwALwBLAEkARAA+ADwAQwBIAEUAQwBLAFMAVQBNAD4AagBZAEYATgBmADAAeQBmADQAaQBzAD0APAAvAEMASABFAEMASwBTAFUATQA+ADwATABBAF8AVQBSAEwAPgBoAHQAdABwADoALwAvAHAAbABhAHkAcgBlAGEAZAB5AC4AZABpAHIAZQBjAHQAdABhAHAAcwAuAG4AZQB0AC8AcAByAC8AcwB2AGMALwByAGkAZwBoAHQAcwBtAGEAbgBhAGcAZQByAC4AYQBzAG0AeAA/AFAAbABhAHkAUgBpAGcAaAB0AD0AMQAmAGEAbQBwADsAVQBzAGUAUwBpAG0AcABsAGUATgBvAG4AUABlAHIAcwBpAHMAdABlAG4AdABMAGkAYwBlAG4AcwBlAD0AMQA8AC8ATABBAF8AVQBSAEwAPgA8AC8ARABBAFQAQQA+ADwALwBXAFIATQBIAEUAQQBEAEUAUgA+AA==' } ]
- },
-
- 'mp4-encrypted-clear' : {
- assetId: 'mp4-basic',
- initDataType: 'cenc',
- audio : { type: 'audio/mp4;codecs="mp4a.40.2"',
- path: '/encrypted-media/content/audio_aac-lc_128k_dashinit.mp4' },
- video : { type: 'video/mp4;codecs="avc1.4d401e"',
- path: '/encrypted-media/content/video_512x288_h264-360k_enc_clear_dashinit.mp4' },
- keys : [ { kid: [ 0xad, 0x13, 0xf9, 0xea, 0x2b, 0xe6, 0x98, 0xb8, 0x75, 0xf5, 0x04, 0xa8, 0xe3, 0xcc, 0xea, 0x64 ],
- key: [ 0xbe, 0x7d, 0xf8, 0xa3, 0x66, 0x7a, 0x6a, 0x8f, 0xd5, 0x64, 0xd0, 0xed, 0x81, 0x33, 0x9a, 0x95 ],
- initDataType: 'cenc',
- initData: 'AAAAcXBzc2gAAAAA7e+LqXnWSs6jyCfc1R0h7QAAAFEIARIQrRP56ivmmLh19QSo48zqZBoIY2FzdGxhYnMiKGV5SmhjM05sZEVsa0lqb2laVzFsTFhSbGMzUXRjMmx1WjJ4bEluMD0yB2RlZmF1bHQAAAMacHNzaAAAAACaBPB5mEBChquS5lvgiF+VAAAC+voCAAABAAEA8AI8AFcAUgBNAEgARQBBAEQARQBSACAAeABtAGwAbgBzAD0AIgBoAHQAdABwADoALwAvAHMAYwBoAGUAbQBhAHMALgBtAGkAYwByAG8AcwBvAGYAdAAuAGMAbwBtAC8ARABSAE0ALwAyADAAMAA3AC8AMAAzAC8AUABsAGEAeQBSAGUAYQBkAHkASABlAGEAZABlAHIAIgAgAHYAZQByAHMAaQBvAG4APQAiADQALgAwAC4AMAAuADAAIgA+ADwARABBAFQAQQA+ADwAUABSAE8AVABFAEMAVABJAE4ARgBPAD4APABLAEUAWQBMAEUATgA+ADEANgA8AC8ASwBFAFkATABFAE4APgA8AEEATABHAEkARAA+AEEARQBTAEMAVABSADwALwBBAEwARwBJAEQAPgA8AC8AUABSAE8AVABFAEMAVABJAE4ARgBPAD4APABLAEkARAA+ADYAdgBrAFQAcgBlAFkAcgB1AEoAaAAxADkAUQBTAG8ANAA4AHoAcQBaAEEAPQA9ADwALwBLAEkARAA+ADwAQwBIAEUAQwBLAFMAVQBNAD4AagBZAEYATgBmADAAeQBmADQAaQBzAD0APAAvAEMASABFAEMASwBTAFUATQA+ADwATABBAF8AVQBSAEwAPgBoAHQAdABwADoALwAvAHAAbABhAHkAcgBlAGEAZAB5AC4AZABpAHIAZQBjAHQAdABhAHAAcwAuAG4AZQB0AC8AcAByAC8AcwB2AGMALwByAGkAZwBoAHQAcwBtAGEAbgBhAGcAZQByAC4AYQBzAG0AeAA/AFAAbABhAHkAUgBpAGcAaAB0AD0AMQAmAGEAbQBwADsAVQBzAGUAUwBpAG0AcABsAGUATgBvAG4AUABlAHIAcwBpAHMAdABlAG4AdABMAGkAYwBlAG4AcwBlAD0AMQA8AC8ATABBAF8AVQBSAEwAPgA8AC8ARABBAFQAQQA+ADwALwBXAFIATQBIAEUAQQBEAEUAUgA+AA==' } ]
- },
-
-
- 'mp4-av-multikey' : {
- assetId: 'mp4-basic',
- initDataType: 'cenc',
- associatedInitData: true, // indicates that initData for one key causes other keys to be returned as well
- audio: { type: 'audio/mp4;codecs="mp4a.40.2"',
- path: '/encrypted-media/content/audio_aac-lc_128k_enc_dashinit.mp4' },
- video : { type: 'video/mp4;codecs="avc1.4d401e"',
- path: '/encrypted-media/content/video_512x288_h264-360k_enc_dashinit.mp4' },
- keys : [ { kid: [ 0xad, 0x13, 0xf9, 0xea, 0x2b, 0xe6, 0x98, 0xb8, 0x75, 0xf5, 0x04, 0xa8, 0xe3, 0xcc, 0xea, 0x64 ],
- key: [ 0xbe, 0x7d, 0xf8, 0xa3, 0x66, 0x7a, 0x6a, 0x8f, 0xd5, 0x64, 0xd0, 0xed, 0x81, 0x33, 0x9a, 0x95 ],
- initDataType: 'cenc',
- initData: 'AAAAcXBzc2gAAAAA7e+LqXnWSs6jyCfc1R0h7QAAAFEIARIQrRP56ivmmLh19QSo48zqZBoIY2FzdGxhYnMiKGV5SmhjM05sZEVsa0lqb2laVzFsTFhSbGMzUXRjMmx1WjJ4bEluMD0yB2RlZmF1bHQAAAMacHNzaAAAAACaBPB5mEBChquS5lvgiF+VAAAC+voCAAABAAEA8AI8AFcAUgBNAEgARQBBAEQARQBSACAAeABtAGwAbgBzAD0AIgBoAHQAdABwADoALwAvAHMAYwBoAGUAbQBhAHMALgBtAGkAYwByAG8AcwBvAGYAdAAuAGMAbwBtAC8ARABSAE0ALwAyADAAMAA3AC8AMAAzAC8AUABsAGEAeQBSAGUAYQBkAHkASABlAGEAZABlAHIAIgAgAHYAZQByAHMAaQBvAG4APQAiADQALgAwAC4AMAAuADAAIgA+ADwARABBAFQAQQA+ADwAUABSAE8AVABFAEMAVABJAE4ARgBPAD4APABLAEUAWQBMAEUATgA+ADEANgA8AC8ASwBFAFkATABFAE4APgA8AEEATABHAEkARAA+AEEARQBTAEMAVABSADwALwBBAEwARwBJAEQAPgA8AC8AUABSAE8AVABFAEMAVABJAE4ARgBPAD4APABLAEkARAA+ADYAdgBrAFQAcgBlAFkAcgB1AEoAaAAxADkAUQBTAG8ANAA4AHoAcQBaAEEAPQA9ADwALwBLAEkARAA+ADwAQwBIAEUAQwBLAFMAVQBNAD4AagBZAEYATgBmADAAeQBmADQAaQBzAD0APAAvAEMASABFAEMASwBTAFUATQA+ADwATABBAF8AVQBSAEwAPgBoAHQAdABwADoALwAvAHAAbABhAHkAcgBlAGEAZAB5AC4AZABpAHIAZQBjAHQAdABhAHAAcwAuAG4AZQB0AC8AcAByAC8AcwB2AGMALwByAGkAZwBoAHQAcwBtAGEAbgBhAGcAZQByAC4AYQBzAG0AeAA/AFAAbABhAHkAUgBpAGcAaAB0AD0AMQAmAGEAbQBwADsAVQBzAGUAUwBpAG0AcABsAGUATgBvAG4AUABlAHIAcwBpAHMAdABlAG4AdABMAGkAYwBlAG4AcwBlAD0AMQA8AC8ATABBAF8AVQBSAEwAPgA8AC8ARABBAFQAQQA+ADwALwBXAFIATQBIAEUAQQBEAEUAUgA+AA==' },
- { kid: [ 0x55, 0x8e, 0xe5, 0x41, 0xb9, 0x0a, 0xb2, 0xf3, 0x95, 0x0d, 0x00, 0xad, 0xe3, 0x76, 0x0d, 0x45 ],
- key: [ 0x91, 0x03, 0x92, 0x63, 0x01, 0x6d, 0xa6, 0x35, 0x77, 0x0d, 0x57, 0xdb, 0x92, 0xf9, 0x8b, 0xd0 ],
- initDataType : 'cenc',
- initData: 'AAAAcXBzc2gAAAAA7e+LqXnWSs6jyCfc1R0h7QAAAFEIARIQVY7lQbkKsvOVDQCt43YNRRoIY2FzdGxhYnMiKGV5SmhjM05sZEVsa0lqb2laVzFsTFhSbGMzUXRjMmx1WjJ4bEluMD0yB2RlZmF1bHQAAAMacHNzaAAAAACaBPB5mEBChquS5lvgiF+VAAAC+voCAAABAAEA8AI8AFcAUgBNAEgARQBBAEQARQBSACAAeABtAGwAbgBzAD0AIgBoAHQAdABwADoALwAvAHMAYwBoAGUAbQBhAHMALgBtAGkAYwByAG8AcwBvAGYAdAAuAGMAbwBtAC8ARABSAE0ALwAyADAAMAA3AC8AMAAzAC8AUABsAGEAeQBSAGUAYQBkAHkASABlAGEAZABlAHIAIgAgAHYAZQByAHMAaQBvAG4APQAiADQALgAwAC4AMAAuADAAIgA+ADwARABBAFQAQQA+ADwAUABSAE8AVABFAEMAVABJAE4ARgBPAD4APABLAEUAWQBMAEUATgA+ADEANgA8AC8ASwBFAFkATABFAE4APgA8AEEATABHAEkARAA+AEEARQBTAEMAVABSADwALwBBAEwARwBJAEQAPgA8AC8AUABSAE8AVABFAEMAVABJAE4ARgBPAD4APABLAEkARAA+AFEAZQBXAE8AVgBRAHEANQA4ADcASwBWAEQAUQBDAHQANAAzAFkATgBSAFEAPQA9ADwALwBLAEkARAA+ADwAQwBIAEUAQwBLAFMAVQBNAD4AWQBpAE8ALwAxADYATABzADkANgBFAD0APAAvAEMASABFAEMASwBTAFUATQA+ADwATABBAF8AVQBSAEwAPgBoAHQAdABwADoALwAvAHAAbABhAHkAcgBlAGEAZAB5AC4AZABpAHIAZQBjAHQAdABhAHAAcwAuAG4AZQB0AC8AcAByAC8AcwB2AGMALwByAGkAZwBoAHQAcwBtAGEAbgBhAGcAZQByAC4AYQBzAG0AeAA/AFAAbABhAHkAUgBpAGcAaAB0AD0AMQAmAGEAbQBwADsAVQBzAGUAUwBpAG0AcABsAGUATgBvAG4AUABlAHIAcwBpAHMAdABlAG4AdABMAGkAYwBlAG4AcwBlAD0AMQA8AC8ATABBAF8AVQBSAEwAPgA8AC8ARABBAFQAQQA+ADwALwBXAFIATQBIAEUAQQBEAEUAUgA+AA==' } ]
- },
-
- 'mp4-multikey' : { assetId: 'mp4-multikey',
- initDataType: 'cenc',
- audio: { type: 'audio/mp4;codecs="mp4a.40.2"',
- path: '/encrypted-media/content/audio_aac-lc_128k_2keys_2sess.mp4' },
- video: { type: 'video/mp4;codecs="avc1.4d401e"',
- path: '/encrypted-media/content/video_512x288_h264-360k_enc_2keys_2sess.mp4' },
- keys: [ { kid: [ 0x13, 0xa7, 0x53, 0x06, 0xd1, 0x18, 0x91, 0x7b, 0x47, 0xa6, 0xc1, 0x83, 0x64, 0x42, 0x51, 0x6f ],
- key: [ 0x8a, 0xaa, 0xd8, 0xc4, 0xdb, 0xde, 0xac, 0xcd, 0xad, 0x26, 0x76, 0xa1, 0xed, 0x38, 0x95, 0x2e ],
- variantId: 'key1',
- initDataType: 'cenc',
- initData: 'AAAAjXBzc2gAAAAA7e+LqXnWSs6jyCfc1R0h7QAAAG0IARIQE6dTBtEYkXtHpsGDZEJRbxoIY2FzdGxhYnMiRGV5SmhjM05sZEVsa0lqb2laVzFsTFhSbGMzUXRNbk5sYzNOcGIyNGlMQ0oyWVhKcFlXNTBTV1FpT2lKclpYa3hJbjA9MgdkZWZhdWx0AAADwnBzc2gAAAAAmgTweZhAQoarkuZb4IhflQAAA6KiAwAAAQABAJgDPABXAFIATQBIAEUAQQBEAEUAUgAgAHgAbQBsAG4AcwA9ACIAaAB0AHQAcAA6AC8ALwBzAGMAaABlAG0AYQBzAC4AbQBpAGMAcgBvAHMAbwBmAHQALgBjAG8AbQAvAEQAUgBNAC8AMgAwADAANwAvADAAMwAvAFAAbABhAHkAUgBlAGEAZAB5AEgAZQBhAGQAZQByACIAIAB2AGUAcgBzAGkAbwBuAD0AIgA0AC4AMAAuADAALgAwACIAPgA8AEQAQQBUAEEAPgA8AFAAUgBPAFQARQBDAFQASQBOAEYATwA+ADwASwBFAFkATABFAE4APgAxADYAPAAvAEsARQBZAEwARQBOAD4APABBAEwARwBJAEQAPgBBAEUAUwBDAFQAUgA8AC8AQQBMAEcASQBEAD4APAAvAFAAUgBPAFQARQBDAFQASQBOAEYATwA+ADwASwBJAEQAPgBCAGwATwBuAEUAeABqAFIAZQA1AEYASABwAHMARwBEAFoARQBKAFIAYgB3AD0APQA8AC8ASwBJAEQAPgA8AEwAQQBfAFUAUgBMAD4AaAB0AHQAcABzADoALwAvAGwAaQBjAC4AcwB0AGEAZwBpAG4AZwAuAGQAcgBtAHQAbwBkAGEAeQAuAGMAbwBtAC8AbABpAGMAZQBuAHMAZQAtAHAAcgBvAHgAeQAtAGgAZQBhAGQAZQByAGEAdQB0AGgALwBkAHIAbQB0AG8AZABhAHkALwBSAGkAZwBoAHQAcwBNAGEAbgBhAGcAZQByAC4AYQBzAG0AeAA8AC8ATABBAF8AVQBSAEwAPgA8AEwAVQBJAF8AVQBSAEwAPgBoAHQAdABwAHMAOgAvAC8AbABpAGMALgBzAHQAYQBnAGkAbgBnAC4AZAByAG0AdABvAGQAYQB5AC4AYwBvAG0ALwBsAGkAYwBlAG4AcwBlAC0AcAByAG8AeAB5AC0AaABlAGEAZABlAHIAYQB1AHQAaAAvAGQAcgBtAHQAbwBkAGEAeQAvAFIAaQBnAGgAdABzAE0AYQBuAGEAZwBlAHIALgBhAHMAbQB4ADwALwBMAFUASQBfAFUAUgBMAD4APABDAEgARQBDAEsAUwBVAE0APgBJAEQAUgB0AFAAZwBVAEkALwBiAEkAPQA8AC8AQwBIAEUAQwBLAFMAVQBNAD4APAAvAEQAQQBUAEEAPgA8AC8AVwBSAE0ASABFAEEARABFAFIAPgA=' },
- { kid: [ 0xee, 0x73, 0x56, 0x4e, 0xc8, 0xa8, 0x90, 0xf0, 0x78, 0xef, 0x68, 0x71, 0xfa, 0x4b, 0xe1, 0x8b ],
- key: [ 0xe4, 0x4f, 0xe1, 0x45, 0x7c, 0x5e, 0xbc, 0xd8, 0x3e, 0xad, 0xdc, 0xd6, 0x2c, 0xaf, 0x55, 0x18 ],
- variantId: 'key2',
- initDataType: 'cenc',
- initData: 'AAAAjXBzc2gAAAAA7e+LqXnWSs6jyCfc1R0h7QAAAG0IARIQ7nNWTsiokPB472hx+kvhixoIY2FzdGxhYnMiRGV5SmhjM05sZEVsa0lqb2laVzFsTFhSbGMzUXRNbk5sYzNOcGIyNGlMQ0oyWVhKcFlXNTBTV1FpT2lKclpYa3lJbjA9MgdkZWZhdWx0AAADwnBzc2gAAAAAmgTweZhAQoarkuZb4IhflQAAA6KiAwAAAQABAJgDPABXAFIATQBIAEUAQQBEAEUAUgAgAHgAbQBsAG4AcwA9ACIAaAB0AHQAcAA6AC8ALwBzAGMAaABlAG0AYQBzAC4AbQBpAGMAcgBvAHMAbwBmAHQALgBjAG8AbQAvAEQAUgBNAC8AMgAwADAANwAvADAAMwAvAFAAbABhAHkAUgBlAGEAZAB5AEgAZQBhAGQAZQByACIAIAB2AGUAcgBzAGkAbwBuAD0AIgA0AC4AMAAuADAALgAwACIAPgA8AEQAQQBUAEEAPgA8AFAAUgBPAFQARQBDAFQASQBOAEYATwA+ADwASwBFAFkATABFAE4APgAxADYAPAAvAEsARQBZAEwARQBOAD4APABBAEwARwBJAEQAPgBBAEUAUwBDAFQAUgA8AC8AQQBMAEcASQBEAD4APAAvAFAAUgBPAFQARQBDAFQASQBOAEYATwA+ADwASwBJAEQAPgBUAGwAWgB6ADcAcQBqAEkAOABKAEIANAA3ADIAaAB4ACsAawB2AGgAaQB3AD0APQA8AC8ASwBJAEQAPgA8AEwAQQBfAFUAUgBMAD4AaAB0AHQAcABzADoALwAvAGwAaQBjAC4AcwB0AGEAZwBpAG4AZwAuAGQAcgBtAHQAbwBkAGEAeQAuAGMAbwBtAC8AbABpAGMAZQBuAHMAZQAtAHAAcgBvAHgAeQAtAGgAZQBhAGQAZQByAGEAdQB0AGgALwBkAHIAbQB0AG8AZABhAHkALwBSAGkAZwBoAHQAcwBNAGEAbgBhAGcAZQByAC4AYQBzAG0AeAA8AC8ATABBAF8AVQBSAEwAPgA8AEwAVQBJAF8AVQBSAEwAPgBoAHQAdABwAHMAOgAvAC8AbABpAGMALgBzAHQAYQBnAGkAbgBnAC4AZAByAG0AdABvAGQAYQB5AC4AYwBvAG0ALwBsAGkAYwBlAG4AcwBlAC0AcAByAG8AeAB5AC0AaABlAGEAZABlAHIAYQB1AHQAaAAvAGQAcgBtAHQAbwBkAGEAeQAvAFIAaQBnAGgAdABzAE0AYQBuAGEAZwBlAHIALgBhAHMAbQB4ADwALwBMAFUASQBfAFUAUgBMAD4APABDAEgARQBDAEsAUwBVAE0APgB4AEQASwBBAFkAMAB2AFoAaABVAFUAPQA8AC8AQwBIAEUAQwBLAFMAVQBNAD4APAAvAEQAQQBUAEEAPgA8AC8AVwBSAE0ASABFAEEARABFAFIAPgA=' } ] },
-
- 'mp4-basic-key1' : { assetId: 'mp4-multikey-sequential',
- variantId: 'key1',
- initDataType: 'cenc',
- audio: { type: 'audio/mp4;codecs="mp4a.40.2"',
- path: '/encrypted-media/content/audio_aac-lc_128k_dashinit.mp4' },
- video: { type: 'video/mp4;codecs="avc1.4d401e"',
- path: '/encrypted-media/content/video_512x288_h264-360k_multikey_key1_dashinit.mp4' },
- keys: [ { kid: [0x8a, 0x0d, 0x85, 0x45, 0x21, 0x05, 0xd4, 0x15, 0x35, 0x8f, 0xea, 0x8f, 0x68, 0xe6, 0xc1, 0x91],
- key: [0x76, 0x6f, 0xab, 0xc1, 0x68, 0x3f, 0xf8, 0xef, 0x4e, 0x76, 0x00, 0x24, 0xc5, 0x23, 0x8f, 0x10],
- initDataType: 'cenc',
- initData: 'AAAAlXBzc2gAAAAA7e+LqXnWSs6jyCfc1R0h7QAAAHUIARIQig2FRSEF1BU1j+qPaObBkRoIY2FzdGxhYnMiTGV5SmhjM05sZEVsa0lqb2liWEEwTFcxMWJIUnBhMlY1TFhObGNYVmxiblJwWVd3aUxDSjJZWEpwWVc1MFNXUWlPaUpyWlhreEluMD0yB2RlZmF1bHQAAANYcHNzaAAAAACaBPB5mEBChquS5lvgiF+VAAADODgDAAABAAEALgM8AFcAUgBNAEgARQBBAEQARQBSACAAeABtAGwAbgBzAD0AIgBoAHQAdABwADoALwAvAHMAYwBoAGUAbQBhAHMALgBtAGkAYwByAG8AcwBvAGYAdAAuAGMAbwBtAC8ARABSAE0ALwAyADAAMAA3AC8AMAAzAC8AUABsAGEAeQBSAGUAYQBkAHkASABlAGEAZABlAHIAIgAgAHYAZQByAHMAaQBvAG4APQAiADQALgAwAC4AMAAuADAAIgA+ADwARABBAFQAQQA+ADwAUABSAE8AVABFAEMAVABJAE4ARgBPAD4APABLAEUAWQBMAEUATgA+ADEANgA8AC8ASwBFAFkATABFAE4APgA8AEEATABHAEkARAA+AEEARQBTAEMAVABSADwALwBBAEwARwBJAEQAPgA8AC8AUABSAE8AVABFAEMAVABJAE4ARgBPAD4APABLAEkARAA+AFIAWQBVAE4AaQBnAFUAaABGAGQAUQAxAGoAKwBxAFAAYQBPAGIAQgBrAFEAPQA9ADwALwBLAEkARAA+ADwATABBAF8AVQBSAEwAPgBoAHQAdABwAHMAOgAvAC8AbABpAGMALgBzAHQAYQBnAGkAbgBnAC4AZAByAG0AdABvAGQAYQB5AC4AYwBvAG0ALwBsAGkAYwBlAG4AcwBlAC0AcAByAG8AeAB5AC0AaABlAGEAZABlAHIAYQB1AHQAaAAvAGQAcgBtAHQAbwBkAGEAeQAvAFIAaQBnAGgAdABzAE0AYQBuAGEAZwBlAHIALgBhAHMAbQB4ADwALwBMAEEAXwBVAFIATAA+ADwATABVAEkAXwBVAFIATAA+AGgAdAB0AHAAcwA6AC8ALwBwAGwAYQB5AHIAZQBhAGQAeQAtAHUAaQAuAGUAeABhAG0AcABsAGUALgBjAG8AbQA8AC8ATABVAEkAXwBVAFIATAA+ADwAQwBIAEUAQwBLAFMAVQBNAD4AcQBOAEkAZQBiAFQAWABzAG8AcgBnAD0APAAvAEMASABFAEMASwBTAFUATQA+ADwALwBEAEEAVABBAD4APAAvAFcAUgBNAEgARQBBAEQARQBSAD4A' } ]
- },
- 'mp4-basic-key2' : { assetId: 'mp4-multikey-sequential',
- variantId: 'key2',
- initDataType: 'cenc',
- audio: { type: 'audio/mp4;codecs="mp4a.40.2"',
- path: '/encrypted-media/content/audio_aac-lc_128k_dashinit.mp4' },
- video: { type: 'video/mp4;codecs="avc1.4d401e"',
- path: '/encrypted-media/content/video_512x288_h264-360k_multikey_key2_dashinit.mp4' },
- keys: [ { kid: [0xfb, 0xb4, 0xb7, 0xf3, 0x4a, 0xbd, 0x31, 0x87, 0x34, 0x4b, 0xce, 0xc4, 0x5f, 0x96, 0x68, 0x88],
- key: [0x26, 0x52, 0xc3, 0x1d, 0xf7, 0x92, 0xd1, 0x7b, 0x08, 0xa6, 0xfa, 0xd3, 0x7c, 0xb6, 0x25, 0x60],
- initDataType: 'cenc',
- initData: 'AAAAlXBzc2gAAAAA7e+LqXnWSs6jyCfc1R0h7QAAAHUIARIQ+7S380q9MYc0S87EX5ZoiBoIY2FzdGxhYnMiTGV5SmhjM05sZEVsa0lqb2liWEEwTFcxMWJIUnBhMlY1TFhObGNYVmxiblJwWVd3aUxDSjJZWEpwWVc1MFNXUWlPaUpyWlhreUluMD0yB2RlZmF1bHQAAANYcHNzaAAAAACaBPB5mEBChquS5lvgiF+VAAADODgDAAABAAEALgM8AFcAUgBNAEgARQBBAEQARQBSACAAeABtAGwAbgBzAD0AIgBoAHQAdABwADoALwAvAHMAYwBoAGUAbQBhAHMALgBtAGkAYwByAG8AcwBvAGYAdAAuAGMAbwBtAC8ARABSAE0ALwAyADAAMAA3AC8AMAAzAC8AUABsAGEAeQBSAGUAYQBkAHkASABlAGEAZABlAHIAIgAgAHYAZQByAHMAaQBvAG4APQAiADQALgAwAC4AMAAuADAAIgA+ADwARABBAFQAQQA+ADwAUABSAE8AVABFAEMAVABJAE4ARgBPAD4APABLAEUAWQBMAEUATgA+ADEANgA8AC8ASwBFAFkATABFAE4APgA8AEEATABHAEkARAA+AEEARQBTAEMAVABSADwALwBBAEwARwBJAEQAPgA8AC8AUABSAE8AVABFAEMAVABJAE4ARgBPAD4APABLAEkARAA+ADgANwBlADAAKwA3ADEASwBoAHoARQAwAFMAOAA3AEUAWAA1AFoAbwBpAEEAPQA9ADwALwBLAEkARAA+ADwATABBAF8AVQBSAEwAPgBoAHQAdABwAHMAOgAvAC8AbABpAGMALgBzAHQAYQBnAGkAbgBnAC4AZAByAG0AdABvAGQAYQB5AC4AYwBvAG0ALwBsAGkAYwBlAG4AcwBlAC0AcAByAG8AeAB5AC0AaABlAGEAZABlAHIAYQB1AHQAaAAvAGQAcgBtAHQAbwBkAGEAeQAvAFIAaQBnAGgAdABzAE0AYQBuAGEAZwBlAHIALgBhAHMAbQB4ADwALwBMAEEAXwBVAFIATAA+ADwATABVAEkAXwBVAFIATAA+AGgAdAB0AHAAcwA6AC8ALwBwAGwAYQB5AHIAZQBhAGQAeQAtAHUAaQAuAGUAeABhAG0AcABsAGUALgBjAG8AbQA8AC8ATABVAEkAXwBVAFIATAA+ADwAQwBIAEUAQwBLAFMAVQBNAD4ARgB0AGkASQBoADYAUwBKAG0AcABZAD0APAAvAEMASABFAEMASwBTAFUATQA+ADwALwBEAEEAVABBAD4APAAvAFcAUgBNAEgARQBBAEQARQBSAD4A' } ] },
-
- 'mp4-multikey-sequential' : { assetId: 'mp4-multikey-sequential',
- initDataType: 'cenc',
- audio: { type: 'audio/mp4;codecs="mp4a.40.2"',
- path: '/encrypted-media/content/audio_aac-lc_128k_dashinit.mp4' },
- video: { type: 'video/mp4;codecs="avc1.4d401e"',
- path: '/encrypted-media/content/video_512x288_h264-360k_multikey_dashinit.mp4' },
- keys: [ { kid: [0x8a, 0x0d, 0x85, 0x45, 0x21, 0x05, 0xd4, 0x15, 0x35, 0x8f, 0xea, 0x8f, 0x68, 0xe6, 0xc1, 0x91],
- key: [0x76, 0x6f, 0xab, 0xc1, 0x68, 0x3f, 0xf8, 0xef, 0x4e, 0x76, 0x00, 0x24, 0xc5, 0x23, 0x8f, 0x10],
- variantId: 'key1',
- initDataType: 'cenc',
- initData: 'AAAAlXBzc2gAAAAA7e+LqXnWSs6jyCfc1R0h7QAAAHUIARIQig2FRSEF1BU1j+qPaObBkRoIY2FzdGxhYnMiTGV5SmhjM05sZEVsa0lqb2liWEEwTFcxMWJIUnBhMlY1TFhObGNYVmxiblJwWVd3aUxDSjJZWEpwWVc1MFNXUWlPaUpyWlhreEluMD0yB2RlZmF1bHQAAANYcHNzaAAAAACaBPB5mEBChquS5lvgiF+VAAADODgDAAABAAEALgM8AFcAUgBNAEgARQBBAEQARQBSACAAeABtAGwAbgBzAD0AIgBoAHQAdABwADoALwAvAHMAYwBoAGUAbQBhAHMALgBtAGkAYwByAG8AcwBvAGYAdAAuAGMAbwBtAC8ARABSAE0ALwAyADAAMAA3AC8AMAAzAC8AUABsAGEAeQBSAGUAYQBkAHkASABlAGEAZABlAHIAIgAgAHYAZQByAHMAaQBvAG4APQAiADQALgAwAC4AMAAuADAAIgA+ADwARABBAFQAQQA+ADwAUABSAE8AVABFAEMAVABJAE4ARgBPAD4APABLAEUAWQBMAEUATgA+ADEANgA8AC8ASwBFAFkATABFAE4APgA8AEEATABHAEkARAA+AEEARQBTAEMAVABSADwALwBBAEwARwBJAEQAPgA8AC8AUABSAE8AVABFAEMAVABJAE4ARgBPAD4APABLAEkARAA+AFIAWQBVAE4AaQBnAFUAaABGAGQAUQAxAGoAKwBxAFAAYQBPAGIAQgBrAFEAPQA9ADwALwBLAEkARAA+ADwATABBAF8AVQBSAEwAPgBoAHQAdABwAHMAOgAvAC8AbABpAGMALgBzAHQAYQBnAGkAbgBnAC4AZAByAG0AdABvAGQAYQB5AC4AYwBvAG0ALwBsAGkAYwBlAG4AcwBlAC0AcAByAG8AeAB5AC0AaABlAGEAZABlAHIAYQB1AHQAaAAvAGQAcgBtAHQAbwBkAGEAeQAvAFIAaQBnAGgAdABzAE0AYQBuAGEAZwBlAHIALgBhAHMAbQB4ADwALwBMAEEAXwBVAFIATAA+ADwATABVAEkAXwBVAFIATAA+AGgAdAB0AHAAcwA6AC8ALwBwAGwAYQB5AHIAZQBhAGQAeQAtAHUAaQAuAGUAeABhAG0AcABsAGUALgBjAG8AbQA8AC8ATABVAEkAXwBVAFIATAA+ADwAQwBIAEUAQwBLAFMAVQBNAD4AcQBOAEkAZQBiAFQAWABzAG8AcgBnAD0APAAvAEMASABFAEMASwBTAFUATQA+ADwALwBEAEEAVABBAD4APAAvAFcAUgBNAEgARQBBAEQARQBSAD4A' },
- { kid: [0xfb, 0xb4, 0xb7, 0xf3, 0x4a, 0xbd, 0x31, 0x87, 0x34, 0x4b, 0xce, 0xc4, 0x5f, 0x96, 0x68, 0x88],
- key: [0x26, 0x52, 0xc3, 0x1d, 0xf7, 0x92, 0xd1, 0x7b, 0x08, 0xa6, 0xfa, 0xd3, 0x7c, 0xb6, 0x25, 0x60],
- variantId: 'key2',
- initDataType: 'cenc',
- initData: 'AAAAlXBzc2gAAAAA7e+LqXnWSs6jyCfc1R0h7QAAAHUIARIQ+7S380q9MYc0S87EX5ZoiBoIY2FzdGxhYnMiTGV5SmhjM05sZEVsa0lqb2liWEEwTFcxMWJIUnBhMlY1TFhObGNYVmxiblJwWVd3aUxDSjJZWEpwWVc1MFNXUWlPaUpyWlhreUluMD0yB2RlZmF1bHQAAANYcHNzaAAAAACaBPB5mEBChquS5lvgiF+VAAADODgDAAABAAEALgM8AFcAUgBNAEgARQBBAEQARQBSACAAeABtAGwAbgBzAD0AIgBoAHQAdABwADoALwAvAHMAYwBoAGUAbQBhAHMALgBtAGkAYwByAG8AcwBvAGYAdAAuAGMAbwBtAC8ARABSAE0ALwAyADAAMAA3AC8AMAAzAC8AUABsAGEAeQBSAGUAYQBkAHkASABlAGEAZABlAHIAIgAgAHYAZQByAHMAaQBvAG4APQAiADQALgAwAC4AMAAuADAAIgA+ADwARABBAFQAQQA+ADwAUABSAE8AVABFAEMAVABJAE4ARgBPAD4APABLAEUAWQBMAEUATgA+ADEANgA8AC8ASwBFAFkATABFAE4APgA8AEEATABHAEkARAA+AEEARQBTAEMAVABSADwALwBBAEwARwBJAEQAPgA8AC8AUABSAE8AVABFAEMAVABJAE4ARgBPAD4APABLAEkARAA+ADgANwBlADAAKwA3ADEASwBoAHoARQAwAFMAOAA3AEUAWAA1AFoAbwBpAEEAPQA9ADwALwBLAEkARAA+ADwATABBAF8AVQBSAEwAPgBoAHQAdABwAHMAOgAvAC8AbABpAGMALgBzAHQAYQBnAGkAbgBnAC4AZAByAG0AdABvAGQAYQB5AC4AYwBvAG0ALwBsAGkAYwBlAG4AcwBlAC0AcAByAG8AeAB5AC0AaABlAGEAZABlAHIAYQB1AHQAaAAvAGQAcgBtAHQAbwBkAGEAeQAvAFIAaQBnAGgAdABzAE0AYQBuAGEAZwBlAHIALgBhAHMAbQB4ADwALwBMAEEAXwBVAFIATAA+ADwATABVAEkAXwBVAFIATAA+AGgAdAB0AHAAcwA6AC8ALwBwAGwAYQB5AHIAZQBhAGQAeQAtAHUAaQAuAGUAeABhAG0AcABsAGUALgBjAG8AbQA8AC8ATABVAEkAXwBVAFIATAA+ADwAQwBIAEUAQwBLAFMAVQBNAD4ARgB0AGkASQBoADYAUwBKAG0AcABZAD0APAAvAEMASABFAEMASwBTAFUATQA+ADwALwBEAEEAVABBAD4APAAvAFcAUgBNAEgARQBBAEQARQBSAD4A' } ] },
-
- 'webm' : { audio : { type: 'audio/webm; codecs="opus"' },
- video : { type: 'video/webm; codecs="vp8"',
- path: '/encrypted-media/content/test-encrypted.webm' },
- keys : [ { kid: [48,49,50,51,52,53,54,55,56,57,48,49,50,51,52,53],
- key: [0xeb, 0xdd, 0x62, 0xf1, 0x68, 0x14, 0xd2, 0x7b,
- 0x68, 0xef, 0x12, 0x2a, 0xfc, 0xe4, 0xae, 0x3c ] } ]
- },
- 'webm-multikey' :
- { audio : { type: 'audio/webm; codecs="opus"' },
- video : { type: 'video/webm; codecs="vp8"',
- path: '/encrypted-media/content/test-encrypted-different-av-keys.webm' },
- keys : [ { kid: [48,49,50,51,52,53,54,55,56,57,48,49,50,51,52,53],
- key: [ 0x7A, 0x7A, 0x62, 0xF1, 0x68, 0x14, 0xD2, 0x7B,
- 0x68, 0xEF, 0x12, 0x2A, 0xFC, 0xE4, 0xAE, 0x0A ] },
- { kid: [49,50,51,52,53,54,55,56,57,48,49,50,51,52,53,54],
- key: [ 0x30, 0x30, 0x62, 0xF1, 0x68, 0x14, 0xD2, 0x7B,
- 0x68, 0xEF, 0x12, 0x2A, 0xFC, 0xE4, 0xAE, 0x0A ] } ]
- },
-} );
-
-function addMemberListToObject( o )
-{
- var items = [ ];
- for( var item in o )
- {
- if ( !o.hasOwnProperty( item ) ) continue;
-
- o[item].name = item;
- items.push( o[item] );
- }
-
- o._items = items;
-
- return o;
-}
-
-function getInitData( contentitem, initDataType )
-{
- if (initDataType == 'webm') {
- return new Uint8Array( contentitem.keys[ 0 ].kid ); // WebM initData supports only a single key
- }
-
- if (initDataType == 'cenc') {
-
- var size = 36 + contentitem.keys.length * 16,
- kids = contentitem.keys.map( function( k ) { return k.kid; } );
-
- return new Uint8Array(Array.prototype.concat.call( [
- 0x00, 0x00, size / 256, size % 256, // size
- 0x70, 0x73, 0x73, 0x68, // 'pssh'
- 0x01, // version = 1
- 0x00, 0x00, 0x00, // flags
- 0x10, 0x77, 0xEF, 0xEC, 0xC0, 0xB2, 0x4D, 0x02, // Common SystemID
- 0xAC, 0xE3, 0x3C, 0x1E, 0x52, 0xE2, 0xFB, 0x4B,
- 0x00, 0x00, 0x00, kids.length ], // key count ]
- Array.prototype.concat.apply( [], kids ),
- [ 0x00, 0x00, 0x00, 0x00 ]// datasize
- ));
- }
- if (initDataType == 'keyids') {
-
- return toUtf8( { kids: contentitem.keys.map( function( k ) { return base64urlEncode( new Uint8Array( k.kid ) ); } ) } );
- }
- throw 'initDataType ' + initDataType + ' not supported.';
-}
-
-function getSingleKeyInitData( kid, initDataType )
-{
- if (initDataType == 'webm') {
- return new Uint8Array( kid );
- }
-
- if (initDataType == 'cenc') {
-
- var size = 52;
-
- return new Uint8Array(Array.prototype.concat.call( [
- 0x00, 0x00, size / 256, size % 256, // size
- 0x70, 0x73, 0x73, 0x68, // 'pssh'
- 0x01, // version = 1
- 0x00, 0x00, 0x00, // flags
- 0x10, 0x77, 0xEF, 0xEC, 0xC0, 0xB2, 0x4D, 0x02, // Common SystemID
- 0xAC, 0xE3, 0x3C, 0x1E, 0x52, 0xE2, 0xFB, 0x4B,
- 0x00, 0x00, 0x00, 0x01 ], // key count ]
- kid,
- [ 0x00, 0x00, 0x00, 0x00 ]// datasize
- ));
- }
- if (initDataType == 'keyids') {
-
- return toUtf8( { kids: [ base64urlEncode( new Uint8Array( kid ) ) ] } );
- }
- throw 'initDataType ' + initDataType + ' not supported.';
-}
-
-function getMultikeyInitDatas( contentitem, initDataType )
-{
- return contentitem.keys.map( function( k ) { return getSingleKeyInitData( k.kid, initDataType ); } );
-}
-
-function getProprietaryInitDatas( contentitem )
-{
- var keysWithInitData = contentitem.keys.filter( function( k ) { return k.initData; } );
- return { initDataType: contentitem.initDataType,
- initDatas : keysWithInitData.map( function( k ) { return k.initData; } ),
- variantIds: keysWithInitData.map( function( k ) { return k.variantId; } )
- };
-}
-
-// Returns a promise that resolves to the following object
-// { supported: boolean, // whether the content is supported at all
-// content: <the content item>, // the content item description
-// initDataTypes: <list of initDataTypes>
-// }
-//
-// Note: we test initData types one at a time since some versions of Edge don't support testing several at once
-//
-function isContentSupportedForInitDataTypes( keysystem, initDataTypes, contentitem )
-{
- return Promise.all( initDataTypes.map( function( initDataType ) {
- var configuration = { initDataTypes : [ initDataType ],
- audioCapabilities: [ { contentType: contentitem.audio.type } ],
- videoCapabilities: [ { contentType: contentitem.video.type } ]
- };
- return navigator.requestMediaKeySystemAccess( keysystem, [ configuration ] ).then( function( access ) {
- return { supported: true, initDataType: access.getConfiguration().initDataTypes[ 0 ] };
- }, function() {
- return { supported: false };
- } );
- } ) ).then( function( results ) {
-
- var initDataTypes = results.filter( function( result ) { return result.supported; } )
- .map( function( result ) { return result.initDataType; } );
-
- return initDataTypes.length > 0 ?
- { content: contentitem, supported: true, initDataTypes: initDataTypes }
- : { content: contentitem, supported: false };
- } );
-}
-
-// Returns a promise that resolves to { content:, supported:, initDataTypes: } object
-function isContentSupported( keysystem, contentitem )
-{
- return isContentSupportedForInitDataTypes( keysystem, [ 'cenc', 'webm', 'keyids' ], contentitem );
-}
-
-// Returns a Promise resolving to an array of supported content for the key system
-function getSupportedContent( keysystem )
-{
- return Promise.all( content._items.map( isContentSupported.bind( null, keysystem ) ) ).
- then( function( results )
- {
- return results.filter( function( r ) { return r.supported; } ).map( function( r ) { return r.content; } );
- } );
-}
-
-// Returns a Promise resolving to an array of { content:, initDataType: } pairs for the key system
-function getSupportedContentAndInitDataTypes( keysystem )
-{
- return Promise.all( content._items.map( isContentSupported.bind( null, keysystem ) ) ).
- then( function( results )
- {
- return results.filter( function( r ) { return r.supported; } );
- } );
-}
-
-// gets a configuration object for provided piece of content
-function getSimpleConfigurationForContent( contentitem )
-{
- return { initDataTypes: [ 'keyids', 'webm', 'cenc' ],
- audioCapabilities: [ { contentType: contentitem.audio.type } ],
- videoCapabilities: [ { contentType: contentitem.video.type } ] };
-}
diff --git a/testing/web-platform/tests/encrypted-media/content/video_512x288_h264-360k_clear_dashinit.mp4 b/testing/web-platform/tests/encrypted-media/content/video_512x288_h264-360k_clear_dashinit.mp4
deleted file mode 100644
index 33ac63f6b..000000000
--- a/testing/web-platform/tests/encrypted-media/content/video_512x288_h264-360k_clear_dashinit.mp4
+++ /dev/null
Binary files differ
diff --git a/testing/web-platform/tests/encrypted-media/content/video_512x288_h264-360k_clear_enc_dashinit.mp4 b/testing/web-platform/tests/encrypted-media/content/video_512x288_h264-360k_clear_enc_dashinit.mp4
deleted file mode 100644
index dca23449a..000000000
--- a/testing/web-platform/tests/encrypted-media/content/video_512x288_h264-360k_clear_enc_dashinit.mp4
+++ /dev/null
Binary files differ
diff --git a/testing/web-platform/tests/encrypted-media/content/video_512x288_h264-360k_dashinit.mp4 b/testing/web-platform/tests/encrypted-media/content/video_512x288_h264-360k_dashinit.mp4
deleted file mode 100644
index 53a461e8a..000000000
--- a/testing/web-platform/tests/encrypted-media/content/video_512x288_h264-360k_dashinit.mp4
+++ /dev/null
Binary files differ
diff --git a/testing/web-platform/tests/encrypted-media/content/video_512x288_h264-360k_enc_2keys_2sess.mp4 b/testing/web-platform/tests/encrypted-media/content/video_512x288_h264-360k_enc_2keys_2sess.mp4
deleted file mode 100644
index f59284cfe..000000000
--- a/testing/web-platform/tests/encrypted-media/content/video_512x288_h264-360k_enc_2keys_2sess.mp4
+++ /dev/null
Binary files differ
diff --git a/testing/web-platform/tests/encrypted-media/content/video_512x288_h264-360k_enc_clear_dashinit.mp4 b/testing/web-platform/tests/encrypted-media/content/video_512x288_h264-360k_enc_clear_dashinit.mp4
deleted file mode 100644
index d837ac650..000000000
--- a/testing/web-platform/tests/encrypted-media/content/video_512x288_h264-360k_enc_clear_dashinit.mp4
+++ /dev/null
Binary files differ
diff --git a/testing/web-platform/tests/encrypted-media/content/video_512x288_h264-360k_enc_dashinit.mp4 b/testing/web-platform/tests/encrypted-media/content/video_512x288_h264-360k_enc_dashinit.mp4
deleted file mode 100644
index 156a799a9..000000000
--- a/testing/web-platform/tests/encrypted-media/content/video_512x288_h264-360k_enc_dashinit.mp4
+++ /dev/null
Binary files differ
diff --git a/testing/web-platform/tests/encrypted-media/content/video_512x288_h264-360k_multikey_dashinit.mp4 b/testing/web-platform/tests/encrypted-media/content/video_512x288_h264-360k_multikey_dashinit.mp4
deleted file mode 100644
index 659a61cdc..000000000
--- a/testing/web-platform/tests/encrypted-media/content/video_512x288_h264-360k_multikey_dashinit.mp4
+++ /dev/null
Binary files differ
diff --git a/testing/web-platform/tests/encrypted-media/content/video_512x288_h264-360k_multikey_key1_dashinit.mp4 b/testing/web-platform/tests/encrypted-media/content/video_512x288_h264-360k_multikey_key1_dashinit.mp4
deleted file mode 100644
index e69de29bb..000000000
--- a/testing/web-platform/tests/encrypted-media/content/video_512x288_h264-360k_multikey_key1_dashinit.mp4
+++ /dev/null
diff --git a/testing/web-platform/tests/encrypted-media/content/video_512x288_h264-360k_multikey_key2_dashinit.mp4 b/testing/web-platform/tests/encrypted-media/content/video_512x288_h264-360k_multikey_key2_dashinit.mp4
deleted file mode 100644
index 0b9b457a6..000000000
--- a/testing/web-platform/tests/encrypted-media/content/video_512x288_h264-360k_multikey_key2_dashinit.mp4
+++ /dev/null
Binary files differ
diff --git a/testing/web-platform/tests/encrypted-media/drm-check-initdata-type.html b/testing/web-platform/tests/encrypted-media/drm-check-initdata-type.html
deleted file mode 100644
index 6b3324027..000000000
--- a/testing/web-platform/tests/encrypted-media/drm-check-initdata-type.html
+++ /dev/null
@@ -1,32 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <title>Encrypted Media Extensions: Successful Playback, Temporary session with DRM, mp4</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
-
- <!-- Content metadata -->
- <!--<script src=/encrypted-media/content/content-metadata.js></script>-->
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/check-initdata-type.js></script>
-
- </head>
- <body>
- <div id='log'></div>
-
- <script>
- var config = { keysystem: getSupportedKeySystem() }
-
- runTest(config);
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/drm-events-session-closed-event.html b/testing/web-platform/tests/encrypted-media/drm-events-session-closed-event.html
deleted file mode 100644
index 425d17646..000000000
--- a/testing/web-platform/tests/encrypted-media/drm-events-session-closed-event.html
+++ /dev/null
@@ -1,39 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <title>Encrypted Media Extensions - Test MediaKeySession closed event with DRM, mp4</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
-
- <!-- Content metadata -->
- <script src=/encrypted-media/content/content-metadata.js></script>
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/events-session-closed-event.js></script>
-
- </head>
- <body>
- <div id='log'></div>
-
- <script>
- var keysystem = getSupportedKeySystem(),
- contentItem = content['mp4-basic'],
- config = {
- keysystem: keysystem,
- content: contentItem,
- initDataType: contentItem.initDataType,
- audioType: contentItem.audio.type,
- videoType: contentItem.video.type
- };
- runTest(config);
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/drm-events.html b/testing/web-platform/tests/encrypted-media/drm-events.html
deleted file mode 100644
index 880376d60..000000000
--- a/testing/web-platform/tests/encrypted-media/drm-events.html
+++ /dev/null
@@ -1,71 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <title>Encrypted Media Extensions: Events with DRM</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
- <script src=/encrypted-media/util/testmediasource.js></script>
-
- <!-- Content metadata -->
- <script src=/encrypted-media/content/content-metadata.js></script>
-
- <!-- Message handler for DRM servers -->
- <script src=/encrypted-media/util/drm-messagehandler.js></script>
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/events.js></script>
-
- </head>
- <body>
- <div id='log'></div>
-
- <script>
- var keysystem = getSupportedKeySystem();
-
- getSupportedContentAndInitDataTypes( keysystem )
- .then( function( supported )
- {
- // This test requires initData for supported content.
- // We prefer explciit initData configured for the content, but
- // otherwise we will generate initData for a supported initDataType
- // FIXME: Move me to a utility function
- var content,
- initDataType,
- initData;
-
- var contentWithExplicitInitData = supported.filter( function( s ) { return s.content.keys && s.content.initDataType; } );
- if ( contentWithExplicitInitData.length > 0 )
- {
- content = contentWithExplicitInitData[ 0 ].content;
- initDataType = content.keys[ 0 ].initDataType;
- initData = base64DecodeToUnit8Array( content.keys[ 0 ].initData );
- }
- else
- {
- content = supported[ 0 ].content;
- initDataType = supported[ 0 ].initDataTypes[ 0 ];
- initData = getInitData( content, initDataType );
- }
-
- var handler = new MessageHandler( keysystem, content );
-
- runTest( { keysystem: keysystem,
- content: content,
- messagehandler: handler.messagehandler,
- initDataType: initDataType,
- initData: initData
- } );
- } );
-
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/drm-expiration.html b/testing/web-platform/tests/encrypted-media/drm-expiration.html
deleted file mode 100644
index 6dec51147..000000000
--- a/testing/web-platform/tests/encrypted-media/drm-expiration.html
+++ /dev/null
@@ -1,67 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <title>Encrypted Media Extensions: Expiration with DRM</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
- <script src=/encrypted-media/util/testmediasource.js></script>
-
- <!-- Content metadata -->
- <script src=/encrypted-media/content/content-metadata.js></script>
-
- <!-- Message handler for DRM servers -->
- <script src=/encrypted-media/util/drm-messagehandler.js></script>
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/expiration.js></script>
-
- </head>
- <body>
- <div id='log'></div>
-
- <script>
- var keysystem = getSupportedKeySystem();
-
- getSupportedContentAndInitDataTypes( keysystem ).then( function( supported ) {
- // This test requires initData for supported content.
- // We prefer explicit initData configured for the content, but
- // otherwise we will generate initData for a supported initDataType
- // FIXME: Move me to a utility function
- var content,
- initDataType,
- initData;
-
- var contentWithExplicitInitData = supported.filter( function( s ) { return s.content.initDataType && s.content.keys; } );
- if ( contentWithExplicitInitData.length > 0 ) {
- content = contentWithExplicitInitData[ 0 ].content;
- initDataType = content.keys[ 0 ].initDataType;
- initData = base64DecodeToUnit8Array( content.keys[ 0 ].initData );
- } else {
- content = supported[ 0 ].content;
- initDataType = supported[ 0 ].initDataTypes[ 0 ];
- initData = getInitData( content, initDataType );
- }
-
- var handler = new MessageHandler( keysystem, content );
-
- runTest( { keysystem: keysystem,
- content: content,
- messagehandler: handler.messagehandler,
- initDataType: initDataType,
- initData: initData,
- expiration: Date.now().valueOf() + 120000 // Two minutes from now
- } );
- } );
-
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/drm-generate-request-disallowed-input.html b/testing/web-platform/tests/encrypted-media/drm-generate-request-disallowed-input.html
deleted file mode 100644
index 70c46edc7..000000000
--- a/testing/web-platform/tests/encrypted-media/drm-generate-request-disallowed-input.html
+++ /dev/null
@@ -1,32 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <title>Encrypted Media Extensions: Test handling of invalid initData for generateRequest()</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/generate-request-disallowed-input.js></script>
-
- </head>
- <body>
- <div id='log'></div>
-
- <script>
- var config = { keysystem: getSupportedKeySystem()
- };
-
- runTest(config);
-
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/drm-invalid-license.html b/testing/web-platform/tests/encrypted-media/drm-invalid-license.html
deleted file mode 100644
index 9584f499c..000000000
--- a/testing/web-platform/tests/encrypted-media/drm-invalid-license.html
+++ /dev/null
@@ -1,32 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <title>Encrypted Media Extensions: Test handling of invalid DRM license</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/invalid-license.js></script>
-
- </head>
- <body>
- <div id='log'></div>
-
- <script>
- var keysystem = getSupportedKeySystem(),
- config = {
- keysystem: keysystem
- };
- runTest(config);
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/drm-keystatuses-multiple-sessions.html b/testing/web-platform/tests/encrypted-media/drm-keystatuses-multiple-sessions.html
deleted file mode 100644
index 8ef745c4f..000000000
--- a/testing/web-platform/tests/encrypted-media/drm-keystatuses-multiple-sessions.html
+++ /dev/null
@@ -1,55 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <title>Encrypted Media Extensions: Successful Playback, Temporary session with DRM, mp4, multiple keys for audio/video</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
- <script src=/encrypted-media/util/testmediasource.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
-
- <!-- Content metadata -->
- <script src=/encrypted-media/content/content-metadata.js></script>
-
- <!-- Message handler for DRM server -->
- <script src=/encrypted-media/util/drm-messagehandler.js></script>
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/keystatuses-multiple-sessions.js></script>
-
- </head>
- <body>
- <div id='log'></div>
-
- <div id='video'>
- <video id="videoelement" width="200px"></video>
- </div>
-
- <script>
- var keysystem = getSupportedKeySystem();
- getSupportedContent( keysystem )
- .then( function( contents ) {
-
- // Select a content item with multiple keys and initData
- var contentitem = contents.filter( function( item ) { return item.keys && item.keys.length > 1 && item.initDataType && !item.associatedInitData; } )[ 0 ],
- handler = new MessageHandler( keysystem, contentitem ),
- config = { keysystem: keysystem,
- content: contentitem,
- messagehandler: handler.messagehandler,
- initDataType: contentitem.initDataType,
- initData: getProprietaryInitDatas(contentitem).initDatas.map( base64DecodeToUnit8Array )
- };
-
- runTest(config);
-
- } );
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/drm-keystatuses.html b/testing/web-platform/tests/encrypted-media/drm-keystatuses.html
deleted file mode 100644
index de7ff395d..000000000
--- a/testing/web-platform/tests/encrypted-media/drm-keystatuses.html
+++ /dev/null
@@ -1,52 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <title>Encrypted Media Extensions: Verify MediaKeySession.keyStatuses with multiple sessions, DRM</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
- <script src=/encrypted-media/util/testmediasource.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
-
- <!-- Content metadata -->
- <script src=/encrypted-media/content/content-metadata.js></script>
-
- <!-- Message handler for DRM -->
- <script src=/encrypted-media/util/drm-messagehandler.js></script>
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/keystatuses.js></script>
-
- </head>
- <body>
- <div id='log'></div>
-
- <script>
- var keysystem = getSupportedKeySystem();
- getSupportedContent( keysystem ).then( function( contents ) {
- // Select a content item with multiple keys and initData that retrieves all keys
- var contentitem = contents.filter( function( item ) {
- return item.keys && item.keys.length > 1 && item.initDataType && item.associatedInitData;
- } )[ 0 ];
-
- var handler = new MessageHandler( keysystem, contentitem );
- var config = { keysystem: keysystem,
- content: contentitem,
- messagehandler: handler.messagehandler,
- initDataType: contentitem.initDataType,
- initData: base64DecodeToUnit8Array( getProprietaryInitDatas(contentitem).initDatas[ 0 ] )
- };
-
- runTest(config);
-
- } );
- </script>
- </body>
-</html> \ No newline at end of file
diff --git a/testing/web-platform/tests/encrypted-media/drm-mp4-onencrypted.html b/testing/web-platform/tests/encrypted-media/drm-mp4-onencrypted.html
deleted file mode 100644
index 9e4aff330..000000000
--- a/testing/web-platform/tests/encrypted-media/drm-mp4-onencrypted.html
+++ /dev/null
@@ -1,47 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <title>Encrypted Media Extensions: Encrypted fired on encrypted media file with DRM, mp4</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
- <script src=/encrypted-media/util/testmediasource.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
-
- <!-- Content metadata -->
- <script src=/encrypted-media/content/content-metadata.js></script>
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/onencrypted.js></script>
-
- </head>
- <body>
- <div id='log'></div>
-
- <div id='video'>
- <video id="videoelement" width="200px"></video>
- </div>
-
- <script>
- var contentItem = content['mp4-av-multikey'],
- config = {
- video: document.getElementById('videoelement'),
- content: contentItem,
- audioType: contentItem.audio.type,
- videoType: contentItem.video.type,
- audioPath: contentItem.audio.path,
- videoPath: contentItem.video.path,
- initDataType: contentItem.initDataType,
- keys: contentItem.keys
- };
- runTest(config);
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/drm-mp4-playback-destroy-persistent-license.html b/testing/web-platform/tests/encrypted-media/drm-mp4-playback-destroy-persistent-license.html
deleted file mode 100644
index 59350fb15..000000000
--- a/testing/web-platform/tests/encrypted-media/drm-mp4-playback-destroy-persistent-license.html
+++ /dev/null
@@ -1,52 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <title>Encrypted Media Extensions: Successful Playback, persistent-license session with DRM, mp4, destroy the license</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
- <script src=/encrypted-media/util/testmediasource.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
-
- <!-- Content metadata -->
- <script src=/encrypted-media/content/content-metadata.js></script>
-
- <!-- Message handler for DRM keysystem -->
- <script src=/encrypted-media/util/drm-messagehandler.js></script>
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/playback-destroy-persistent-license.js></script>
-
- </head>
- <body>
- <div id='log'></div>
-
- <div id='video'>
- <video id="videoelement" width="200px"></video>
- </div>
-
- <script>
- var keysystem = getSupportedKeySystem(),
- contentitem = content['mp4-basic'],
- handler = new MessageHandler( keysystem, contentitem, 'persistent-license' ),
- config = { video: document.getElementById('videoelement'),
- keysystem: keysystem,
- messagehandler: handler.messagehandler,
- audioPath: contentitem.audio.path,
- videoPath: contentitem.video.path,
- audioType: contentitem.audio.type,
- videoType: contentitem.video.type,
- initDataType: contentitem.initDataType
- };
-
- runTest(config);
- </script>
- </body>
-</html> \ No newline at end of file
diff --git a/testing/web-platform/tests/encrypted-media/drm-mp4-playback-persistent-license-events.html b/testing/web-platform/tests/encrypted-media/drm-mp4-playback-persistent-license-events.html
deleted file mode 100644
index 3df5fffd2..000000000
--- a/testing/web-platform/tests/encrypted-media/drm-mp4-playback-persistent-license-events.html
+++ /dev/null
@@ -1,52 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <title>Encrypted Media Extensions: Successful Playback, persistent-license session with DRM, mp4, event sequence</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
- <script src=/encrypted-media/util/testmediasource.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
-
- <!-- Content metadata -->
- <script src=/encrypted-media/content/content-metadata.js></script>
-
- <!-- Message handler for DRM keysystem -->
- <script src=/encrypted-media/util/drm-messagehandler.js></script>
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/playback-persistent-license-events.js></script>
-
- </head>
- <body>
- <div id='log'></div>
-
- <div id='video'>
- <video id="videoelement" width="200px"></video>
- </div>
-
- <script>
- var keysystem = getSupportedKeySystem(),
- contentitem = content['mp4-basic'],
- handler = new MessageHandler( keysystem, contentitem, 'persistent-license' ),
- config = { video: document.getElementById('videoelement'),
- keysystem: keysystem,
- messagehandler: handler.messagehandler,
- audioPath: contentitem.audio.path,
- videoPath: contentitem.video.path,
- audioType: contentitem.audio.type,
- videoType: contentitem.video.type,
- initDataType: contentitem.initDataType,
- };
-
- runTest(config);
- </script>
- </body>
-</html> \ No newline at end of file
diff --git a/testing/web-platform/tests/encrypted-media/drm-mp4-playback-persistent-license.html b/testing/web-platform/tests/encrypted-media/drm-mp4-playback-persistent-license.html
deleted file mode 100644
index 066e0040f..000000000
--- a/testing/web-platform/tests/encrypted-media/drm-mp4-playback-persistent-license.html
+++ /dev/null
@@ -1,52 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <title>Encrypted Media Extensions: Successful Playback, persistent-license session with DRM, mp4</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
- <script src=/encrypted-media/util/testmediasource.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
-
- <!-- Content metadata -->
- <script src=/encrypted-media/content/content-metadata.js></script>
-
- <!-- Message handler for DRM keysystem -->
- <script src=/encrypted-media/util/drm-messagehandler.js></script>
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/playback-persistent-license.js></script>
-
- </head>
- <body>
- <div id='log'></div>
-
- <div id='video'>
- <video id="videoelement" width="200px"></video>
- </div>
-
- <script>
- var keysystem = getSupportedKeySystem(),
- contentitem = content['mp4-basic'],
- handler = new MessageHandler( keysystem, contentitem, 'persistent-license' ),
- config = { video: document.getElementById('videoelement'),
- keysystem: keysystem,
- messagehandler: handler.messagehandler,
- audioPath: contentitem.audio.path,
- videoPath: contentitem.video.path,
- audioType: contentitem.audio.type,
- videoType: contentitem.video.type,
- initDataType: contentitem.initDataType
- };
-
- runTest(config);
- </script>
- </body>
-</html> \ No newline at end of file
diff --git a/testing/web-platform/tests/encrypted-media/drm-mp4-playback-persistent-usage-record-events.html b/testing/web-platform/tests/encrypted-media/drm-mp4-playback-persistent-usage-record-events.html
deleted file mode 100644
index b0c82621a..000000000
--- a/testing/web-platform/tests/encrypted-media/drm-mp4-playback-persistent-usage-record-events.html
+++ /dev/null
@@ -1,53 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <title>Encrypted Media Extensions: Successful Playback, persistent-usage-record session with DRM, mp4, event sequence</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
- <script src=/encrypted-media/util/testmediasource.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
-
- <!-- Content metadata -->
- <script src=/encrypted-media/content/content-metadata.js></script>
-
- <!-- Message handler for DRM servers -->
- <script src=/encrypted-media/util/drm-messagehandler.js></script>
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/playback-persistent-usage-record-events.js></script>
-
- </head>
- <body>
- <div id='log'></div>
-
- <div id='video'>
- <video id="videoelement" width="200px"></video>
- </div>
-
- <script>
- var keysystem = getSupportedKeySystem(),
- contentitem = content['mp4-basic'],
- handler = new MessageHandler( keysystem, contentitem, 'persistent-usage-record' ),
- config = { video: document.getElementById('videoelement'),
- keysystem: keysystem,
- messagehandler: handler.messagehandler,
- audioPath: contentitem.audio.path,
- videoPath: contentitem.video.path,
- audioType: contentitem.audio.type,
- videoType: contentitem.video.type,
- initDataType: contentitem.initDataType,
- servercertificate: handler.servercertificate
- };
-
- runTest(config);
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/drm-mp4-playback-persistent-usage-record.html b/testing/web-platform/tests/encrypted-media/drm-mp4-playback-persistent-usage-record.html
deleted file mode 100644
index 1a9f8fb6f..000000000
--- a/testing/web-platform/tests/encrypted-media/drm-mp4-playback-persistent-usage-record.html
+++ /dev/null
@@ -1,54 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <meta name="timeout" content="long">
- <title>Encrypted Media Extensions: Successful Playback, persistent-usage-record session with DRM, mp4</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
- <script src=/encrypted-media/util/testmediasource.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
-
- <!-- Content metadata -->
- <script src=/encrypted-media/content/content-metadata.js></script>
-
- <!-- Message handler for DRM servers -->
- <script src=/encrypted-media/util/drm-messagehandler.js></script>
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/playback-persistent-usage-record.js></script>
-
- </head>
- <body>
- <div id='log'></div>
-
- <div id='video'>
- <video id="videoelement" width="200px"></video>
- </div>
-
- <script>
- var keysystem = getSupportedKeySystem(),
- contentitem = content['mp4-basic'],
- handler = new MessageHandler( keysystem, contentitem, 'persistent-usage-record' ),
- config = { video: document.getElementById('videoelement'),
- keysystem: keysystem,
- messagehandler: handler.messagehandler,
- audioPath: contentitem.audio.path,
- videoPath: contentitem.video.path,
- audioType: contentitem.audio.type,
- videoType: contentitem.video.type,
- initDataType: contentitem.initDataType,
- servercertificate: handler.servercertificate
- };
-
- runTest(config);
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/drm-mp4-playback-retrieve-destroy-persistent-license.html b/testing/web-platform/tests/encrypted-media/drm-mp4-playback-retrieve-destroy-persistent-license.html
deleted file mode 100644
index 3a1646174..000000000
--- a/testing/web-platform/tests/encrypted-media/drm-mp4-playback-retrieve-destroy-persistent-license.html
+++ /dev/null
@@ -1,54 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <meta name="timeout" content="long">
- <title>Encrypted Media Extensions: Successful Playback, persistent-license session with DRM, mp4, retrieve license, playback and destroy the license</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
- <script src=/encrypted-media/util/testmediasource.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
-
- <!-- Content metadata -->
- <script src=/encrypted-media/content/content-metadata.js></script>
-
- <!-- Message handler for DRM keysystem -->
- <script src=/encrypted-media/util/drm-messagehandler.js></script>
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/playback-retrieve-persistent-license.js></script>
-
- </head>
- <body>
- <div id='log'></div>
-
- <div id='video'>
- <video id="videoelement" width="200px"></video>
- </div>
-
- <script>
- var keysystem = getSupportedKeySystem(),
- contentitem = content['mp4-basic'],
- handler = new MessageHandler( keysystem, contentitem, 'persistent-license' ),
- config = { video: document.getElementById('videoelement'),
- keysystem: keysystem,
- messagehandler: handler.messagehandler,
- audioPath: contentitem.audio.path,
- videoPath: contentitem.video.path,
- audioType: contentitem.audio.type,
- videoType: contentitem.video.type,
- initDataType: contentitem.initDataType,
- windowscript: 'resources/drm-retrieve-destroy-persistent-license.html',
- testcase: 'playback, retrieve, playback and destroy' };
-
- runTest(config);
- </script>
- </body>
-</html> \ No newline at end of file
diff --git a/testing/web-platform/tests/encrypted-media/drm-mp4-playback-retrieve-persistent-license.html b/testing/web-platform/tests/encrypted-media/drm-mp4-playback-retrieve-persistent-license.html
deleted file mode 100644
index 416093c14..000000000
--- a/testing/web-platform/tests/encrypted-media/drm-mp4-playback-retrieve-persistent-license.html
+++ /dev/null
@@ -1,54 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <meta name="timeout" content="long">
- <title>Encrypted Media Extensions: Successful Playback, persistent-license session with DRM, mp4, retrieve the license, playback</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
- <script src=/encrypted-media/util/testmediasource.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
-
- <!-- Content metadata -->
- <script src=/encrypted-media/content/content-metadata.js></script>
-
- <!-- Message handler for DRM keysystem -->
- <script src=/encrypted-media/util/drm-messagehandler.js></script>
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/playback-retrieve-persistent-license.js></script>
-
- </head>
- <body>
- <div id='log'></div>
-
- <div id='video'>
- <video id="videoelement" width="200px"></video>
- </div>
-
- <script>
- var keysystem = getSupportedKeySystem(),
- contentitem = content['mp4-basic'],
- handler = new MessageHandler( keysystem, contentitem, 'persistent-license' ),
- config = { video: document.getElementById('videoelement'),
- keysystem: keysystem,
- messagehandler: handler.messagehandler,
- audioPath: contentitem.audio.path,
- videoPath: contentitem.video.path,
- audioType: contentitem.audio.type,
- videoType: contentitem.video.type,
- initDataType: contentitem.initDataType,
- windowscript: 'resources/drm-retrieve-persistent-license.html',
- testcase: 'playback, retrieve, playback' };
-
- runTest(config);
- </script>
- </body>
-</html> \ No newline at end of file
diff --git a/testing/web-platform/tests/encrypted-media/drm-mp4-playback-retrieve-persistent-usage-record.html b/testing/web-platform/tests/encrypted-media/drm-mp4-playback-retrieve-persistent-usage-record.html
deleted file mode 100644
index da5048f29..000000000
--- a/testing/web-platform/tests/encrypted-media/drm-mp4-playback-retrieve-persistent-usage-record.html
+++ /dev/null
@@ -1,53 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <title>Encrypted Media Extensions: persistent-usage-record, playback and retrieve record in new window, DRM, mp4</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
- <script src=/encrypted-media/util/testmediasource.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
-
- <!-- Content metadata -->
- <script src=/encrypted-media/content/content-metadata.js></script>
-
- <!-- Message handler for DRM server -->
- <script src=/encrypted-media/util/drm-messagehandler.js></script>
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/playback-retrieve-persistent-usage-record.js></script>
-
- </head>
- <body>
- <div id='log'></div>
-
- <div id='video'>
- <video id="videoelement" width="200px"></video>
- </div>
-
- <script>
- var keysystem = getSupportedKeySystem(),
- contentitem = content['mp4-basic'],
- handler = new MessageHandler( keysystem, contentitem, 'persistent-usage-record' ),
- config = { video: document.getElementById('videoelement'),
- keysystem: keysystem,
- messagehandler: handler.messagehandler,
- audioPath: contentitem.audio.path,
- videoPath: contentitem.video.path,
- audioType: contentitem.audio.type,
- videoType: contentitem.video.type,
- initDataType: contentitem.initDataType,
- servercertificate: handler.servercertificate,
- windowscript: 'resources/drm-retrieve-persistent-usage-record.html' };
-
- runTest(config);
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/drm-mp4-playback-temporary-clear-encrypted.html b/testing/web-platform/tests/encrypted-media/drm-mp4-playback-temporary-clear-encrypted.html
deleted file mode 100644
index a8621ba25..000000000
--- a/testing/web-platform/tests/encrypted-media/drm-mp4-playback-temporary-clear-encrypted.html
+++ /dev/null
@@ -1,53 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <title>Encrypted Media Extensions: Successful Playback, Temporary session with DRM, mp4, clear then encrypted</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
- <script src=/encrypted-media/util/testmediasource.js></script>
-
- <!-- Content metadata -->
- <script src=/encrypted-media/content/content-metadata.js></script>
-
- <!-- Message handler for DRM servers -->
- <script src=/encrypted-media/util/drm-messagehandler.js></script>
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/playback-temporary.js></script>
-
- </head>
- <body>
- <div id='log'></div>
-
- <div id='video'>
- <video id="videoelement" width="200px"></video>
- </div>
-
- <script>
- var keysystem = getSupportedKeySystem(),
- contentitem = content['mp4-clear-encrypted'],
- handler = new MessageHandler(keysystem, contentitem),
- config = { video: document.getElementById('videoelement'),
- keysystem: keysystem,
- messagehandler: handler.messagehandler,
- audioPath: contentitem.audio.path,
- videoPath: contentitem.video.path,
- audioType: contentitem.audio.type,
- videoType: contentitem.video.type,
- initDataType: contentitem.initDataType,
- testcase: 'single key, clear then encrypted content',
- duration: 4 };
-
- runTest(config);
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/drm-mp4-playback-temporary-encrypted-clear-sources.html b/testing/web-platform/tests/encrypted-media/drm-mp4-playback-temporary-encrypted-clear-sources.html
deleted file mode 100644
index 74bd77053..000000000
--- a/testing/web-platform/tests/encrypted-media/drm-mp4-playback-temporary-encrypted-clear-sources.html
+++ /dev/null
@@ -1,58 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <title>Encrypted Media Extensions: Successful Playback, alternate Encrypted and Clear playbacks, Temporary, mp4, DRM</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
- <script src=/encrypted-media/util/testmediasource.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
-
- <!-- Content metadata -->
- <script src=/encrypted-media/content/content-metadata.js></script>
-
- <!-- Message handler for DRM -->
- <script src=/encrypted-media/util/drm-messagehandler.js></script>
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/playback-temporary-encrypted-clear-sources.js></script>
-
- </head>
- <body>
- <div id='log'></div>
-
- <div id='video'>
- <video id="videoelement" width="200px"></video>
- </div>
-
- <script>
- var keysystem = getSupportedKeySystem(),
- encryptedcontentitem = content['mp4-basic'],
- clearcontentitem = content['mp4-clear'],
- handler = new MessageHandler(keysystem, encryptedcontentitem),
- configEncrypted = { video: document.getElementById('videoelement'),
- keysystem: keysystem,
- messagehandler: handler.messagehandler,
- audioPath: encryptedcontentitem.audio.path,
- videoPath: encryptedcontentitem.video.path,
- audioType: encryptedcontentitem.audio.type,
- videoType: encryptedcontentitem.video.type,
- initDataType: encryptedcontentitem.initDataType
- },
- configClear = { audioPath: clearcontentitem.audio.path,
- videoPath: clearcontentitem.video.path,
- audioType: clearcontentitem.audio.type,
- videoType: clearcontentitem.video.type,
- };
-
- runTest(configEncrypted,configClear);
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/drm-mp4-playback-temporary-encrypted-clear.html b/testing/web-platform/tests/encrypted-media/drm-mp4-playback-temporary-encrypted-clear.html
deleted file mode 100644
index ed5ff2363..000000000
--- a/testing/web-platform/tests/encrypted-media/drm-mp4-playback-temporary-encrypted-clear.html
+++ /dev/null
@@ -1,53 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <title>Encrypted Media Extensions: Successful Playback, Temporary session with DRM, mp4, encrypted then clear</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
- <script src=/encrypted-media/util/testmediasource.js></script>
-
- <!-- Content metadata -->
- <script src=/encrypted-media/content/content-metadata.js></script>
-
- <!-- Message handler for DRM servers -->
- <script src=/encrypted-media/util/drm-messagehandler.js></script>
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/playback-temporary.js></script>
-
- </head>
- <body>
- <div id='log'></div>
-
- <div id='video'>
- <video id="videoelement" width="200px"></video>
- </div>
-
- <script>
- var keysystem = getSupportedKeySystem(),
- contentitem = content['mp4-encrypted-clear'],
- handler = new MessageHandler(keysystem, contentitem),
- config = { video: document.getElementById('videoelement'),
- keysystem: keysystem,
- messagehandler: handler.messagehandler,
- audioPath: contentitem.audio.path,
- videoPath: contentitem.video.path,
- audioType: contentitem.audio.type,
- videoType: contentitem.video.type,
- initDataType: contentitem.initDataType,
- testcase: 'single key, clear then encrypted content',
- duration: 4 };
-
- runTest(config);
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/drm-mp4-playback-temporary-events.html b/testing/web-platform/tests/encrypted-media/drm-mp4-playback-temporary-events.html
deleted file mode 100644
index 9846eeeec..000000000
--- a/testing/web-platform/tests/encrypted-media/drm-mp4-playback-temporary-events.html
+++ /dev/null
@@ -1,53 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <meta name="timeout" content="long">
- <title>Encrypted Media Extensions: Successful playback, temporary session with DRM, mp4, validating events</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
- <script src=/encrypted-media/util/testmediasource.js></script>
-
- <!-- Content metadata -->
- <script src=/encrypted-media/content/content-metadata.js></script>
-
- <!-- Message handler for DRM servers -->
- <script src=/encrypted-media/util/drm-messagehandler.js></script>
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/playback-temporary-events.js></script>
-
- </head>
- <body>
- <div id='log'></div>
-
- <div id='video'>
- <video id="videoelement" width="200px"></video>
- </div>
-
- <script>
- var keysystem = getSupportedKeySystem(),
- contentitem = content['mp4-basic'],
- handler = new MessageHandler( keysystem, contentitem ),
- config = { video: document.getElementById('videoelement'),
- keysystem: keysystem,
- messagehandler: handler.messagehandler,
- audioPath: contentitem.audio.path,
- videoPath: contentitem.video.path,
- audioType: contentitem.audio.type,
- videoType: contentitem.video.type,
- initDataType: contentitem.initDataType
- };
-
- runTest(config);
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/drm-mp4-playback-temporary-expired.html b/testing/web-platform/tests/encrypted-media/drm-mp4-playback-temporary-expired.html
deleted file mode 100644
index 1a649d869..000000000
--- a/testing/web-platform/tests/encrypted-media/drm-mp4-playback-temporary-expired.html
+++ /dev/null
@@ -1,52 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <title>Encrypted Media Extensions: Successful Playback, Temporary session with DRM, mp4, expired license</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
- <script src=/encrypted-media/util/testmediasource.js></script>
-
- <!-- Content metadata -->
- <script src=/encrypted-media/content/content-metadata.js></script>
-
- <!-- Message handler for DRM servers -->
- <script src=/encrypted-media/util/drm-messagehandler.js></script>
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/playback-temporary-expired.js></script>
-
- </head>
- <body>
- <div id='log'></div>
-
- <div id='video'>
- <video id="videoelement" width="200px"></video>
- </div>
-
- <script>
- var keysystem = getSupportedKeySystem(),
- contentitem = content['mp4-basic'],
- handler = new MessageHandler(keysystem, contentitem),
- config = { video: document.getElementById('videoelement'),
- keysystem: keysystem,
- messagehandler: handler.messagehandler,
- audioPath: contentitem.audio.path,
- videoPath: contentitem.video.path,
- audioType: contentitem.audio.type,
- videoType: contentitem.video.type,
- initDataType: contentitem.initDataType
- };
-
- runTest(config);
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/drm-mp4-playback-temporary-multikey-sequential-readyState.html b/testing/web-platform/tests/encrypted-media/drm-mp4-playback-temporary-multikey-sequential-readyState.html
deleted file mode 100644
index 42d563a5d..000000000
--- a/testing/web-platform/tests/encrypted-media/drm-mp4-playback-temporary-multikey-sequential-readyState.html
+++ /dev/null
@@ -1,58 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <meta name="timeout" content="long">
- <title>Encrypted Media Extensions: Successful Playback, Temporary session with DRM, mp4, multiple keys in sequence, check readyState</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
- <script src=/encrypted-media/util/testmediasource.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
-
- <!-- Content metadata -->
- <script src=/encrypted-media/content/content-metadata.js></script>
-
- <!-- Message handler for Clear Key keysystem -->
- <script src=/encrypted-media/util/drm-messagehandler.js></script>
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/playback-temporary-multikey-sequential.js></script>
-
- </head>
- <body>
- <div id='log'></div>
-
- <div id='video'>
- <video id="videoelement" width="200px"></video>
- </div>
-
- <script>
- var keysystem = getSupportedKeySystem(),
- contentitem = content['mp4-multikey-sequential'],
- handler = new MessageHandler(keysystem, contentitem),
- initdatas = getProprietaryInitDatas(contentitem),
- config = { video: document.getElementById('videoelement'),
- keysystem: keysystem,
- messagehandler: handler.messagehandler,
- audioPath: contentitem.audio.path,
- videoPath: contentitem.video.path,
- audioType: contentitem.audio.type,
- videoType: contentitem.video.type,
- initDataType: contentitem.initDataType,
- initData: initdatas.initDatas.map(base64DecodeToUnit8Array),
- variantIds: initdatas.variantIds,
- duration: 5,
- checkReadyState: true
- };
-
- runTest(config);
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/drm-mp4-playback-temporary-multikey-sequential.html b/testing/web-platform/tests/encrypted-media/drm-mp4-playback-temporary-multikey-sequential.html
deleted file mode 100644
index 0b23721b6..000000000
--- a/testing/web-platform/tests/encrypted-media/drm-mp4-playback-temporary-multikey-sequential.html
+++ /dev/null
@@ -1,57 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <meta name="timeout" content="long">
- <title>Encrypted Media Extensions: Successful Playback, Temporary session with DRM, mp4, multiple keys in sequence</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
- <script src=/encrypted-media/util/testmediasource.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
-
- <!-- Content metadata -->
- <script src=/encrypted-media/content/content-metadata.js></script>
-
- <!-- Message handler for Clear Key keysystem -->
- <script src=/encrypted-media/util/drm-messagehandler.js></script>
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/playback-temporary-multikey-sequential.js></script>
-
- </head>
- <body>
- <div id='log'></div>
-
- <div id='video'>
- <video id="videoelement" width="200px"></video>
- </div>
-
- <script>
- var keysystem = getSupportedKeySystem(),
- contentitem = content['mp4-multikey-sequential'],
- handler = new MessageHandler( keysystem, contentitem ),
- initdatas = getProprietaryInitDatas(contentitem),
- config = { video: document.getElementById('videoelement'),
- keysystem: keysystem,
- messagehandler: handler.messagehandler,
- audioPath: contentitem.audio.path,
- videoPath: contentitem.video.path,
- audioType: contentitem.audio.type,
- videoType: contentitem.video.type,
- initDataType: contentitem.initDataType,
- initData: initdatas.initDatas.map(base64DecodeToUnit8Array),
- variantIds: initdatas.variantIds,
- duration: 5
- };
-
- runTest(config);
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/drm-mp4-playback-temporary-multikey.html b/testing/web-platform/tests/encrypted-media/drm-mp4-playback-temporary-multikey.html
deleted file mode 100644
index b29139ed2..000000000
--- a/testing/web-platform/tests/encrypted-media/drm-mp4-playback-temporary-multikey.html
+++ /dev/null
@@ -1,52 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <title>Encrypted Media Extensions: Successful playback, temporary session with DRM, mp4, multiple keys</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
- <script src=/encrypted-media/util/testmediasource.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
-
- <!-- Content metadata -->
- <script src=/encrypted-media/content/content-metadata.js></script>
-
- <!-- Message handler for DRM keysystem -->
- <script src=/encrypted-media/util/drm-messagehandler.js></script>
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/playback-temporary.js></script>
-
- </head>
- <body>
- <div id='log'></div>
-
- <div id='video'>
- <video id="videoelement" width="200px"></video>
- </div>
-
- <script>
- var keysystem = getSupportedKeySystem(),
- contentitem = content['mp4-av-multikey'],
- handler = new MessageHandler( keysystem, contentitem ),
- config = { video: document.getElementById('videoelement'),
- keysystem: keysystem,
- messagehandler: handler.messagehandler,
- audioPath: contentitem.audio.path,
- videoPath: contentitem.video.path,
- audioType: contentitem.audio.type,
- videoType: contentitem.video.type,
- initDataType: contentitem.initDataType,
- testcase: 'multikey audio/video'
- };
- runTest(config);
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/drm-mp4-playback-temporary-multisession.html b/testing/web-platform/tests/encrypted-media/drm-mp4-playback-temporary-multisession.html
deleted file mode 100644
index 391ebf907..000000000
--- a/testing/web-platform/tests/encrypted-media/drm-mp4-playback-temporary-multisession.html
+++ /dev/null
@@ -1,55 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <title>Encrypted Media Extensions: Verify MediaKeySession.keyStatuses with multiple sessions, DRM</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
- <script src=/encrypted-media/util/testmediasource.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
-
- <!-- Content metadata -->
- <script src=/encrypted-media/content/content-metadata.js></script>
-
- <!-- Message handler for DRM keysystem -->
- <script src=/encrypted-media/util/drm-messagehandler.js></script>
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/playback-temporary-multisession.js></script>
-
- </head>
- <body>
- <div id='log'></div>
-
- <div id='video'>
- <video id="videoelement" width="200px"></video>
- </div>
-
- <script>
- var keysystem = getSupportedKeySystem(),
- contentitem = content['mp4-multikey'],
- handler = new MessageHandler( keysystem, contentitem ),
- proprietaryInitDatas = getProprietaryInitDatas(contentitem),
- config = { video: document.getElementById('videoelement'),
- keysystem: keysystem,
- messagehandler: handler.messagehandler,
- audioPath: contentitem.audio.path,
- videoPath: contentitem.video.path,
- audioType: contentitem.audio.type,
- videoType: contentitem.video.type,
- initDataType: contentitem.initDataType,
- initData: proprietaryInitDatas.initDatas.map( base64DecodeToUnit8Array ),
- variantIds: proprietaryInitDatas.variantIds,
- testcase: 'multikey video' };
-
- runTest(config);
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/drm-mp4-playback-temporary-setMediaKeys-after-src.html b/testing/web-platform/tests/encrypted-media/drm-mp4-playback-temporary-setMediaKeys-after-src.html
deleted file mode 100644
index 20dda66ad..000000000
--- a/testing/web-platform/tests/encrypted-media/drm-mp4-playback-temporary-setMediaKeys-after-src.html
+++ /dev/null
@@ -1,52 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <title>Encrypted Media Extensions: Successful Playback, Temporary session with DRM, mp4</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
- <script src=/encrypted-media/util/testmediasource.js></script>
-
- <!-- Content metadata -->
- <script src=/encrypted-media/content/content-metadata.js></script>
-
- <!-- Message handler for DRM servers -->
- <script src=/encrypted-media/util/drm-messagehandler.js></script>
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/playback-temporary-setMediaKeys.js></script>
-
- </head>
- <body>
- <div id='log'></div>
-
- <div id='video'>
- <video id="videoelement" width="200px"></video>
- </div>
-
- <script>
- var keysystem = getSupportedKeySystem(),
- contentitem = content['mp4-basic'],
- handler = new MessageHandler( keysystem, contentitem ),
- config = { video: document.getElementById('videoelement'),
- keysystem: keysystem,
- messagehandler: handler.messagehandler,
- audioPath: contentitem.audio.path,
- videoPath: contentitem.video.path,
- audioType: contentitem.audio.type,
- videoType: contentitem.video.type,
- initDataType: contentitem.initDataType,
- testcase: SETMEDIAKEYS_AFTER_SRC };
-
- runTest(config);
- </script>
- </body>
-</html> \ No newline at end of file
diff --git a/testing/web-platform/tests/encrypted-media/drm-mp4-playback-temporary-setMediaKeys-after-update.html b/testing/web-platform/tests/encrypted-media/drm-mp4-playback-temporary-setMediaKeys-after-update.html
deleted file mode 100644
index 4f81da08d..000000000
--- a/testing/web-platform/tests/encrypted-media/drm-mp4-playback-temporary-setMediaKeys-after-update.html
+++ /dev/null
@@ -1,52 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <title>Encrypted Media Extensions: Successful Playback, Temporary session with DRM, mp4</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
- <script src=/encrypted-media/util/testmediasource.js></script>
-
- <!-- Content metadata -->
- <script src=/encrypted-media/content/content-metadata.js></script>
-
- <!-- Message handler for DRM servers -->
- <script src=/encrypted-media/util/drm-messagehandler.js></script>
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/playback-temporary-setMediaKeys.js></script>
-
- </head>
- <body>
- <div id='log'></div>
-
- <div id='video'>
- <video id="videoelement" width="200px"></video>
- </div>
-
- <script>
- var keysystem = getSupportedKeySystem(),
- contentitem = content['mp4-basic'],
- handler = new MessageHandler( keysystem, contentitem ),
- config = { video: document.getElementById('videoelement'),
- keysystem: keysystem,
- messagehandler: handler.messagehandler,
- audioPath: contentitem.audio.path,
- videoPath: contentitem.video.path,
- audioType: contentitem.audio.type,
- videoType: contentitem.video.type,
- initDataType: contentitem.initDataType,
- testcase: SETMEDIAKEYS_AFTER_UPDATE };
-
- runTest(config);
- </script>
- </body>
-</html> \ No newline at end of file
diff --git a/testing/web-platform/tests/encrypted-media/drm-mp4-playback-temporary-setMediaKeys-immediately.html b/testing/web-platform/tests/encrypted-media/drm-mp4-playback-temporary-setMediaKeys-immediately.html
deleted file mode 100644
index c97c571b6..000000000
--- a/testing/web-platform/tests/encrypted-media/drm-mp4-playback-temporary-setMediaKeys-immediately.html
+++ /dev/null
@@ -1,52 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <title>Encrypted Media Extensions: Successful Playback, Temporary session with DRM, mp4</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
- <script src=/encrypted-media/util/testmediasource.js></script>
-
- <!-- Content metadata -->
- <script src=/encrypted-media/content/content-metadata.js></script>
-
- <!-- Message handler for DRM servers -->
- <script src=/encrypted-media/util/drm-messagehandler.js></script>
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/playback-temporary-setMediaKeys.js></script>
-
- </head>
- <body>
- <div id='log'></div>
-
- <div id='video'>
- <video id="videoelement" width="200px"></video>
- </div>
-
- <script>
- var keysystem = getSupportedKeySystem(),
- contentitem = content['mp4-basic'],
- handler = new MessageHandler( keysystem, contentitem ),
- config = { video: document.getElementById('videoelement'),
- keysystem: keysystem,
- messagehandler: handler.messagehandler,
- audioPath: contentitem.audio.path,
- videoPath: contentitem.video.path,
- audioType: contentitem.audio.type,
- videoType: contentitem.video.type,
- initDataType: contentitem.initDataType,
- testcase: SETMEDIAKEYS_IMMEDIATELY };
-
- runTest(config);
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/drm-mp4-playback-temporary-setMediaKeys-onencrypted.html b/testing/web-platform/tests/encrypted-media/drm-mp4-playback-temporary-setMediaKeys-onencrypted.html
deleted file mode 100644
index c16809b85..000000000
--- a/testing/web-platform/tests/encrypted-media/drm-mp4-playback-temporary-setMediaKeys-onencrypted.html
+++ /dev/null
@@ -1,52 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <title>Encrypted Media Extensions: Successful Playback, Temporary session with DRM, mp4</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
- <script src=/encrypted-media/util/testmediasource.js></script>
-
- <!-- Content metadata -->
- <script src=/encrypted-media/content/content-metadata.js></script>
-
- <!-- Message handler for DRM servers -->
- <script src=/encrypted-media/util/drm-messagehandler.js></script>
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/playback-temporary-setMediaKeys.js></script>
-
- </head>
- <body>
- <div id='log'></div>
-
- <div id='video'>
- <video id="videoelement" width="200px"></video>
- </div>
-
- <script>
- var keysystem = getSupportedKeySystem(),
- contentitem = content['mp4-basic'],
- handler = new MessageHandler( keysystem, contentitem ),
- config = { video: document.getElementById('videoelement'),
- keysystem: keysystem,
- messagehandler: handler.messagehandler,
- audioPath: contentitem.audio.path,
- videoPath: contentitem.video.path,
- audioType: contentitem.audio.type,
- videoType: contentitem.video.type,
- initDataType: contentitem.initDataType,
- testcase: SETMEDIAKEYS_ONENCRYPTED };
-
- runTest(config);
- </script>
- </body>
-</html> \ No newline at end of file
diff --git a/testing/web-platform/tests/encrypted-media/drm-mp4-playback-temporary-two-videos.html b/testing/web-platform/tests/encrypted-media/drm-mp4-playback-temporary-two-videos.html
deleted file mode 100644
index 1aafba40f..000000000
--- a/testing/web-platform/tests/encrypted-media/drm-mp4-playback-temporary-two-videos.html
+++ /dev/null
@@ -1,54 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <title>Encrypted Media Extensions: Successful Playback, Temporary session with DRM, mp4, two videos</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
- <script src=/encrypted-media/util/testmediasource.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
-
- <!-- Content metadata -->
- <script src=/encrypted-media/content/content-metadata.js></script>
-
- <!-- Message handler for DRM server -->
- <script src=/encrypted-media/util/drm-messagehandler.js></script>
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/playback-temporary-two-videos.js></script>
-
- </head>
- <body>
- <div id='log'></div>
-
- <div id='video'>
- <video id="videoelement1" width="200px"></video>
- <video id="videoelement2" width="200px"></video>
- </div>
-
- <script>
- var keysystem = getSupportedKeySystem(),
- contentitem = content['mp4-basic'],
- handler = new MessageHandler( keysystem, contentitem ),
- config = { video: [ document.getElementById( 'videoelement1' ),
- document.getElementById( 'videoelement2' ) ],
- keysystem: keysystem,
- messagehandler: handler.messagehandler,
- audioPath: contentitem.audio.path,
- videoPath: contentitem.video.path,
- audioType: contentitem.audio.type,
- videoType: contentitem.video.type,
- initDataType: contentitem.initDataType
- };
-
- runTest(config);
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/drm-mp4-playback-temporary-waitingforkey.html b/testing/web-platform/tests/encrypted-media/drm-mp4-playback-temporary-waitingforkey.html
deleted file mode 100644
index bf970db67..000000000
--- a/testing/web-platform/tests/encrypted-media/drm-mp4-playback-temporary-waitingforkey.html
+++ /dev/null
@@ -1,53 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <title>Encrypted Media Extensions: Verify MediaKeySession.keyStatuses with multiple sessions, DRM</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
- <script src=/encrypted-media/util/testmediasource.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
-
- <!-- Content metadata -->
- <script src=/encrypted-media/content/content-metadata.js></script>
-
- <!-- Message handler for DRM keysystem -->
- <script src=/encrypted-media/util/drm-messagehandler.js></script>
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/playback-temporary-waitingforkey.js></script>
-
- </head>
- <body>
- <div id='log'></div>
-
- <div id='video'>
- <video id="videoelement" width="200px"></video>
- </div>
-
- <script>
- var contentitem = content['mp4-basic'],
- keysystem = getSupportedKeySystem(),
- handler = new MessageHandler( keysystem, contentitem ),
- config = { video: document.getElementById('videoelement'),
- keysystem: keysystem,
- messagehandler: handler.messagehandler,
- audioPath: contentitem.audio.path,
- videoPath: contentitem.video.path,
- audioType: contentitem.audio.type,
- videoType: contentitem.video.type,
- initDataType: contentitem.initDataType,
- initData: getProprietaryInitDatas(contentitem).initDatas.map( base64DecodeToUnit8Array ),
- };
-
- runTest(config);
- </script>
- </body>
-</html> \ No newline at end of file
diff --git a/testing/web-platform/tests/encrypted-media/drm-mp4-playback-temporary.html b/testing/web-platform/tests/encrypted-media/drm-mp4-playback-temporary.html
deleted file mode 100644
index 592f2a8a1..000000000
--- a/testing/web-platform/tests/encrypted-media/drm-mp4-playback-temporary.html
+++ /dev/null
@@ -1,52 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <title>Encrypted Media Extensions: Successful Playback, Temporary session with DRM, mp4</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
- <script src=/encrypted-media/util/testmediasource.js></script>
-
- <!-- Content metadata -->
- <script src=/encrypted-media/content/content-metadata.js></script>
-
- <!-- Message handler for DRM servers -->
- <script src=/encrypted-media/util/drm-messagehandler.js></script>
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/playback-temporary.js></script>
-
- </head>
- <body>
- <div id='log'></div>
-
- <div id='video'>
- <video id="videoelement" width="200px"></video>
- </div>
-
- <script>
- var keysystem = getSupportedKeySystem(),
- contentitem = content['mp4-basic'],
- handler = new MessageHandler( keysystem, contentitem ),
- config = { video: document.getElementById('videoelement'),
- keysystem: keysystem,
- messagehandler: handler.messagehandler,
- audioPath: contentitem.audio.path,
- videoPath: contentitem.video.path,
- audioType: contentitem.audio.type,
- videoType: contentitem.video.type,
- initDataType: contentitem.initDataType,
- testcase: 'single key' };
-
- runTest(config);
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/drm-mp4-requestmediakeysystemaccess.html b/testing/web-platform/tests/encrypted-media/drm-mp4-requestmediakeysystemaccess.html
deleted file mode 100644
index 2656f8feb..000000000
--- a/testing/web-platform/tests/encrypted-media/drm-mp4-requestmediakeysystemaccess.html
+++ /dev/null
@@ -1,41 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <meta name="timeout" content="long">
- <title>Encrypted Media Extensions: requestMediaKeySystemAccess tests, DRM</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
- <script src=/encrypted-media/util/testmediasource.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
-
- <!-- Content metadata -->
- <script src=/encrypted-media/content/content-metadata.js></script>
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/requestmediakeysystemaccess.js></script>
-
- </head>
- <body>
- <div id='log'></div>
-
- <script>
- var contentitem = content['mp4-basic'],
- keySystem = getSupportedKeySystem(),
- config = { keysystem: keySystem,
- audioType: contentitem.audio.type,
- videoType: contentitem.video.type,
- initDataType: getSupportedInitDataTypes( keySystem )[ 0 ]
- };
-
- runTest(config);
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/drm-mp4-reset-src-after-setmediakeys.html b/testing/web-platform/tests/encrypted-media/drm-mp4-reset-src-after-setmediakeys.html
deleted file mode 100644
index b91211df4..000000000
--- a/testing/web-platform/tests/encrypted-media/drm-mp4-reset-src-after-setmediakeys.html
+++ /dev/null
@@ -1,46 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <title>Encrypted Media Extensions - Reset MediaSource after setMediaKeys for DRM, mp4</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
- <script src=/encrypted-media/util/testmediasource.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
-
- <!-- Content metadata -->
- <script src=/encrypted-media/content/content-metadata.js></script>
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/reset-src-after-setmediakeys.js></script>
-
- </head>
- <body>
- <div id='log'></div>
- <div id='video'>
- <video id="videoelement" width="200px"></video>
- </div>
-
- <script>
- var contentItem = content['mp4-av-multikey'],
- keysystem = getSupportedKeySystem(),
- config = {
- video: document.getElementById('videoelement'),
- keysystem: keysystem,
- content: contentItem,
- initDataType: contentItem.initDataType,
- audioType: contentItem.audio.type,
- videoType: contentItem.video.type,
- audioPath: contentItem.audio.path,
- videoPath: contentItem.video.path,
- };
- runTest(config);
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/drm-mp4-setmediakeys-again-after-playback.html b/testing/web-platform/tests/encrypted-media/drm-mp4-setmediakeys-again-after-playback.html
deleted file mode 100644
index d215036fa..000000000
--- a/testing/web-platform/tests/encrypted-media/drm-mp4-setmediakeys-again-after-playback.html
+++ /dev/null
@@ -1,52 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <title>Encrypted Media Extensions: setMediaKeys again after playback with DRM</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
- <script src=/encrypted-media/util/testmediasource.js></script>
-
- <!-- Content metadata -->
- <script src=/encrypted-media/content/content-metadata.js></script>
-
- <!-- Message handler for DRM servers -->
- <script src=/encrypted-media/util/drm-messagehandler.js></script>
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/setmediakeys-again-after-playback.js></script>
-
- </head>
- <body>
- <div id='log'></div>
-
- <div id='video'>
- <video id="videoelement" width="200px"></video>
- </div>
-
- <script>
- var keysystem = getSupportedKeySystem(),
- contentitem = content['mp4-basic'],
- handler = new MessageHandler(keysystem, contentitem );
- getSupportedContent( keysystem ).then( function( contents ) {
- runTest( { video: document.getElementById('videoelement'),
- keysystem: keysystem,
- messagehandler: handler.messagehandler,
- content: contentitem,
- audioPath: contentitem.audio.path,
- videoPath: contentitem.video.path,
- audioType: contentitem.audio.type,
- videoType: contentitem.video.type
- } );
- } );
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/drm-mp4-setmediakeys-again-after-resetting-src.html b/testing/web-platform/tests/encrypted-media/drm-mp4-setmediakeys-again-after-resetting-src.html
deleted file mode 100644
index d1723b5ce..000000000
--- a/testing/web-platform/tests/encrypted-media/drm-mp4-setmediakeys-again-after-resetting-src.html
+++ /dev/null
@@ -1,52 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <title>Encrypted Media Extensions: setMediaKeys again after resetting src attribute on video element with DRM</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
- <script src=/encrypted-media/util/testmediasource.js></script>
-
- <!-- Content metadata -->
- <script src=/encrypted-media/content/content-metadata.js></script>
-
- <!-- Message handler for DRM servers -->
- <script src=/encrypted-media/util/drm-messagehandler.js></script>
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/setmediakeys-again-after-resetting-src.js></script>
-
- </head>
- <body>
- <div id='log'></div>
-
- <div id='video'>
- <video id="videoelement" width="200px"></video>
- </div>
-
- <script>
- var keysystem = getSupportedKeySystem(),
- contentitem = content['mp4-basic'],
- handler = new MessageHandler(keysystem, contentitem );
- getSupportedContent( keysystem ).then( function( contents ) {
- runTest( { video: document.getElementById('videoelement'),
- keysystem: keysystem,
- messagehandler: handler.messagehandler,
- content: contentitem,
- audioPath: contentitem.audio.path,
- videoPath: contentitem.video.path,
- audioType: contentitem.audio.type,
- videoType: contentitem.video.type
- } );
- } );
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/drm-mp4-setmediakeys-at-same-time.html b/testing/web-platform/tests/encrypted-media/drm-mp4-setmediakeys-at-same-time.html
deleted file mode 100644
index 581d22f4a..000000000
--- a/testing/web-platform/tests/encrypted-media/drm-mp4-setmediakeys-at-same-time.html
+++ /dev/null
@@ -1,44 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <title>Encrypted Media Extensions: setMediaKeys multiple at same time with DRM</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
-
- <!-- Content metadata -->
- <script src=/encrypted-media/content/content-metadata.js></script>
-
- <!-- Message handler for DRM servers -->
- <script src=/encrypted-media/util/drm-messagehandler.js></script>
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/setmediakeys-at-same-time.js></script>
-
- </head>
- <body>
- <div id='log'></div>
-
- <div id='video'>
- <video id="videoelement" width="200px"></video>
- </div>
-
- <script>
- var keysystem = getSupportedKeySystem();
- getSupportedContent( keysystem ).then( function( contents ) {
- runTest( { video: document.getElementById('videoelement'),
- keysystem: keysystem,
- content: contents[ 0 ]
- } );
- } );
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/drm-mp4-setmediakeys-multiple-times-with-different-mediakeys.html b/testing/web-platform/tests/encrypted-media/drm-mp4-setmediakeys-multiple-times-with-different-mediakeys.html
deleted file mode 100644
index 7d3fe0963..000000000
--- a/testing/web-platform/tests/encrypted-media/drm-mp4-setmediakeys-multiple-times-with-different-mediakeys.html
+++ /dev/null
@@ -1,50 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <title>Encrypted Media Extensions: setMediaKeys multiple times with different mediakeys with DRM</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
- <script src=/encrypted-media/util/testmediasource.js></script>
-
- <!-- Content metadata -->
- <script src=/encrypted-media/content/content-metadata.js></script>
-
- <!-- Message handler for DRM servers -->
- <script src=/encrypted-media/util/drm-messagehandler.js></script>
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/setmediakeys-multiple-times-with-different-mediakeys.js></script>
-
- </head>
- <body>
- <div id='log'></div>
-
- <div id='video'>
- <video id="videoelement" width="200px"></video>
- </div>
-
- <script>
- var keysystem = getSupportedKeySystem(),
- contentitem = content['mp4-basic'];
- getSupportedContent( keysystem ).then( function( contents ) {
- runTest( { video: document.getElementById('videoelement'),
- keysystem: keysystem,
- content: contentitem,
- audioPath: contentitem.audio.path,
- videoPath: contentitem.video.path,
- audioType: contentitem.audio.type,
- videoType: contentitem.video.type
- } );
- } );
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/drm-mp4-setmediakeys-multiple-times-with-the-same-mediakeys.html b/testing/web-platform/tests/encrypted-media/drm-mp4-setmediakeys-multiple-times-with-the-same-mediakeys.html
deleted file mode 100644
index efc6d1978..000000000
--- a/testing/web-platform/tests/encrypted-media/drm-mp4-setmediakeys-multiple-times-with-the-same-mediakeys.html
+++ /dev/null
@@ -1,50 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <title>Encrypted Media Extensions: setMediaKeys multiple times with the same mediakeys with DRM</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
- <script src=/encrypted-media/util/testmediasource.js></script>
-
- <!-- Content metadata -->
- <script src=/encrypted-media/content/content-metadata.js></script>
-
- <!-- Message handler for DRM servers -->
- <script src=/encrypted-media/util/drm-messagehandler.js></script>
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/setmediakeys-multiple-times-with-the-same-mediakeys.js></script>
-
- </head>
- <body>
- <div id='log'></div>
-
- <div id='video'>
- <video id="videoelement" width="200px"></video>
- </div>
-
- <script>
- var keysystem = getSupportedKeySystem(),
- contentitem = content['mp4-basic'];
- getSupportedContent( keysystem ).then( function( contents ) {
- runTest( { video: document.getElementById('videoelement'),
- keysystem: keysystem,
- content: contentitem,
- audioPath: contentitem.audio.path,
- videoPath: contentitem.video.path,
- audioType: contentitem.audio.type,
- videoType: contentitem.video.type
- } );
- } );
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/drm-mp4-setmediakeys-to-multiple-video-elements.html b/testing/web-platform/tests/encrypted-media/drm-mp4-setmediakeys-to-multiple-video-elements.html
deleted file mode 100644
index bd78cb930..000000000
--- a/testing/web-platform/tests/encrypted-media/drm-mp4-setmediakeys-to-multiple-video-elements.html
+++ /dev/null
@@ -1,48 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <title>Encrypted Media Extensions: setMediaKeys to multiple video elements with DRM</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
-
- <!-- Content metadata -->
- <script src=/encrypted-media/content/content-metadata.js></script>
-
- <!-- Message handler for DRM servers -->
- <script src=/encrypted-media/util/drm-messagehandler.js></script>
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/setmediakeys-to-multiple-video-elements.js></script>
-
- </head>
- <body>
- <div id='log'></div>
-
- <div id='video1'>
- <video id="videoelement1" width="200px"></video>
- </div>
- <div id='video2'>
- <video id="videoelement2" width="200px"></video>
- </div>
-
- <script>
- var keysystem = getSupportedKeySystem();
- getSupportedContent( keysystem ).then( function( contents ) {
- runTest( { video1: document.getElementById('videoelement1'),
- video2: document.getElementById('videoelement2'),
- keysystem: keysystem,
- content: contents[ 0 ]
- } );
- } );
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/drm-mp4-setmediakeys.html b/testing/web-platform/tests/encrypted-media/drm-mp4-setmediakeys.html
deleted file mode 100644
index 1a74a6236..000000000
--- a/testing/web-platform/tests/encrypted-media/drm-mp4-setmediakeys.html
+++ /dev/null
@@ -1,44 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <title>Encrypted Media Extensions: setMediaKeys with DRM</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
-
- <!-- Content metadata -->
- <script src=/encrypted-media/content/content-metadata.js></script>
-
- <!-- Message handler for DRM servers -->
- <script src=/encrypted-media/util/drm-messagehandler.js></script>
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/setmediakeys.js></script>
-
- </head>
- <body>
- <div id='log'></div>
-
- <div id='video'>
- <video id="videoelement" width="200px"></video>
- </div>
-
- <script>
- var keysystem = getSupportedKeySystem();
- getSupportedContent( keysystem ).then( function( contents ) {
- runTest( { video: document.getElementById('videoelement'),
- keysystem: keysystem,
- content: contents[ 0 ]
- } );
- } );
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/drm-mp4-syntax-mediakeys.html b/testing/web-platform/tests/encrypted-media/drm-mp4-syntax-mediakeys.html
deleted file mode 100644
index f6d039261..000000000
--- a/testing/web-platform/tests/encrypted-media/drm-mp4-syntax-mediakeys.html
+++ /dev/null
@@ -1,43 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <title>Encrypted Media Extensions - Test MediaKeys attribute, setServerCertificate and setServerCertificate exception syntax for DRM, mp4</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
-
- <!-- Content metadata -->
- <script src=/encrypted-media/content/content-metadata.js></script>
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/syntax-mediakeys.js></script>
-
- </head>
- <body>
- <div id='log'></div>
- <div id='video'>
- <video id="videoelement" width="200px"></video>
- </div>
- <script>
- var keysystem = getSupportedKeySystem();
- var contentItem = content['mp4-basic'],
- config = {
- keysystem: keysystem,
- content: contentItem,
- initData: stringToUint8Array(atob(contentItem.keys[0].initData)),
- initDataType: contentItem.initDataType,
- audioType: contentItem.audio.type,
- videoType: contentItem.video.type
- };
- runTest(config);
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/drm-mp4-syntax-mediakeysession.html b/testing/web-platform/tests/encrypted-media/drm-mp4-syntax-mediakeysession.html
deleted file mode 100644
index 0c737df9e..000000000
--- a/testing/web-platform/tests/encrypted-media/drm-mp4-syntax-mediakeysession.html
+++ /dev/null
@@ -1,43 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <title>Encrypted Media Extensions - Test MediaKeySession attribute and function syntax for DRM, mp4</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
-
- <!-- Content metadata -->
- <script src=/encrypted-media/content/content-metadata.js></script>
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/syntax-mediakeysession.js></script>
-
- </head>
- <body>
- <div id='log'></div>
- <div id='video'>
- <video id="videoelement" width="200px"></video>
- </div>
- <script>
- var keysystem = getSupportedKeySystem();
- var contentItem = content['mp4-basic'],
- config = {
- keysystem: keysystem,
- content: contentItem,
- initData: stringToUint8Array(atob(contentItem.keys[0].initData)),
- initDataType: contentItem.initDataType,
- audioType: contentItem.audio.type,
- videoType: contentItem.video.type
- };
- runTest(config);
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/drm-mp4-syntax-mediakeysystemaccess.html b/testing/web-platform/tests/encrypted-media/drm-mp4-syntax-mediakeysystemaccess.html
deleted file mode 100644
index d54e19437..000000000
--- a/testing/web-platform/tests/encrypted-media/drm-mp4-syntax-mediakeysystemaccess.html
+++ /dev/null
@@ -1,43 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <title>Encrypted Media Extensions - Test navigator.requestmediakeysystemaccess exception and MediaKeySystemAccess attribute syntax for DRM, mp4</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
-
- <!-- Content metadata -->
- <script src=/encrypted-media/content/content-metadata.js></script>
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/syntax-mediakeysystemaccess.js></script>
-
- </head>
- <body>
- <div id='log'></div>
- <div id='video'>
- <video id="videoelement" width="200px"></video>
- </div>
- <script>
- var keysystem = getSupportedKeySystem();
- var contentItem = content['mp4-basic'],
- config = {
- keysystem: keysystem,
- content: contentItem,
- initData: stringToUint8Array(atob(contentItem.keys[0].initData)),
- initDataType: contentItem.initDataType,
- audioType: contentItem.audio.type,
- videoType: contentItem.video.type
- };
- runTest(config);
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/drm-mp4-unique-origin.html b/testing/web-platform/tests/encrypted-media/drm-mp4-unique-origin.html
deleted file mode 100644
index a344ae5c0..000000000
--- a/testing/web-platform/tests/encrypted-media/drm-mp4-unique-origin.html
+++ /dev/null
@@ -1,44 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <title>Encrypted Media Extensions: Unique origin with DRM, mp4</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
-
- <!-- Content metadata -->
- <script src=/encrypted-media/content/content-metadata.js></script>
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/unique-origin.js></script>
-
- </head>
- <body>
- <div id='log'></div>
- <div id='video'>
- <video id="videoelement" width="200px"></video>
- </div>
-
- <script>
- var contentItem = content['mp4-av-multikey'],
- keysystem = getSupportedKeySystem(),
- config = {
- video: document.getElementById('videoelement'),
- keysystem: keysystem,
- initDataType: contentItem.initDataType,
- audioType: contentItem.audio.type,
- videoType: contentItem.video.type,
- audioPath: contentItem.audio.path,
- videoPath: contentItem.video.path
- };
- runTest(config);
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/drm-mp4-waiting-for-a-key.html b/testing/web-platform/tests/encrypted-media/drm-mp4-waiting-for-a-key.html
deleted file mode 100644
index 508afcacb..000000000
--- a/testing/web-platform/tests/encrypted-media/drm-mp4-waiting-for-a-key.html
+++ /dev/null
@@ -1,52 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <title>Encrypted Media Extensions - Waiting for a key for DRM, mp4</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
- <script src=/encrypted-media/util/testmediasource.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
-
- <!-- Message handler for DRM servers -->
- <script src=/encrypted-media/util/drm-messagehandler.js></script>
-
- <!-- Content metadata -->
- <script src=/encrypted-media/content/content-metadata.js></script>
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/waiting-for-a-key.js></script>
-
- </head>
- <body>
- <div id='log'></div>
- <div id='video'>
- <video id="videoelement" width="200px"></video>
- </div>
-
- <script>
- var contentItem = content['mp4-basic'],
- keysystem = getSupportedKeySystem(),
- handler = new MessageHandler( keysystem, contentItem ),
- config = {
- video: document.getElementById('videoelement'),
- keysystem: keysystem,
- content: contentItem,
- messageHandler: handler.messagehandler,
- initDataType: contentItem.initDataType,
- audioType: contentItem.audio.type,
- videoType: contentItem.video.type,
- audioPath: contentItem.audio.path,
- videoPath: contentItem.video.path,
- };
- runTest(config);
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/drm-not-callable-after-createsession.html b/testing/web-platform/tests/encrypted-media/drm-not-callable-after-createsession.html
deleted file mode 100644
index 22d9a1359..000000000
--- a/testing/web-platform/tests/encrypted-media/drm-not-callable-after-createsession.html
+++ /dev/null
@@ -1,35 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <title>Encrypted Media Extensions: Test MediaKeySession not callable immediately after CreateSession(), DRM.</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
-
- <!-- Message handler for DRM server -->
- <script src=/encrypted-media/util/drm-messagehandler.js></script>
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/not-callable-after-createsession.js></script>
-
- </head>
- <body>
- <div id='log'></div>
-
- <script>
- var config = { keysystem: getSupportedKeySystem()
- };
-
- runTest(config);
-
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/drm-temporary-license-type.html b/testing/web-platform/tests/encrypted-media/drm-temporary-license-type.html
deleted file mode 100644
index a4b54dac3..000000000
--- a/testing/web-platform/tests/encrypted-media/drm-temporary-license-type.html
+++ /dev/null
@@ -1,71 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <title>Encrypted Media Extensions: Test that persistent license cannot be ingested into temporary session</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Web Platform Test Harness scripts -->
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
- <script src=/encrypted-media/util/testmediasource.js></script>
-
- <!-- Content metadata -->
- <script src=/encrypted-media/content/content-metadata.js></script>
-
- <!-- Message handler for DRM servers -->
- <script src=/encrypted-media/util/drm-messagehandler.js></script>
-
- <!-- The script for this specific test -->
- <script src=/encrypted-media/scripts/temporary-license-type.js></script>
-
- </head>
- <body>
- <div id='log'></div>
-
- <script>
- var keysystem = getSupportedKeySystem();
-
- getSupportedContentAndInitDataTypes( keysystem )
- .then( function( supported )
- {
- // This test requires initData for supported content.
- // We prefer explicit initData configured for the content, but
- // otherwise we will generate initData for a supported initDataType
- // FIXME: Move me to a utility function
- var content,
- initDataType,
- initData;
-
- var contentWithExplicitInitData = supported.filter( function( s ) { return s.content.keys && s.content.initDataType; } );
- if ( contentWithExplicitInitData.length > 0 )
- {
- content = contentWithExplicitInitData[ 0 ].content;
- initDataType = content.keys[ 0 ].initDataType;
- initData = base64DecodeToUnit8Array( content.keys[ 0 ].initData );
- }
- else
- {
- content = supported[ 0 ].content;
- initDataType = supported[ 0 ].initDataTypes[ 0 ];
- initData = getInitData( content, initDataType );
- }
-
- var handler = new MessageHandler( keysystem, content, 'persistent-license' );
-
- runTest( { keysystem: keysystem,
- content: content,
- messagehandler: handler.messagehandler,
- initDataType: initDataType,
- initData: initData
- } );
- } );
-
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/idlharness.html b/testing/web-platform/tests/encrypted-media/idlharness.html
deleted file mode 100644
index e65ad5e30..000000000
--- a/testing/web-platform/tests/encrypted-media/idlharness.html
+++ /dev/null
@@ -1,51 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <title>Encrypted Media Extentions IDL test</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <script src=/resources/testharness.js></script>
- <script src=/resources/testharnessreport.js></script>
- <script src=/resources/WebIDLParser.js></script>
- <script src=/resources/idlharness.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
- </head>
- <body>
- <h1 class="instructions">Description</h1>
- <p class="instructions">
- This test verifies that implementations of the Encrypted Media Extensions API match its WebIDL definition.
- </p>
-
- <div id='log'></div>
-
- <script>
- setup(function() {
-
- fetch( 'EncryptedMediaExtensions.idl')
- .then( function( response ) {
- if ( !response.ok ) throw new Error( 'IDL fetch failed' );
- return response.text();
- } )
- .then( function( idls ) {
-
- var idl_array = new IdlArray();
- idl_array.add_untested_idls("[PrimaryGlobal] interface Window {};");
- idl_array.add_untested_idls("interface Navigator {};");
- idl_array.add_untested_idls("interface ArrayBuffer {};");
- idl_array.add_untested_idls("interface HTMLMediaElement {};");
- idl_array.add_untested_idls("interface Event {};");
- idl_array.add_untested_idls("interface EventTarget {};");
-
- idl_array.add_idls(idls);
-
- idl_array.test();
-
- done();
-
- } );
-
- }, {explicit_done: true});
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/polyfill/cast-polyfill.js b/testing/web-platform/tests/encrypted-media/polyfill/cast-polyfill.js
deleted file mode 100644
index 576e0ad04..000000000
--- a/testing/web-platform/tests/encrypted-media/polyfill/cast-polyfill.js
+++ /dev/null
@@ -1,80 +0,0 @@
-(function() {
-
- if ( /CrKey\/[0-9]+\.[0-9a-z]+\.[0-9a-z]+/i.exec( navigator.userAgent ) ) {
-
- var castscript = document.createElement('script');
- castscript.type = 'text/javascript';
- castscript.src = 'https://www.gstatic.com/cast/sdk/libs/receiver/2.0.0/cast_receiver.js'
- document.head.appendChild( castscript );
-
- var _requestMediaKeySystemAccess = navigator.requestMediaKeySystemAccess.bind( navigator ),
- _setMediaKeys = HTMLMediaElement.prototype.setMediaKeys,
- _load = MediaKeySession.prototype.load;
-
- MediaKeySession.prototype.load = function load()
- {
- return _load.call( this ).then( function( success )
- {
- return success ? this.remove() : false;
- }.bind( this ) );
- };
-
- function MediaKeys( mediaKeys )
- {
- this._mediaKeys = mediaKeys;
- }
-
- MediaKeys.prototype.setServerCertificate = function setServerCertificate( certificate )
- {
- return this._mediaKeys.setServerCertificate( certificate );
- };
-
- MediaKeys.prototype.createSession = function createSession( sessionType ) {
-
- if ( sessionType === 'persistent-usage-record' )
- {
- return cast.receiver.eme.KeySession.createSession( this._mediaKeys, 'persistent-release-message' );
- }
-
- return this._mediaKeys.createSession( sessionType );
- };
-
- function MediaKeySystemAccess( access )
- {
- this._access = mediaKeySystemAccess;
- }
-
- Object.defineProperty( MediaKeySystemAccess.prototype, 'keySystem', { get: function() { return this._access.keySystem; } } );
-
- MediaKeySystemAccess.prototype.getConfiguration = function getConfiguration() { return this._access.getConfiguration(); };
-
- MediaKeySystemAccess.prototype.createMediaKeys = function createMediaKeys() {
-
- return this._access.createMediaKey().then( function( mediaKeys ) { return new MediaKeys( mediaKeys ); } );
-
- };
-
- HTMLMediaElement.prototype.setMediaKeys = function setMediaKeys( mediaKeys )
- {
- if ( mediaKeys instanceof MediaKeys )
- {
- return _setMediaKeys.call( this, mediaKeys._mediaKeys );
- }
- else
- {
- return _setMediaKeys.call( this, mediaKeys );
- }
- };
-
- navigator.requestMediaKeySystemAccess = function requestMediaKeySystemAccess( keysystem, supportedConfigurations ) {
-
- if ( keysystem !== 'com.chromecast.playready' )
- {
- return _requestMediaKeySystemAccess( keysystem, supportedConfigurations );
- }
-
- return _requestMediaKeySystemAccess( keysystem, supportedConfigurations )
- .then( function( access ) { return new MediaKeySystemAccess( access ); } );
- };
- }
-})(); \ No newline at end of file
diff --git a/testing/web-platform/tests/encrypted-media/polyfill/chrome-polyfill.js b/testing/web-platform/tests/encrypted-media/polyfill/chrome-polyfill.js
deleted file mode 100644
index 2f11497cc..000000000
--- a/testing/web-platform/tests/encrypted-media/polyfill/chrome-polyfill.js
+++ /dev/null
@@ -1,37 +0,0 @@
-(function(){
- if( navigator.userAgent.toLowerCase().indexOf('edge') === -1
- && navigator.userAgent.toLowerCase().indexOf('chrome') > -1){
-
- if ( ( /chrome\/([0-9]*)\./.exec( navigator.userAgent.toLowerCase() )[1] | 0 ) < 54 ) {
-
- // Work around https://bugs.chromium.org/p/chromium/issues/detail?id=622956
- // Chrome does not fire the empty keystatuschange event when a session is closed
- var _mediaKeySessionClose = MediaKeySession.prototype.close;
- var _mediaKeySessionKeyStatusesGetter = Object.getOwnPropertyDescriptor( MediaKeySession.prototype, 'keyStatuses' ).get;
- var _emptyMediaKeyStatusMap = { size: 0,
- has: function() { return false; },
- get: function() { return undefined; },
- entries:function() { return []; }, // this may not be correct, I think it should be some iterator thing
- keys: function() { return []; },
- values: function() { return []; },
- forEach:function() { return; } };
-
- MediaKeySession.prototype.close = function close()
- {
- this.__closed = true;
-
- setTimeout( function() {
- this.dispatchEvent( new Event( 'keystatuseschange' ) );
- }.bind( this ), 0 );
-
- return _mediaKeySessionClose.call( this );
- };
-
- Object.defineProperty( MediaKeySession.prototype, 'keyStatuses', { get: function() {
-
- return this.__closed ? _emptyMediaKeyStatusMap : _mediaKeySessionKeyStatusesGetter.call( this );
-
- } } );
- }
- }
-}());
diff --git a/testing/web-platform/tests/encrypted-media/polyfill/clearkey-polyfill.js b/testing/web-platform/tests/encrypted-media/polyfill/clearkey-polyfill.js
deleted file mode 100644
index 057ea3e03..000000000
--- a/testing/web-platform/tests/encrypted-media/polyfill/clearkey-polyfill.js
+++ /dev/null
@@ -1,510 +0,0 @@
-(function(){
-
- // Save platform functions that will be modified
- var _requestMediaKeySystemAccess = navigator.requestMediaKeySystemAccess.bind( navigator ),
- _setMediaKeys = HTMLMediaElement.prototype.setMediaKeys;
-
- // Allow us to modify the target of Events
- Object.defineProperties( Event.prototype, {
- target: { get: function() { return this._target || this.currentTarget; },
- set: function( newtarget ) { this._target = newtarget; } }
- } );
-
- var EventTarget = function(){
- this.listeners = {};
- };
-
- EventTarget.prototype.listeners = null;
-
- EventTarget.prototype.addEventListener = function(type, callback){
- if(!(type in this.listeners)) {
- this.listeners[type] = [];
- }
- this.listeners[type].push(callback);
- };
-
- EventTarget.prototype.removeEventListener = function(type, callback){
- if(!(type in this.listeners)) {
- return;
- }
- var stack = this.listeners[type];
- for(var i = 0, l = stack.length; i < l; i++){
- if(stack[i] === callback){
- stack.splice(i, 1);
- return this.removeEventListener(type, callback);
- }
- }
- };
-
- EventTarget.prototype.dispatchEvent = function(event){
- if(!(event.type in this.listeners)) {
- return;
- }
- var stack = this.listeners[event.type];
- event.target = this;
- for(var i = 0, l = stack.length; i < l; i++) {
- stack[i].call(this, event);
- }
- };
-
- function MediaKeySystemAccessProxy( keysystem, access, configuration )
- {
- this._keysystem = keysystem;
- this._access = access;
- this._configuration = configuration;
- }
-
- Object.defineProperties( MediaKeySystemAccessProxy.prototype, {
- keysystem: { get: function() { return this._keysystem; } }
- });
-
- MediaKeySystemAccessProxy.prototype.getConfiguration = function getConfiguration()
- {
- return this._configuration;
- };
-
- MediaKeySystemAccessProxy.prototype.createMediaKeys = function createMediaKeys()
- {
- return new Promise( function( resolve, reject ) {
-
- this._access.createMediaKeys()
- .then( function( mediaKeys ) { resolve( new MediaKeysProxy( mediaKeys ) ); })
- .catch( function( error ) { reject( error ); } );
-
- }.bind( this ) );
- };
-
- function MediaKeysProxy( mediaKeys )
- {
- this._mediaKeys = mediaKeys;
- this._sessions = [ ];
- this._videoelement = undefined;
- this._onTimeUpdateListener = MediaKeysProxy.prototype._onTimeUpdate.bind( this );
- }
-
- MediaKeysProxy.prototype._setVideoElement = function _setVideoElement( videoElement )
- {
- if ( videoElement !== this._videoelement )
- {
- if ( this._videoelement )
- {
- this._videoelement.removeEventListener( 'timeupdate', this._onTimeUpdateListener );
- }
-
- this._videoelement = videoElement;
-
- if ( this._videoelement )
- {
- this._videoelement.addEventListener( 'timeupdate', this._onTimeUpdateListener );
- }
- }
- };
-
- MediaKeysProxy.prototype._onTimeUpdate = function( event )
- {
- this._sessions.forEach( function( session ) {
-
- if ( session._sessionType === 'persistent-usage-record' )
- {
- session._onTimeUpdate( event );
- }
-
- } );
- };
-
- MediaKeysProxy.prototype._removeSession = function _removeSession( session )
- {
- var index = this._sessions.indexOf( session );
- if ( index !== -1 ) this._sessions.splice( index, 1 );
- };
-
- MediaKeysProxy.prototype.createSession = function createSession( sessionType )
- {
- if ( !sessionType || sessionType === 'temporary' ) return this._mediaKeys.createSession();
-
- var session = new MediaKeySessionProxy( this, sessionType );
- this._sessions.push( session );
-
- return session;
- };
-
- MediaKeysProxy.prototype.setServerCertificate = function setServerCertificate( certificate )
- {
- return this._mediaKeys.setServerCertificate( certificate );
- };
-
- function MediaKeySessionProxy( mediaKeysProxy, sessionType )
- {
- EventTarget.call( this );
-
- this._mediaKeysProxy = mediaKeysProxy
- this._sessionType = sessionType;
- this._sessionId = "";
-
- // MediaKeySessionProxy states
- // 'created' - After initial creation
- // 'loading' - Persistent license session waiting for key message to load stored keys
- // 'active' - Normal active state - proxy all key messages
- // 'removing' - Release message generated, waiting for ack
- // 'closed' - Session closed
- this._state = 'created';
-
- this._closed = new Promise( function( resolve ) { this._resolveClosed = resolve; }.bind( this ) );
- }
-
- MediaKeySessionProxy.prototype = Object.create( EventTarget.prototype );
-
- Object.defineProperties( MediaKeySessionProxy.prototype, {
-
- sessionId: { get: function() { return this._sessionId; } },
- expiration: { get: function() { return NaN; } },
- closed: { get: function() { return this._closed; } },
- keyStatuses:{ get: function() { return this._session.keyStatuses; } }, // TODO this will fail if examined too early
- _kids: { get: function() { return this._keys.map( function( key ) { return key.kid; } ); } },
- });
-
- MediaKeySessionProxy.prototype._createSession = function _createSession()
- {
- this._session = this._mediaKeysProxy._mediaKeys.createSession();
-
- this._session.addEventListener( 'message', MediaKeySessionProxy.prototype._onMessage.bind( this ) );
- this._session.addEventListener( 'keystatuseschange', MediaKeySessionProxy.prototype._onKeyStatusesChange.bind( this ) );
- };
-
- MediaKeySessionProxy.prototype._onMessage = function _onMessage( event )
- {
- switch( this._state )
- {
- case 'loading':
- this._session.update( toUtf8( { keys: this._keys } ) )
- .then( function() {
- this._state = 'active';
- this._loaded( true );
- }.bind(this)).catch( this._loadfailed );
-
- break;
-
- case 'active':
- this.dispatchEvent( event );
- break;
-
- default:
- // Swallow the event
- break;
- }
- };
-
- MediaKeySessionProxy.prototype._onKeyStatusesChange = function _onKeyStatusesChange( event )
- {
- switch( this._state )
- {
- case 'active' :
- case 'removing' :
- this.dispatchEvent( event );
- break;
-
- default:
- // Swallow the event
- break;
- }
- };
-
- MediaKeySessionProxy.prototype._onTimeUpdate = function _onTimeUpdate( event )
- {
- if ( !this._firstTime ) this._firstTime = Date.now();
- this._latestTime = Date.now();
- this._store();
- };
-
- MediaKeySessionProxy.prototype._queueMessage = function _queueMessage( messageType, message )
- {
- setTimeout( function() {
-
- var messageAsArray = toUtf8( message ).buffer;
-
- this.dispatchEvent( new MediaKeyMessageEvent( 'message', { messageType: messageType, message: messageAsArray } ) );
-
- }.bind( this ) );
- };
-
- function _storageKey( sessionId )
- {
- return sessionId;
- }
-
- MediaKeySessionProxy.prototype._store = function _store()
- {
- var data;
-
- if ( this._sessionType === 'persistent-usage-record' )
- {
- data = { kids: this._kids };
- if ( this._firstTime ) data.firstTime = this._firstTime;
- if ( this._latestTime ) data.latestTime = this._latestTime;
- }
- else
- {
- data = { keys: this._keys };
- }
-
- window.localStorage.setItem( _storageKey( this._sessionId ), JSON.stringify( data ) );
- };
-
- MediaKeySessionProxy.prototype._load = function _load( sessionId )
- {
- var store = window.localStorage.getItem( _storageKey( sessionId ) );
- if ( store === null ) return false;
-
- var data;
- try { data = JSON.parse( store ) } catch( error ) {
- return false;
- }
-
- if ( data.kids )
- {
- this._sessionType = 'persistent-usage-record';
- this._keys = data.kids.map( function( kid ) { return { kid: kid }; } );
- if ( data.firstTime ) this._firstTime = data.firstTime;
- if ( data.latestTime ) this._latestTime = data.latestTime;
- }
- else
- {
- this._sessionType = 'persistent-license';
- this._keys = data.keys;
- }
-
- return true;
- };
-
- MediaKeySessionProxy.prototype._clear = function _clear()
- {
- window.localStorage.removeItem( _storageKey( this._sessionId ) );
- };
-
- MediaKeySessionProxy.prototype.generateRequest = function generateRequest( initDataType, initData )
- {
- if ( this._state !== 'created' ) return Promise.reject( new InvalidStateError() );
-
- this._createSession();
-
- this._state = 'active';
-
- return this._session.generateRequest( initDataType, initData )
- .then( function() {
- this._sessionId = Math.random().toString(36).slice(2);
- }.bind( this ) );
- };
-
- MediaKeySessionProxy.prototype.load = function load( sessionId )
- {
- if ( this._state !== 'created' ) return Promise.reject( new InvalidStateError() );
-
- return new Promise( function( resolve, reject ) {
-
- try
- {
- if ( !this._load( sessionId ) )
- {
- resolve( false );
-
- return;
- }
-
- this._sessionId = sessionId;
-
- if ( this._sessionType === 'persistent-usage-record' )
- {
- var msg = { kids: this._kids };
- if ( this._firstTime ) msg.firstTime = this._firstTime;
- if ( this._latestTime ) msg.latestTime = this._latestTime;
-
- this._queueMessage( 'license-release', msg );
-
- this._state = 'removing';
-
- resolve( true );
- }
- else
- {
- this._createSession();
-
- this._state = 'loading';
- this._loaded = resolve;
- this._loadfailed = reject;
-
- var initData = { kids: this._kids };
-
- this._session.generateRequest( 'keyids', toUtf8( initData ) );
- }
- }
- catch( error )
- {
- reject( error );
- }
- }.bind( this ) );
- };
-
- MediaKeySessionProxy.prototype.update = function update( response )
- {
- return new Promise( function( resolve, reject ) {
-
- switch( this._state ) {
-
- case 'active' :
-
- var message = fromUtf8( response );
-
- // JSON Web Key Set
- this._keys = message.keys;
-
- this._store();
-
- resolve( this._session.update( response ) );
-
- break;
-
- case 'removing' :
-
- this._state = 'closed';
-
- this._clear();
-
- this._mediaKeysProxy._removeSession( this );
-
- this._resolveClosed();
-
- delete this._session;
-
- resolve();
-
- break;
-
- default:
- reject( new InvalidStateError() );
- }
-
- }.bind( this ) );
- };
-
- MediaKeySessionProxy.prototype.close = function close()
- {
- if ( this._state === 'closed' ) return Promise.resolve();
-
- this._state = 'closed';
-
- this._mediaKeysProxy._removeSession( this );
-
- this._resolveClosed();
-
- var session = this._session;
- if ( !session ) return Promise.resolve();
-
- this._session = undefined;
-
- return session.close();
- };
-
- MediaKeySessionProxy.prototype.remove = function remove()
- {
- if ( this._state !== 'active' || !this._session ) return Promise.reject( new DOMException('InvalidStateError('+this._state+')') );
-
- this._state = 'removing';
-
- this._mediaKeysProxy._removeSession( this );
-
- return this._session.close()
- .then( function() {
-
- var msg = { kids: this._kids };
-
- if ( this._sessionType === 'persistent-usage-record' )
- {
- if ( this._firstTime ) msg.firstTime = this._firstTime;
- if ( this._latestTime ) msg.latestTime = this._latestTime;
- }
-
- this._queueMessage( 'license-release', msg );
-
- }.bind( this ) )
- };
-
- HTMLMediaElement.prototype.setMediaKeys = function setMediaKeys( mediaKeys )
- {
- if ( mediaKeys instanceof MediaKeysProxy )
- {
- mediaKeys._setVideoElement( this );
- return _setMediaKeys.call( this, mediaKeys._mediaKeys );
- }
- else
- {
- return _setMediaKeys.call( this, mediaKeys );
- }
- };
-
- navigator.requestMediaKeySystemAccess = function( keysystem, configurations )
- {
- // First, see if this is supported by the platform
- return new Promise( function( resolve, reject ) {
-
- _requestMediaKeySystemAccess( keysystem, configurations )
- .then( function( access ) { resolve( access ); } )
- .catch( function( error ) {
-
- if ( error instanceof TypeError ) reject( error );
-
- if ( keysystem !== 'org.w3.clearkey' ) reject( error );
-
- if ( !configurations.some( is_persistent_configuration ) ) reject( error );
-
- // Shallow copy the configurations, swapping out the labels and omitting the sessiontypes
- var configurations_copy = configurations.map( function( config, index ) {
-
- var config_copy = copy_configuration( config );
- config_copy.label = index.toString();
- return config_copy;
-
- } );
-
- // And try again with these configurations
- _requestMediaKeySystemAccess( keysystem, configurations_copy )
- .then( function( access ) {
-
- // Create the supported configuration based on the original request
- var configuration = access.getConfiguration(),
- original_configuration = configurations[ configuration.label ];
-
- // If the original configuration did not need persistent session types, then we're done
- if ( !is_persistent_configuration( original_configuration ) ) resolve( access );
-
- // Create the configuration that we will return
- var returned_configuration = copy_configuration( configuration );
-
- if ( original_configuration.label )
- returned_configuration.label = original_configuration;
- else
- delete returned_configuration.label;
-
- returned_configuration.sessionTypes = original_configuration.sessionTypes;
-
- resolve( new MediaKeySystemAccessProxy( keysystem, access, returned_configuration ) );
- } )
- .catch( function( error ) { reject( error ); } );
- } );
- } );
- };
-
- function is_persistent_configuration( configuration )
- {
- return configuration.sessionTypes &&
- ( configuration.sessionTypes.indexOf( 'persistent-usage-record' ) !== -1
- || configuration.sessionTypes.indexOf( 'persistent-license' ) !== -1 );
- }
-
- function copy_configuration( src )
- {
- var dst = {};
- [ 'label', 'initDataTypes', 'audioCapabilities', 'videoCapabilities', 'distinctiveIdenfifier', 'persistentState' ]
- .forEach( function( item ) { if ( src[item] ) dst[item] = src[item]; } );
- return dst;
- }
-}());
diff --git a/testing/web-platform/tests/encrypted-media/polyfill/edge-keystatuses.js b/testing/web-platform/tests/encrypted-media/polyfill/edge-keystatuses.js
deleted file mode 100644
index 886144459..000000000
--- a/testing/web-platform/tests/encrypted-media/polyfill/edge-keystatuses.js
+++ /dev/null
@@ -1,144 +0,0 @@
-(function() {
-
- // This polyfill fixes the following problems with Edge browser
- // (1) Various maplike methods for keystatuses are not supported or suported incorrectly
- // (2) Key Ids exposed in keystatuses are incorrect (byte swaps)
- if ( navigator.userAgent.toLowerCase().indexOf('edge') > -1 ) {
- ///////////////////////////////////////////////////////////////////////////////////////////////
- // The following function is the core of this JS patch. The rest of this file is infrastructure
- // required to enable this function
- ///////////////////////////////////////////////////////////////////////////////////////////////
- function _proxyKeyStatusesChange( event ) {
- this._keyStatuses.clear();
- var keyStatuses = [];
- this._session.keyStatuses.forEach( function( keyId, status ) {
- var newKeyId = new Uint8Array( keyId );
-
- function swap( arr, a, b ) { var t = arr[a]; arr[a] = arr[b]; arr[b] = t; }
- swap( newKeyId, 0, 3 );
- swap( newKeyId, 1, 2 );
- swap( newKeyId, 4, 5 );
- swap( newKeyId, 6, 7 );
-
- keyStatuses.push( { key: newKeyId, status: status, ord: arrayBufferAsString( newKeyId ) } );
- });
-
- function lexicographical( a, b ) { return a < b ? -1 : a === b ? 0 : +1; }
- function lexicographicalkey( a, b ) { return lexicographical( a.ord, b.ord ); }
-
- keyStatuses.sort( lexicographicalkey ).forEach( function( obj ) {
- this._keyStatuses._set( obj.key, obj.status );
- }.bind( this ) );
-
- this.dispatchEvent( event );
- };
- ///////////////////////////////////////////////////////////////////////////////////////////////
-
- // Override MediaKeys.createSession
- var _mediaKeysCreateSession = MediaKeys.prototype.createSession;
- MediaKeys.prototype.createSession = function ( sessionType ) {
- return new MediaKeySession( _mediaKeysCreateSession.call( this, sessionType ) );
- };
-
- // MediaKeySession proxy
- function MediaKeySession( session ) {
- EventTarget.call( this );
- this._session = session;
- this._keyStatuses = new MediaKeyStatusMap();
- this._session.addEventListener("keystatuseschange",this._onKeyStatusesChange.bind(this));
- this._session.addEventListener("message",this.dispatchEvent.bind(this));
- }
-
- MediaKeySession.prototype = Object.create( EventTarget.prototype );
-
- Object.defineProperties( MediaKeySession.prototype, {
- sessionId: { get: function() { return this._session.sessionId; } },
- expiration: { get: function() { return this._session.expiration; } },
- closed: { get: function() { return this._session.closed; } },
- keyStatuses:{ get: function() { return this._keyStatuses; } }
- });
-
- [ "generateRequest", "load", "update", "remove", "close" ].forEach( function( fnname ) {
- MediaKeySession.prototype[ fnname ] = function() {
- return window.MediaKeySession.prototype[ fnname ].apply( this._session, arguments );
- }
- } );
-
- MediaKeySession.prototype._onKeyStatusesChange = _proxyKeyStatusesChange;
-
- // MediaKeyStatusMap proxy
- //
- // We need a proxy class to replace the broken MediaKeyStatusMap one. We cannot use a
- // regular Map directly because we need get and has methods to compare by value not
- // as references.
- function MediaKeyStatusMap() { this._map = new Map(); }
-
- Object.defineProperties( MediaKeyStatusMap.prototype, {
- size: { get: function() { return this._map.size; } },
- forEach: { get: function() { return function( f ) { return this._map.forEach( f ); } } },
- entries: { get: function() { return function() { return this._map.entries(); } } },
- values: { get: function() { return function() { return this._map.values(); } } },
- keys: { get: function() { return function() { return this._map.keys(); } } },
- clear: { get: function() { return function() { return this._map.clear(); } } } } );
-
- MediaKeyStatusMap.prototype[ Symbol.iterator ] = function() { return this._map[ Symbol.iterator ]() };
-
- MediaKeyStatusMap.prototype.has = function has( keyId ) {
- for ( var k of this._map.keys() ) { if ( arrayBufferEqual( k, keyId ) ) return true; }
- return false;
- };
-
- MediaKeyStatusMap.prototype.get = function get( keyId ) {
- for ( var k of this._map.entries() ) { if ( arrayBufferEqual( k[ 0 ], keyId ) ) return k[ 1 ]; }
- };
-
- MediaKeyStatusMap.prototype._set = function _set( keyId, status ) {
- this._map.set( new Uint8Array( keyId ), status );
- };
-
- function arrayBufferEqual(buf1, buf2)
- {
- if (buf1.byteLength !== buf2.byteLength) return false;
- var a1 = Array.from( new Int8Array(buf1) ), a2 = Array.from( new Int8Array(buf2) );
- return a1.every( function( x, i ) { return x === a2[i]; } );
- }
-
- // EventTarget
- function EventTarget(){
- this.listeners = {};
- };
-
- EventTarget.prototype.listeners = null;
-
- EventTarget.prototype.addEventListener = function(type, callback){
- if(!(type in this.listeners)) {
- this.listeners[type] = [];
- }
- this.listeners[type].push(callback);
- };
-
- EventTarget.prototype.removeEventListener = function(type, callback){
- if(!(type in this.listeners)) {
- return;
- }
- var stack = this.listeners[type];
- for(var i = 0, l = stack.length; i < l; i++){
- if(stack[i] === callback){
- stack.splice(i, 1);
- return this.removeEventListener(type, callback);
- }
- }
- };
-
- EventTarget.prototype.dispatchEvent = function(event){
- if(!(event.type in this.listeners)) {
- return;
- }
- var stack = this.listeners[event.type];
- event.target = this;
- for(var i = 0, l = stack.length; i < l; i++) {
- stack[i].call(this, event);
- }
- };
- }
-})();
diff --git a/testing/web-platform/tests/encrypted-media/polyfill/edge-persistent-usage-record.js b/testing/web-platform/tests/encrypted-media/polyfill/edge-persistent-usage-record.js
deleted file mode 100644
index 7f86f0c05..000000000
--- a/testing/web-platform/tests/encrypted-media/polyfill/edge-persistent-usage-record.js
+++ /dev/null
@@ -1,193 +0,0 @@
-(function() {
-
- // This polyfill fixes the following problems with Edge browser
- // (1) To retrieve a persisted usage record, you must use session type 'persistent-release-message' instead of 'persistent-usage-record'
- // (2) To retrieve a persisted usage record, you must call remove() after calling load()
- // (3) On providing a license release acknowledgement, the session does not automatically close as is should
- // (4) Retrieval of the usage record at the end of an active session is not supported
-
- if ( navigator.userAgent.toLowerCase().indexOf('edge') > -1 ) {
-
- var _mediaKeySystemAccessCreateMediaKeys = MediaKeySystemAccess.prototype.createMediaKeys;
- _mediaKeysCreateSession = MediaKeys.prototype.createSession;
-
- // MediaKeySession proxy
- function MediaKeySession( mediaKeys, session )
- {
- EventTarget.call( this );
-
- this._mediaKeys = mediaKeys;
- this._session = session;
- this._sessionId = undefined;
- this._removing = false;
-
- session.addEventListener( 'message', this.dispatchEvent.bind( this ) );
- session.addEventListener( 'keystatuseschange', this.dispatchEvent.bind( this ) );
- session.closed.then( function() { if ( !this._removing ) this._resolveClosed(); }.bind ( this ) );
-
- this._closed = new Promise( function( resolve ) { this._resolveClosed = resolve; }.bind( this ) );
- }
-
- MediaKeySession.prototype = Object.create( EventTarget.prototype );
-
- Object.defineProperties( MediaKeySession.prototype, {
- sessionId: { get: function() { return this._sessionId ? this._sessionId : this._session.sessionId; } },
- expiration: { get: function() { return this._session.expiration; } },
- closed: { get: function() { return this._closed; } },
- keyStatuses:{ get: function() { return this._session.keyStatuses; } }
- });
-
- // load()
- //
- // Use a surrogate 'persistent-release-message' session to obtain the release message
- //
- MediaKeySession.prototype.load = function load( sessionId )
- {
- if ( this.sessionId ) return Promise.reject( new DOMException('InvalidAccessError') );
-
- this._surrogate = this._mediaKeys.createSession( 'persistent-release-message' );
- this._surrogate.addEventListener( 'message', this.dispatchEvent.bind( this ) );
-
- return this._surrogate.load( sessionId ).then( function( success ) {
- if (!success) return false;
-
- this._sessionId = sessionId;
- this._removing = true;
- this._session.close();
-
- return this._surrogate.remove().then( function() { return true; } );
- }.bind( this ) );
- };
-
- // remove()
- //
- // On an existing session, use a surrogate 'persistent-release-message' session to obtain the release message
- //
- MediaKeySession.prototype.remove = function remove()
- {
- if ( this._sessionId !== undefined ) return Promise.reject( new DOMException('InvalidAccessError') );
- if ( this.sessionId === undefined ) return Promise.reject( new DOMException('InvalidAccessError') );
-
- this._surrogate = this._mediaKeys.createSession( 'persistent-release-message' );
- this._surrogate.addEventListener( 'message', this.dispatchEvent.bind( this ) );
- this._removing = true;
- this._sessionId = this._session.sessionId;
-
- var self = this;
-
- return Promise.all( [ self._session.close(), self._session.closed ] ).then( function() {
- return self._surrogate.load( self._sessionId );
- }).then( function( success ) {
- if ( !success ) {
- throw new DOMException('InvalidAccessError');
- }
-
- return self._surrogate.remove();
- }).then( function() { return true; } );
- }
-
- // update()
- //
- // For a normal session, pass through, otherwise update the surrogate and close the proxy
- MediaKeySession.prototype.update = function update( message )
- {
- if ( !this._removing ) return this._session.update( message );
-
- return this._surrogate.update( message ).then( function() {
- this._sessionId = undefined;
- this._resolveClosed();
- }.bind( this ) );
- };
-
- // close() - pass through
- //
- MediaKeySession.prototype.close = function close()
- {
- if ( !this._removing ) return this._session.close();
- this._resolveClosed();
- return Promise.resolve();
- };
-
- // generateRequest() - pass through
- //
- MediaKeySession.prototype.generateRequest = function generateRequest( initDataType, initData )
- {
- if ( this.sessionId ) Promise.reject( new DOMException('InvalidAccessError') );
- return this._session.generateRequest( initDataType, initData );
- };
-
- // Wrap PlayReady persistent-usage-record sessions in our Proxy
- MediaKeys.prototype.createSession = function createSession( sessionType ) {
-
- var session = _mediaKeysCreateSession.call( this, sessionType );
- if ( this._keySystem !== 'com.microsoft.playready' || sessionType !== 'persistent-usage-record' )
- {
- return session;
- }
-
- return new MediaKeySession( this, session );
-
- };
-
- //
- // Annotation polyfills - annotate not otherwise available data
- //
-
- // Annotate MediaKeys with the keysystem
- MediaKeySystemAccess.prototype.createMediaKeys = function createMediaKeys()
- {
- return _mediaKeySystemAccessCreateMediaKeys.call( this ).then( function( mediaKeys ) {
- mediaKeys._keySystem = this.keySystem;
- return mediaKeys;
- }.bind( this ) );
- };
-
- //
- // Utilities
- //
-
- // Allow us to modify the target of Events
- Object.defineProperties( Event.prototype, {
- target: { get: function() { return this._target || this.currentTarget; },
- set: function( newtarget ) { this._target = newtarget; } }
- } );
-
- // Make an EventTarget base class
- function EventTarget(){
- this.listeners = {};
- };
-
- EventTarget.prototype.listeners = null;
-
- EventTarget.prototype.addEventListener = function(type, callback){
- if(!(type in this.listeners)) {
- this.listeners[type] = [];
- }
- this.listeners[type].push(callback);
- };
-
- EventTarget.prototype.removeEventListener = function(type, callback){
- if(!(type in this.listeners)) {
- return;
- }
- var stack = this.listeners[type];
- for(var i = 0, l = stack.length; i < l; i++){
- if(stack[i] === callback){
- stack.splice(i, 1);
- return this.removeEventListener(type, callback);
- }
- }
- };
-
- EventTarget.prototype.dispatchEvent = function(event){
- if(!(event.type in this.listeners)) {
- return;
- }
- var stack = this.listeners[event.type];
- event.target = this;
- for(var i = 0, l = stack.length; i < l; i++) {
- stack[i].call(this, event);
- }
- };
- }
-})();
diff --git a/testing/web-platform/tests/encrypted-media/polyfill/firefox-polyfill.js b/testing/web-platform/tests/encrypted-media/polyfill/firefox-polyfill.js
deleted file mode 100644
index ce241af36..000000000
--- a/testing/web-platform/tests/encrypted-media/polyfill/firefox-polyfill.js
+++ /dev/null
@@ -1,23 +0,0 @@
-(function(){
- if(navigator.userAgent.toLowerCase().indexOf('firefox') > -1){
-
- // Work around https://bugzilla.mozilla.org/show_bug.cgi?id=1282142
- // Firefox does not correctly reject the Clear Key session types it does not support
- var _requestMediaKeySystemAccess = navigator.requestMediaKeySystemAccess.bind( navigator );
-
- navigator.requestMediaKeySystemAccess = function( keysystem, configurations )
- {
- if ( keysystem !== 'org.w3.clearkey' ) return _requestMediaKeySystemAccess( keysystem, configurations );
-
- var supported_configurations = configurations.filter( function( c ) {
-
- return !c.sessionTypes || ( c.sessionTypes.length === 1 && c.sessionTypes[ 0 ] === 'temporary' );
-
- } );
-
- if ( supported_configurations.length === 0 ) return Promise.reject( new DOMException( 'None of the requested configurations were supported.' ) );
-
- return _requestMediaKeySystemAccess( keysystem, supported_configurations );
- }
- }
-}()); \ No newline at end of file
diff --git a/testing/web-platform/tests/encrypted-media/polyfill/make-polyfill-tests.py b/testing/web-platform/tests/encrypted-media/polyfill/make-polyfill-tests.py
deleted file mode 100644
index b4248569a..000000000
--- a/testing/web-platform/tests/encrypted-media/polyfill/make-polyfill-tests.py
+++ /dev/null
@@ -1,29 +0,0 @@
-#!/usr/bin/python
-import os, re, os.path, glob
-
-head = re.compile( r"^(\s*</head>)", re.MULTILINE )
-runtest = re.compile( r"runTest\(\s*(\S.*?)\s*\)", re.DOTALL )
-
-scripts = '''
- <!-- Polyfill files (NOTE: These are added by auto-generation script) -->
- <script src=/encrypted-media/polyfill/chrome-polyfill.js></script>
- <script src=/encrypted-media/polyfill/firefox-polyfill.js></script>
- <script src=/encrypted-media/polyfill/edge-persistent-usage-record.js></script>
- <script src=/encrypted-media/polyfill/edge-keystatuses.js></script>
- <script src=/encrypted-media/polyfill/clearkey-polyfill.js></script>'''
-
-def process_file( infile, outfile ) :
- with open( outfile, "w" ) as output :
- with open( infile, "r" ) as input :
- output.write( runtest.sub( r"runTest( \1, 'polyfill: ' )", head.sub( scripts + r"\1", input.read() ) ) )
-
-if __name__ == '__main__' :
- if (not os.getcwd().endswith('polyfill')) :
- print "Please run from polyfill directory"
- exit( 1 )
-
- for infile in glob.glob( "../*.html" ) :
- process_file( infile, os.path.basename( infile ) )
-
- for infile in glob.glob( "../resources/*.html" ) :
- process_file( infile, os.path.join( "resources", os.path.basename( infile ) ) ) \ No newline at end of file
diff --git a/testing/web-platform/tests/encrypted-media/resources/clearkey-retrieve-destroy-persistent-license.html b/testing/web-platform/tests/encrypted-media/resources/clearkey-retrieve-destroy-persistent-license.html
deleted file mode 100644
index b1bec547e..000000000
--- a/testing/web-platform/tests/encrypted-media/resources/clearkey-retrieve-destroy-persistent-license.html
+++ /dev/null
@@ -1,106 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <title>Encrypted Media Extensions: persistent-license, retrieve and destroy, ClearKey</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
- <script src=/encrypted-media/util/testmediasource.js></script>
-
- <!-- Message handler for Clear Key keysystem -->
- <script src=/encrypted-media/util/clearkey-messagehandler.js></script>
-
- </head>
- <body>
- <div id='log'></div>
-
- <div id='video'>
- <video id="videoelement" width="200px"></video>
- </div>
-
- <script>
- // Wait for a message from the main window with details of our task
- window.addEventListener( 'message', function( event ) {
-
- var config = event.data.config,
- configuration = { initDataTypes: [ config.initDataType ],
- audioCapabilities: [ { contentType: config.audioType } ],
- videoCapabilities: [ { contentType: config.videoType } ],
- sessionTypes: [ 'persistent-license' ] },
- assertions = [ ];
-
- var _mediaKeys,
- _mediaKeySession;
-
- config.video = document.getElementById('videoelement');
- config.messagehandler = (new MessageHandler( 'org.w3.clearkey')).messagehandler;
-
- function onComplete() {
- window.opener.postMessage(assertions, '*');
- }
-
- function onFailure(error) {
- assertions.push( { actual: false, expected: true, message: error.toString() } );
- onComplete();
- }
-
- function onMessage( messageevent )
- {
- assertions.push( { expected: true, actual: messageevent instanceof window.MediaKeyMessageEvent, message: "event is of correct class" } );
- assertions.push( { expected: 'message', actual: messageevent.type, message: "event type is message" } );
- assertions.push( { expected: 'license-release', actual: messageevent.messageType, message: "message type is license-release" } );
-
- config.messagehandler( messageevent.messageType, messageevent.message )
- .then( function( response ) {
- messageevent.target.update( response ).catch(onFailure);
- });
- }
-
- function onTimeupdate(event) {
- if ( config.video.currentTime > ( config.duration || 1 ) ) {
- config.video.pause();
- config.video.removeAttribute('src');
- config.video.load();
- _mediaKeySession.remove();
- }
- }
-
- function onClosed() {
- // Try and reload and check this fails
- var mediaKeySession = _mediaKeys.createSession( 'persistent-license' );
- mediaKeySession.load( event.data.sessionId ).then( function( success ) {
- assertions.push( { expected: false, actual: success, message: "Load of removed session should fail" } );
- onComplete();
- }).catch(onFailure);
- }
-
- navigator.requestMediaKeySystemAccess(config.keysystem, [ configuration ] )
- .then(function(access) {
- return access.createMediaKeys();
- }).then(function(mediaKeys) {
- _mediaKeys = mediaKeys;
- return config.video.setMediaKeys(mediaKeys);
- }).then(function() {
- config.video.addEventListener('timeupdate', onTimeupdate, true);
- _mediaKeySession = _mediaKeys.createSession( 'persistent-license' );
- _mediaKeySession.addEventListener( 'message', onMessage );
- _mediaKeySession.closed.then(onClosed);
- return _mediaKeySession.load( event.data.sessionId );
- }).then(function( success ) {
- assertions.push( { actual: success, expected: true, message: "Expect load session to succeed" } );
- if ( !success ) throw new DOMException();
- return testmediasource(config);
- }).then(function(source) {
- config.video.src = URL.createObjectURL(source);
- config.video.play();
- })
- .catch(onFailure);
- } );
-
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/resources/clearkey-retrieve-persistent-license.html b/testing/web-platform/tests/encrypted-media/resources/clearkey-retrieve-persistent-license.html
deleted file mode 100644
index 78ca4e1bb..000000000
--- a/testing/web-platform/tests/encrypted-media/resources/clearkey-retrieve-persistent-license.html
+++ /dev/null
@@ -1,74 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <title>Encrypted Media Extensions: persistent-license, retrieve and playback, ClearKey</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
- <script src=/encrypted-media/util/testmediasource.js></script>
-
- </head>
- <body>
- <div id='log'></div>
-
- <div id='video'>
- <video id="videoelement" width="200px"></video>
- </div>
-
- <script>
- // Wait for a message from the main window with details of our task
- window.addEventListener( 'message', function( event ) {
-
- var config = event.data.config,
- configuration = { initDataTypes: [ config.initDataType ],
- audioCapabilities: [ { contentType: config.audioType } ],
- videoCapabilities: [ { contentType: config.videoType } ],
- sessionTypes: [ 'persistent-license' ] },
- assertions = [ ];
-
- var _mediaKeySession;
-
- config.video = document.getElementById('videoelement');
-
- function onComplete() {
- window.opener.postMessage(assertions, '*');
- }
-
- function onFailure(error) {
- assertions.push( { actual: false, expected: true, message: error.toString() } );
- onComplete();
- }
-
- function onTimeupdate(event) {
- if ( config.video.currentTime > ( config.duration || 1 ) ) {
- config.video.pause();
- _mediaKeySession.close()
- }
- }
-
- navigator.requestMediaKeySystemAccess(config.keysystem, [ configuration ] )
- .then(function(access) {
- return access.createMediaKeys();
- }).then(function(mediaKeys) {
- config.video.setMediaKeys(mediaKeys);
- config.video.addEventListener('timeupdate', onTimeupdate, true);
- _mediaKeySession = mediaKeys.createSession( 'persistent-license' );
- _mediaKeySession.closed.then(onComplete);
- return _mediaKeySession.load(event.data.sessionId);
- }).then(function( success ) {
- if ( !success ) throw new DOMException( 'Could not load session' );
- return testmediasource(config);
- }).then(function(source) {
- config.video.src = URL.createObjectURL(source);
- config.video.play();
- })
- .catch(onFailure);
- } );
-
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/resources/drm-retrieve-destroy-persistent-license.html b/testing/web-platform/tests/encrypted-media/resources/drm-retrieve-destroy-persistent-license.html
deleted file mode 100644
index 21a05e879..000000000
--- a/testing/web-platform/tests/encrypted-media/resources/drm-retrieve-destroy-persistent-license.html
+++ /dev/null
@@ -1,107 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <title>Encrypted Media Extensions: persistent-license, retrieve and destroy, drm</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
- <script src=/encrypted-media/util/testmediasource.js></script>
-
- <!-- Message handler for DRM keysystem -->
- <script src=/encrypted-media/util/drm-messagehandler.js></script>
-
- </head>
- <body>
- <div id='log'></div>
-
- <div id='video'>
- <video id="videoelement" width="200px"></video>
- </div>
-
- <script>
- // Wait for a message from the main window with details of our task
- window.addEventListener( 'message', function( event ) {
-
- var config = event.data.config,
- configuration = { initDataTypes: [ config.initDataType ],
- audioCapabilities: [ { contentType: config.audioType } ],
- videoCapabilities: [ { contentType: config.videoType } ],
- sessionTypes: [ 'persistent-license' ] },
- assertions = [ ];
-
- var _mediaKeys,
- _mediaKeySession;
-
- config.video = document.getElementById('videoelement');
- config.messagehandler = (new MessageHandler( config.keysystem, undefined, 'persistent-license' ) ).messagehandler;
-
-function onComplete() {
- window.opener.postMessage(assertions, '*');
- }
-
- function onFailure(error) {
- assertions.push( { actual: false, expected: true, message: error.toString() } );
- onComplete();
- }
-
- function onMessage( messageevent )
- {
- assertions.push( { expected: true, actual: messageevent instanceof window.MediaKeyMessageEvent, message: "event is of correct class" } );
- assertions.push( { expected: 'message', actual: messageevent.type, message: "event type is message" } );
- assertions.push( { expected: 'license-release', actual: messageevent.messageType, message: "message type is license-release" } );
-
- config.messagehandler( messageevent.messageType, messageevent.message )
- .then( function( response ) {
- messageevent.target.update( response ).catch(onFailure);
- });
- }
-
- function onTimeupdate(event) {
- if ( config.video.currentTime > ( config.duration || 1 ) ) {
- config.video.pause();
- config.video.removeAttribute('src');
- config.video.load();
- _mediaKeySession.remove();
- }
- }
-
- function onClosed() {
- // Try and reload and check this fails
- var mediaKeySession = _mediaKeys.createSession( 'persistent-license' );
- mediaKeySession.load( event.data.sessionId ).then( function( success ) {
- assertions.push( { expected: false, actual: success, message: "Load of removed session should fail" } );
- onComplete();
- }).catch(onFailure);
- }
-
- navigator.requestMediaKeySystemAccess(config.keysystem, [ configuration ] )
- .then(function(access) {
- return access.createMediaKeys();
- }).then(function(mediaKeys) {
- _mediaKeys = mediaKeys;
- return config.video.setMediaKeys(mediaKeys);
- }).then(function() {
- config.video.addEventListener('timeupdate', onTimeupdate, true);
- _mediaKeySession = _mediaKeys.createSession( 'persistent-license' );
- _mediaKeySession.addEventListener( 'message', onMessage );
- _mediaKeySession.closed.then(onClosed);
- return _mediaKeySession.load( event.data.sessionId );
- }).then(function( success ) {
- assertions.push( { actual: success, expected: true, message: "Expect load session to succeed" } );
- if ( !success ) throw new DOMException();
- return testmediasource(config);
- }).then(function(source) {
- config.video.src = URL.createObjectURL(source);
- config.video.play();
- })
- .catch(onFailure);
- } );
-
-
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/resources/drm-retrieve-persistent-license.html b/testing/web-platform/tests/encrypted-media/resources/drm-retrieve-persistent-license.html
deleted file mode 100644
index 6f3ed80ff..000000000
--- a/testing/web-platform/tests/encrypted-media/resources/drm-retrieve-persistent-license.html
+++ /dev/null
@@ -1,72 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <title>Encrypted Media Extensions: persistent-license, retrieve and playback, DRM</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
- <script src=/encrypted-media/util/testmediasource.js></script>
- </head>
- <body>
- <div id='log'></div>
-
- <div id='video'>
- <video id="videoelement" width="200px"></video>
- </div>
-
- <script>
- // Wait for a message from the main window with details of our task
- window.addEventListener( 'message', function( event ) {
-
- var config = event.data.config,
- configuration = { initDataTypes: [ config.initDataType ],
- audioCapabilities: [ { contentType: config.audioType } ],
- videoCapabilities: [ { contentType: config.videoType } ],
- sessionTypes: [ 'persistent-license' ] },
- assertions = [ ];
-
- var _mediaKeySession;
- config.video = document.getElementById('videoelement');
-
- function onComplete() {
- window.opener.postMessage(assertions, '*');
- }
-
- function onFailure(error) {
- assertions.push( { actual: false, expected: true, message: error.toString() } );
- onComplete();
- }
-
- function onTimeupdate(event) {
- if ( config.video.currentTime > ( config.duration || 1 ) ) {
- config.video.pause();
- _mediaKeySession.close()
- }
- }
-
- navigator.requestMediaKeySystemAccess(config.keysystem, [ configuration ] )
- .then(function(access) {
- return access.createMediaKeys();
- }).then(function(mediaKeys) {
- config.video.setMediaKeys(mediaKeys);
- config.video.addEventListener('timeupdate', onTimeupdate, true);
- _mediaKeySession = mediaKeys.createSession( 'persistent-license' );
- _mediaKeySession.closed.then(onComplete);
- return _mediaKeySession.load(event.data.sessionId);
- }).then(function( success ) {
- if ( !success ) throw new DOMException( 'Could not load session' );
- return testmediasource(config);
- }).then(function(source) {
- config.video.src = URL.createObjectURL(source);
- config.video.play();
- })
- .catch(onFailure);
- } );
-
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/resources/drm-retrieve-persistent-usage-record.html b/testing/web-platform/tests/encrypted-media/resources/drm-retrieve-persistent-usage-record.html
deleted file mode 100644
index 935f77748..000000000
--- a/testing/web-platform/tests/encrypted-media/resources/drm-retrieve-persistent-usage-record.html
+++ /dev/null
@@ -1,71 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <title>Encrypted Media Extensions: Retrieve stored persistent-usage-record</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
-
- <!-- Message handler for Clear Key keysystem -->
- <script src=/encrypted-media/util/drm-messagehandler.js></script>
-
- </head>
- <body>
- <div id='log'></div>
-
- <script>
- window.addEventListener( 'message', function( event ) {
-
- var config = event.data.config,
- configuration = { initDataTypes: [ config.initDataType ],
- audioCapabilities: [ { contentType: config.audioType } ],
- videoCapabilities: [ { contentType: config.videoType } ],
- sessionTypes: [ 'persistent-usage-record' ] },
- assertions = [ ],
- _mediaKeys,
- _mediaKeySession;
-
- config.messagehandler = (new MessageHandler( config.keysystem, undefined, 'persistent-usage-record' ) ).messagehandler;
-
- function onFailure(error) {
- assertions.push( { actual: false, expected: true, message: error } );
- window.opener.postMessage(assertions, '*');
- }
-
- function onMessage( event )
- {
- assertions.push( { expected: true, actual: event instanceof window.MediaKeyMessageEvent, message: "event is of correct class" } );
- assertions.push( { expected: 'message', actual: event.type, message: "event type is message" } );
- assertions.push( { expected: 'license-release', actual: event.messageType, message: "message type is license-release" } );
-
- config.messagehandler( event.messageType, event.message ).then( function( response ) {
- event.target.update( response ).catch( onFailure );
- });
- }
-
- navigator.requestMediaKeySystemAccess(config.keysystem, [ configuration ] ).then(function(access) {
- return access.createMediaKeys();
- }).then(function(mediaKeys) {
- _mediaKeys = mediaKeys;
- return config.servercertificate ? _mediaKeys.setServerCertificate( config.servercertificate ) : true;
- }).then( function( success ) {
- _mediaKeySession = _mediaKeys.createSession( 'persistent-usage-record' );
- _mediaKeySession.addEventListener( 'message', onMessage );
- _mediaKeySession.closed.then( function() {
- window.opener.postMessage(assertions, '*');
- });
- return _mediaKeySession.load( event.data.sessionId );
- }).then(function( success ) {
- if ( !success ) {
- assertions.push( { actual: success, expected: true, message: "Error loading session" } );
- window.opener.postMessage(assertions, '*');
- }
- }).catch( onFailure );
- });
- </script>
- </body>
-</html>
diff --git a/testing/web-platform/tests/encrypted-media/resources/retrieve-persistent-usage-record.html b/testing/web-platform/tests/encrypted-media/resources/retrieve-persistent-usage-record.html
deleted file mode 100644
index 339e3c3ae..000000000
--- a/testing/web-platform/tests/encrypted-media/resources/retrieve-persistent-usage-record.html
+++ /dev/null
@@ -1,93 +0,0 @@
-<!doctype html>
-<html>
- <head>
- <meta charset=utf-8>
- <title>Encrypted Media Extensions: Retrieve stored persistent-usage-record</title>
- <link rel="help" href="https://w3c.github.io/encrypted-media/">
-
- <!-- Helper scripts for Encrypted Media Extensions tests -->
- <script src=/encrypted-media/util/utils.js></script>
- <script src=/encrypted-media/util/fetch.js></script>
- <script src=/encrypted-media/util/utf8.js></script>
-
- <!-- Message handler for Clear Key keysystem -->
- <script src=/encrypted-media/util/clearkey-messagehandler.js></script>
-
- </head>
- <body>
- <div id='log'></div>
-
- <script>
-
- window.addEventListener( 'message', function( event ) {
-
- var config = event.data.config,
- configuration = { initDataTypes: [ config.initDataType ],
- audioCapabilities: [ { contentType: config.audioType } ],
- videoCapabilities: [ { contentType: config.videoType } ],
- sessionTypes: [ 'persistent-usage-record' ] },
- assertions = [ ];
-
- config.messagehandler = (new MessageHandler('org.w3.keysystem')).messagehandler;
-
- function onMessage( event )
- {
- assertions.push( { expected: true, actual: event instanceof window.MediaKeyMessageEvent, message: "event is of correct class" } );
- assertions.push( { expected: 'message', actual: event.type, message: "event type is message" } );
- assertions.push( { expected: 'license-release', actual: event.messageType, message: "message type is license-release" } );
-
- var release = fromUtf8( event.message );
-
- consoleWrite( JSON.stringify( release ) );
-
- assertions.push( { expected: 1, actual: release.kids.length, message: "release message contains a single key" } );
- assertions.push( { expected: true, actual: ( typeof release.firstTime === 'number' ), message: "firstTime is a number" } );
- assertions.push( { expected: true, actual: ( typeof release.latestTime === 'number' ), message: "latestTime is a number" } );
-
- var duration = release.latestTime - release.firstTime;
- assertions.push( { expected: true, actual: ( duration >= 2000 ), message: "duration >= 2s" } );
- assertions.push( { expected: true, actual: ( duration < 4000 ), message: "duration < 4s" } );
-
- config.messagehandler( event.messageType, event.message )
- .then( function( response ) {
-
- event.target.update( response ).catch(function(error) {
-
- assertions.push( { actual: false, expected: true, message: error } );
-
- window.opener.postMessage(assertions, '*');
- });
- });
- }
-
- navigator.requestMediaKeySystemAccess(config.keysystem, [ configuration ] ).then(function(access) {
-
- return access.createMediaKeys();
-
- }).then(function(mediaKeys) {
-
- var mediaKeySession = mediaKeys.createSession( 'persistent-usage-record' );
-
- mediaKeySession.addEventListener( 'message', onMessage );
- mediaKeySession.closed.then( function() {
-
- window.opener.postMessage(assertions, '*');
-
- });
-
- return mediaKeySession.load( event.data.sessionId );
-
- }).catch(function(error) {
-
- assertions.push( { actual: false, expected: true, message: error.toString() } );
-
- window.opener.postMessage(assertions, '*');
-
- });
-
-
- } );
-
- </script>
- </body>
-</html> \ No newline at end of file
diff --git a/testing/web-platform/tests/encrypted-media/scripts/check-initdata-type.js b/testing/web-platform/tests/encrypted-media/scripts/check-initdata-type.js
deleted file mode 100644
index 5c7cb6e4b..000000000
--- a/testing/web-platform/tests/encrypted-media/scripts/check-initdata-type.js
+++ /dev/null
@@ -1,35 +0,0 @@
- function runTest( config, qualifier )
- {
- function checkInitDataType(initDataType)
- {
- return isInitDataTypeSupported(initDataType).then(function(result) {
- // If |initDataType| is not supported, simply succeed.
- if (!result)
- return Promise.resolve('Not supported');
-
- return navigator.requestMediaKeySystemAccess( config.keysystem, getSimpleConfigurationForInitDataType(initDataType))
- .then(function(access) {
- return access.createMediaKeys();
- }).then(function(mediaKeys) {
- var mediaKeySession = mediaKeys.createSession();
- var initData = getInitData(initDataType);
- return mediaKeySession.generateRequest(initDataType, initData);
- });
- });
- }
-
- promise_test(function()
- {
- return checkInitDataType('webm');
- }, testnamePrefix( qualifier, config.keysystem ) + ' support for "webm".');
-
- promise_test(function()
- {
- return checkInitDataType('cenc');
- }, testnamePrefix( qualifier, config.keysystem ) + ' support for "cenc".');
-
- promise_test(function()
- {
- return checkInitDataType('keyids');
- }, testnamePrefix( qualifier, config.keysystem ) + ' support for "keyids".');
-}
diff --git a/testing/web-platform/tests/encrypted-media/scripts/clearkey-update-non-ascii-input.js b/testing/web-platform/tests/encrypted-media/scripts/clearkey-update-non-ascii-input.js
deleted file mode 100644
index b34c493fd..000000000
--- a/testing/web-platform/tests/encrypted-media/scripts/clearkey-update-non-ascii-input.js
+++ /dev/null
@@ -1,48 +0,0 @@
-// This test is only applicable to clearkey
-function runTest(config, qualifier)
-{
- var testname = testnamePrefix(qualifier, config.keysystem) + ' test handling of non-ASCII responses for update()';
-
- var configuration = getSimpleConfigurationForContent(config.content);
-
- if (config.initDataType) {
- configuration.initDataTypes = [config.initDataType];
- }
-
- promise_test(function (test) {
- var initDataType;
- var initData;
- var mediaKeySession;
- var messageEventFired = false;
-
- return navigator.requestMediaKeySystemAccess(config.keysystem, [configuration]).then(function (access) {
- initDataType = access.getConfiguration().initDataTypes[0];
- initData = getInitData(config.content, initDataType);
- return access.createMediaKeys();
- }).then(function (mediaKeys) {
- mediaKeySession = mediaKeys.createSession();
- var eventWatcher = new EventWatcher(test, mediaKeySession, ['message']);
- var promise = eventWatcher.wait_for('message');
- mediaKeySession.generateRequest(initDataType, initData);
- return promise;
- }).then(function (messageEvent) {
- // |jwkSet| contains a non-ASCII character \uDC00.
- var jwkSet = '{"keys":[{'
- + '"kty":"oct",'
- + '"k":"MDEyMzQ1Njc4OTAxMjM0NQ",'
- + '"kid":"MDEyMzQ1Njc4O\uDC00TAxMjM0NQ"'
- + '}]}';
- messageEventFired = true;
- return messageEvent.target.update(stringToUint8Array(jwkSet));
- }).then(function () {
- assert_unreached('Error: update() should fail because the processed message has non-ASCII character.');
- }).catch(function (error) {
- if(messageEventFired){
- assert_equals(error.name, 'TypeError');
- }
- else {
- assert_unreached('Error: ' + error.name);
- }
- });
- }, testname);
-} \ No newline at end of file
diff --git a/testing/web-platform/tests/encrypted-media/scripts/events-session-closed-event.js b/testing/web-platform/tests/encrypted-media/scripts/events-session-closed-event.js
deleted file mode 100644
index 44f683eac..000000000
--- a/testing/web-platform/tests/encrypted-media/scripts/events-session-closed-event.js
+++ /dev/null
@@ -1,52 +0,0 @@
-function runTest(config, qualifier)
-{
- var testname = testnamePrefix(qualifier, config.keysystem) + ' test MediaKeySession closed event.';
-
- var configuration = {
- initDataTypes: [config.initDataType],
- audioCapabilities: [{
- contentType: config.audioType
- }],
- videoCapabilities: [{
- contentType: config.videoType
- }],
- sessionTypes: ['temporary']
- };
-
- promise_test(function (test) {
- var initDataType;
- var initData;
- var mediaKeySession;
-
- return navigator.requestMediaKeySystemAccess(config.keysystem, [configuration]).then(function (access) {
- initDataType = access.getConfiguration().initDataTypes[0];
- return access.createMediaKeys();
- }).then(function (mediaKeys) {
- mediaKeySession = mediaKeys.createSession();
- if(config.initData) {
- initData = config.initData;
- } else {
- initData = stringToUint8Array(atob(config.content.keys[0].initData));
- }
- return mediaKeySession.generateRequest(initDataType, initData);
- }).then(function() {
- // close() should result in the closed promise being
- // fulfilled.
- return mediaKeySession.close();
- }).then(function (result) {
- assert_equals(result, undefined);
- // Wait for the session to be closed.
- return mediaKeySession.closed;
- }).then(function (result) {
- assert_equals(result, undefined);
- // Now that the session is closed, verify that the
- // closed attribute immediately returns a fulfilled
- // promise.
- return mediaKeySession.closed;
- }).then(function (result) {
- assert_equals(result, undefined);
- }).catch(function(error) {
- assert_unreached('Error: ' + error.name);
- });
- }, testname);
-} \ No newline at end of file
diff --git a/testing/web-platform/tests/encrypted-media/scripts/events.js b/testing/web-platform/tests/encrypted-media/scripts/events.js
deleted file mode 100644
index 85c86ae78..000000000
--- a/testing/web-platform/tests/encrypted-media/scripts/events.js
+++ /dev/null
@@ -1,59 +0,0 @@
-function runTest(config,qualifier) {
-
- var testname = testnamePrefix(qualifier, config.keysystem) + ', basic events';
-
- var configuration = getSimpleConfigurationForContent(config.content);
-
- if (config.initDataType && config.initData) {
- configuration.initDataTypes = [config.initDataType];
- }
-
- async_test(function(test)
- {
- var initDataType;
- var initData;
- var mediaKeySession;
-
- function onFailure(error) {
- forceTestFailureFromPromise(test, error);
- }
-
- function processMessage(event)
- {
- assert_true(event instanceof window.MediaKeyMessageEvent);
- assert_equals(event.target, mediaKeySession);
- assert_equals(event.type, 'message');
- assert_in_array(event.messageType,['license-request', 'individualization-request']);
-
- config.messagehandler( event.messageType, event.message ).then(function(response) {
- waitForEventAndRunStep('keystatuseschange', mediaKeySession, test.step_func(processKeyStatusesChange), test);
- return mediaKeySession.update( response );
- }).catch(onFailure);
- }
-
- function processKeyStatusesChange(event)
- {
- assert_true(event instanceof Event);
- assert_equals(event.target, mediaKeySession);
- assert_equals(event.type, 'keystatuseschange');
- test.done();
- }
-
- navigator.requestMediaKeySystemAccess(config.keysystem,[configuration]).then(function(access) {
- initDataType = access.getConfiguration().initDataTypes[0];
-
- if (config.initDataType && config.initData) {
- initData = config.initData;
- } else {
- initData = getInitData(config.content, initDataType);
- }
-
- return access.createMediaKeys();
- }).then(test.step_func(function(mediaKeys) {
- mediaKeySession = mediaKeys.createSession();
- waitForEventAndRunStep('message', mediaKeySession, test.step_func(processMessage), test);
- return mediaKeySession.generateRequest(initDataType, initData);
- })).catch(onFailure);
- }, testname );
-
-}
diff --git a/testing/web-platform/tests/encrypted-media/scripts/expiration.js b/testing/web-platform/tests/encrypted-media/scripts/expiration.js
deleted file mode 100644
index 96b7fbfee..000000000
--- a/testing/web-platform/tests/encrypted-media/scripts/expiration.js
+++ /dev/null
@@ -1,43 +0,0 @@
-function runTest(config,qualifier) {
-
- var testname = testnamePrefix(qualifier, config.keysystem) + ', expiration';
-
- var configuration = getSimpleConfigurationForContent(config.content);
- if (config.initDataType && config.initData) {
- configuration.initDataTypes = [config.initDataType];
- }
-
- async_test(function(test) {
-
- var _mediaKeys,
- _mediaKeySession;
-
- 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');
-
- assert_in_array(event.messageType, [ 'license-request', 'individualization-request' ] );
-
- config.messagehandler(event.messageType, event.message, {expiration: config.expiration}).then(function(response) {
- return event.target.update(response);
- }).then(test.step_func(function() {
- assert_approx_equals(event.target.expiration, config.expiration, 4000, "expiration attribute should equal provided expiration time");
- test.done();
- })).catch(onFailure);
- }
-
- navigator.requestMediaKeySystemAccess(config.keysystem, [configuration]).then(function(access) {
- return access.createMediaKeys();
- }).then(function(mediaKeys) {
- _mediaKeys = mediaKeys;
- _mediaKeySession = _mediaKeys.createSession( 'temporary' );
- waitForEventAndRunStep('message', _mediaKeySession, onMessage, test);
- return _mediaKeySession.generateRequest(config.initDataType, config.initData);
- }).catch(onFailure);
- }, testname);
-}
diff --git a/testing/web-platform/tests/encrypted-media/scripts/generate-request-disallowed-input.js b/testing/web-platform/tests/encrypted-media/scripts/generate-request-disallowed-input.js
deleted file mode 100644
index 19e0c3555..000000000
--- a/testing/web-platform/tests/encrypted-media/scripts/generate-request-disallowed-input.js
+++ /dev/null
@@ -1,73 +0,0 @@
-function runTest(config,qualifier) {
- var tests = [ ], initData, keyId;
- function push_test(keysystem, initDataType, initData, testname) {
- tests.push({ keysystem: keysystem, initDataType: initDataType, initData: initData, testname: testname });
- }
-
- initData = new Uint8Array(70000);
- push_test(config.keysystem, 'webm', initData, testnamePrefix( qualifier, config.keysystem ) + ', temporary, webm, initData longer than 64Kb characters');
-
- initData = new Uint8Array(70000);
- push_test(config.keysystem, 'cenc', initData, testnamePrefix( qualifier, config.keysystem ) + ', temporary, cenc, initData longer than 64Kb characters');
-
- initData = new Uint8Array(70000);
- push_test(config.keysystem, 'keyids', initData, testnamePrefix( qualifier, config.keysystem ) + ', temporary, keyids, initData longer than 64Kb characters');
-
- // Invalid 'pssh' box as the size specified is larger than what
- // is provided.
- initData = new Uint8Array([
- 0x00, 0x00, 0xff, 0xff, // size = huge
- 0x70, 0x73, 0x73, 0x68, // 'pssh'
- 0x00, // version = 0
- 0x00, 0x00, 0x00, // flags
- 0x10, 0x77, 0xEF, 0xEC, 0xC0, 0xB2, 0x4D, 0x02, // Common SystemID
- 0xAC, 0xE3, 0x3C, 0x1E, 0x52, 0xE2, 0xFB, 0x4B,
- 0x00, 0x00, 0x00, 0x00 // datasize
- ]);
- push_test(config.keysystem, 'cenc', initData, testnamePrefix( qualifier, config.keysystem ) + ', temporary, cenc, invalid initdata (invalid pssh)');
-
- // Invalid data as type = 'psss'.
- initData = new Uint8Array([
- 0x00, 0x00, 0x00, 0x00, // size = 0
- 0x70, 0x73, 0x73, 0x73, // 'psss'
- 0x00, // version = 0
- 0x00, 0x00, 0x00, // flags
- 0x10, 0x77, 0xEF, 0xEC, 0xC0, 0xB2, 0x4D, 0x02, // Common SystemID
- 0xAC, 0xE3, 0x3C, 0x1E, 0x52, 0xE2, 0xFB, 0x4B,
- 0x00, 0x00, 0x00, 0x00 // datasize
- ]);
- push_test(config.keysystem, 'cenc', initData, testnamePrefix( qualifier, config.keysystem ) + ', temporary, cenc, invalid initdata (not pssh)');
-
- // Valid key ID size must be at least 1 character for keyids.
- keyId = new Uint8Array(0);
- initData = stringToUint8Array(createKeyIDs(keyId));
- push_test(config.keysystem, 'keyids', initData, testnamePrefix( qualifier, config.keysystem ) + ', temporary, keyids, invalid initdata (too short key ID)');
-
- // Valid key ID size must be less than 512 characters for keyids.
- keyId = new Uint8Array(600);
- initData = stringToUint8Array(createKeyIDs(keyId));
- push_test(config.keysystem, 'keyids', initData, testnamePrefix( qualifier, config.keysystem ) + ', temporary, keyids, invalid initdata (too long key ID)');
-
- Promise.all( tests.map(function(testspec) {
- return isInitDataTypeSupported(testspec.keysystem,testspec.initDataType);
- })).then(function(results) {
- tests.filter(function(testspec, i) { return results[i]; } ).forEach(function(testspec) {
- promise_test(function(test) {
- // Create a "temporary" session for |keysystem| and call generateRequest()
- // with the provided initData. generateRequest() should fail with an
- // InvalidAccessError. Returns a promise that is resolved
- // if the error occurred and rejected otherwise.
- return navigator.requestMediaKeySystemAccess(testspec.keysystem, getSimpleConfigurationForInitDataType(testspec.initDataType)).then(function(access) {
- return access.createMediaKeys();
- }).then(function(mediaKeys) {
- var mediaKeySession = mediaKeys.createSession("temporary");
- return mediaKeySession.generateRequest(testspec.initDataType, testspec.initData);
- }).then(test.step_func(function() {
- assert_unreached('generateRequest() succeeded unexpectedly');
- }), test.step_func(function(error) {
- assert_equals(error.name, 'TypeError');
- }));
- },testspec.testname);
- });
- });
-}
diff --git a/testing/web-platform/tests/encrypted-media/scripts/invalid-license.js b/testing/web-platform/tests/encrypted-media/scripts/invalid-license.js
deleted file mode 100644
index 992eef5dc..000000000
--- a/testing/web-platform/tests/encrypted-media/scripts/invalid-license.js
+++ /dev/null
@@ -1,33 +0,0 @@
-function runTest(config)
-{
- promise_test(function (test) {
- var initDataType;
- var initData;
- var keySystem = config.keysystem;
- var invalidLicense = new Uint8Array([0x00, 0x11, 0x22, 0x33, 0x44, 0x55, 0x66, 0x77]);
- var messageEventFired = false;
-
- return navigator.requestMediaKeySystemAccess(keySystem, getSimpleConfiguration()).then(function (access) {
- initDataType = access.getConfiguration().initDataTypes[0];
- initData = getInitData(initDataType);
- return access.createMediaKeys();
- }).then(function (mediaKeys) {
- var keySession = mediaKeys.createSession();
- var eventWatcher = new EventWatcher(test, keySession, ['message']);
- var promise = eventWatcher.wait_for('message');
- keySession.generateRequest(initDataType, initData);
- return promise;
- }).then(function (messageEvent) {
- messageEventFired = true;
- return messageEvent.target.update(invalidLicense);
- }).then(function () {
- assert_unreached('Error: update() should fail because of an invalid license.');
- }).catch(function (error) {
- if(messageEventFired) {
- assert_equals(error.name, 'TypeError');
- } else {
- assert_unreached('Error: ' + error.name);
- }
- });
- }, 'Update with invalid Clear Key license');
-} \ No newline at end of file
diff --git a/testing/web-platform/tests/encrypted-media/scripts/keystatuses-multiple-sessions.js b/testing/web-platform/tests/encrypted-media/scripts/keystatuses-multiple-sessions.js
deleted file mode 100644
index e9bf10e88..000000000
--- a/testing/web-platform/tests/encrypted-media/scripts/keystatuses-multiple-sessions.js
+++ /dev/null
@@ -1,103 +0,0 @@
-function runTest(config,qualifier)
-{
- var testname = testnamePrefix(qualifier, config.keysystem) + ', temporary, keystatuses, multiple sessions';
-
- var configuration = getSimpleConfigurationForContent(config.content);
-
- if (config.initDataType && config.initData) configuration.initDataTypes = [config.initDataType];
-
- async_test(function(test)
- {
- var mediaKeySession1;
- var mediaKeySession2;
-
- // Even though key ids are uint8, using printable values so that
- // they can be verified easily.
- var key1 = new Uint8Array(config.content.keys[0].kid),
- key2 = new Uint8Array(config.content.keys[1].kid),
- variant1 = config.content.keys[0].variantId,
- variant2 = config.content.keys[1].variantId;
-
- function onFailure(error) {
- forceTestFailureFromPromise(test,error);
- }
-
- function processMessage1(event)
- {
- // This should only be called for session1.
- assert_equals(event.target, mediaKeySession1);
-
- // No keys added yet.
- verifyKeyStatuses(mediaKeySession1.keyStatuses, {expected: [], unexpected: [key1, key2]});
-
- // Add key1 to session1.
- config.messagehandler(event.messageType, event.message, {variantId:variant1}).then(function(response) {
- return event.target.update(response);
- }).catch(onFailure);
-
- }
-
- function processKeyStatusesChange1(event)
- {
- // This should only be called for session1.
- assert_equals(event.target, mediaKeySession1);
-
- // Check that keyStatuses contains the expected key1 only.
- verifyKeyStatuses(mediaKeySession1.keyStatuses, {expected: [key1], unexpected: [key2]});
-
- // Now trigger a message event on session2.
- mediaKeySession2.generateRequest(config.initDataType, config.initData[1]).catch(onFailure);
- }
-
- function processMessage2(event)
- {
- // This should only be called for session2.
- assert_equals(event.target, mediaKeySession2);
-
- // session2 has no keys added yet.
- verifyKeyStatuses(mediaKeySession2.keyStatuses, {expected: [], unexpected: [key1, key2]});
-
- // session1 should still have 1 key.
- verifyKeyStatuses(mediaKeySession1.keyStatuses, {expected: [key1], unexpected: [key2]});
-
- // Add key2 to session2.
- config.messagehandler(event.messageType, event.message, {variantId:variant2}).then(function(response) {
- return event.target.update(response);
- }).catch(onFailure);
- }
-
- function processKeyStatusesChange2(event)
- {
- // This should only be called for session2.
- assert_equals(event.target, mediaKeySession2);
-
- // Check that keyStatuses contains the expected key2 only.
- verifyKeyStatuses(mediaKeySession2.keyStatuses, {expected: [key2], unexpected: [key1]});
-
- // session1 should still have 1 key.
- verifyKeyStatuses(mediaKeySession1.keyStatuses, {expected: [key1], unexpected: [key2]});
-
- test.done();
- }
-
- navigator.requestMediaKeySystemAccess(config.keysystem, [configuration]).then(function(access) {
- return access.createMediaKeys();
- }).then(function(mediaKeys) {
- mediaKeySession1 = mediaKeys.createSession();
- mediaKeySession2 = mediaKeys.createSession();
-
- // There should be no keys defined on either session.
- verifyKeyStatuses(mediaKeySession1.keyStatuses, {expected: [], unexpected: [key1, key2]});
- verifyKeyStatuses(mediaKeySession2.keyStatuses, {expected: [], unexpected: [key1, key2]});
-
- // Bind all the event handlers now.
- waitForEventAndRunStep('message', mediaKeySession1, processMessage1, test);
- waitForEventAndRunStep('message', mediaKeySession2, processMessage2, test);
- waitForEventAndRunStep('keystatuseschange', mediaKeySession1, processKeyStatusesChange1, test);
- waitForEventAndRunStep('keystatuseschange', mediaKeySession2, processKeyStatusesChange2, test);
-
- // Generate a request on session1.
- return mediaKeySession1.generateRequest(config.initDataType, config.initData[0]);
- }).catch(onFailure);
- }, testname );
-}
diff --git a/testing/web-platform/tests/encrypted-media/scripts/keystatuses.js b/testing/web-platform/tests/encrypted-media/scripts/keystatuses.js
deleted file mode 100644
index 8d33dd421..000000000
--- a/testing/web-platform/tests/encrypted-media/scripts/keystatuses.js
+++ /dev/null
@@ -1,165 +0,0 @@
-function runTest(config,qualifier)
-{
- var testname = testnamePrefix(qualifier, config.keysystem) + ', temporary, keystatuses';
-
- var configuration = getSimpleConfigurationForContent(config.content);
-
- if (config.initDataType && config.initData) {
- configuration.initDataTypes = [config.initDataType];
- }
-
- async_test(function(test)
- {
- var mediaKeySession;
- var initDataType;
- var initData;
- var closed = false;
-
- // Even though key ids are uint8, using printable values so that
- // they can be verified easily.
- var key1 = new Uint8Array(config.content.keys[0].kid),
- key2 = new Uint8Array(config.content.keys[1].kid),
- key1String = arrayBufferAsString(key1),
- key2String = arrayBufferAsString(key2);
-
- function onFailure(error) {
- forceTestFailureFromPromise(test, error);
- }
-
- function processMessage(event)
- {
- // No keys added yet.
- assert_equals(mediaKeySession.keyStatuses.size, 0);
-
- waitForEventAndRunStep('keystatuseschange', mediaKeySession, processKeyStatusesChange, test);
-
- // Add keys to session
- config.messagehandler(event.messageType, event.message).then(function(response) {
- return event.target.update(response);
- }).catch(onFailure);
- }
-
- function checkKeyStatusFor2Keys()
- {
- // Two keys added, so both should show up in |keyStatuses|.
- assert_equals(mediaKeySession.keyStatuses.size, 2);
-
- // Check |keyStatuses| for 2 entries.
- var result = [];
- for (let item of mediaKeySession.keyStatuses) {
- result.push({ key: arrayBufferAsString(item[0]), value: item[1] });
- }
- function lexicographical( a, b ) { return a < b ? -1 : a === b ? 0 : +1; }
- function lexicographicalkey( a, b ) { return lexicographical( a.key, b.key ); }
- var expected1 = [{ key: key1String, value: 'usable'}, { key: key2String, value: 'usable'}].sort( lexicographicalkey );
- var expected2 = [{ key: key1String, value: 'status-pending'}, { key: key2String, value: 'status-pending'}].sort( lexicographicalkey );
- assert_in_array( JSON.stringify(result),
- [ JSON.stringify(expected1),JSON.stringify(expected2) ],
- "keystatuses should have the two expected keys with keystatus 'usable' or 'status-pending'");
-
- // |keyStatuses| must contain both keys.
- result = [];
- for (var key of mediaKeySession.keyStatuses.keys()) {
- result.push(arrayBufferAsString(key));
- }
- assert_array_equals(result,
- [key1String, key2String].sort( lexicographical ),
- "keyStatuses.keys() should return an iterable over the two expected keys");
-
- // Both values in |mediaKeySession| should be 'usable' or 'status-pending'.
- result = [];
- for (var value of mediaKeySession.keyStatuses.values()) {
- result.push(value);
- }
-
- assert_equals( result.length, 2, "keyStatuses.values() should have two elements" );
- assert_equals( result[0], result[1], "the values in keyStatuses.values() should be equal" );
- assert_in_array( result[0], [ 'usable', 'status-pending' ] );
-
- // Check |keyStatuses.entries()|.
- result = [];
- for (var entry of mediaKeySession.keyStatuses.entries()) {
- result.push({ key: arrayBufferAsString(entry[0]), value: entry[1] });
- }
- assert_in_array(JSON.stringify(result),
- [ JSON.stringify(expected1), JSON.stringify(expected2) ],
- "keyStatuses.entries() should return an iterable over the two expected keys, with keystatus 'usable' or 'status-pending'");
-
- // forEach() should return both entries.
- result = [];
- mediaKeySession.keyStatuses.forEach(function(status, keyId) {
- result.push({ key: arrayBufferAsString(keyId), value: status });
- });
- assert_in_array(JSON.stringify(result),
- [ JSON.stringify(expected1), JSON.stringify(expected2) ],
- "keyStatuses.forEach() should iterate over the two expected keys, with keystatus 'usable' or 'status-pending'");
-
- // has() and get() should return the expected values.
- assert_true(mediaKeySession.keyStatuses.has(key1), "keyStatuses should have key1");
- assert_true(mediaKeySession.keyStatuses.has(key2), "keyStatuses should have key2");
- assert_in_array(mediaKeySession.keyStatuses.get(key1), [ 'usable', 'status-pending' ], "key1 should have status 'usable' or 'status-pending'");
- assert_in_array(mediaKeySession.keyStatuses.get(key2), [ 'usable', 'status-pending' ], "key2 should have status 'usable' or 'status-pending'");
-
- // Try some invalid keyIds.
- var invalid1 = key1.subarray(0, key1.length - 1);
- assert_false(mediaKeySession.keyStatuses.has(invalid1), "keystatuses should not have invalid key (1)");
- assert_equals(mediaKeySession.keyStatuses.get(invalid1), undefined, "keystatus value for invalid key should be undefined (1)");
-
- var invalid2 = key1.subarray(1);
- assert_false(mediaKeySession.keyStatuses.has(invalid2), "keystatuses should not have invalid key (2)");
- assert_equals(mediaKeySession.keyStatuses.get(invalid2), undefined, "keystatus value for invalid key should be undefined (2)");
-
- var invalid3 = new Uint8Array(key1);
- invalid3[0] += 1;
- assert_false(mediaKeySession.keyStatuses.has(invalid3), "keystatuses should not have invalid key (3)");
- assert_equals(mediaKeySession.keyStatuses.get(invalid3), undefined, "keystatus value for invalid key should be undefined (3)");
-
- var invalid4 = new Uint8Array(key1);
- invalid4[invalid4.length - 1] -= 1;
- assert_false(mediaKeySession.keyStatuses.has(invalid4), "keystatuses should not have invalid key (4)");
- assert_equals(mediaKeySession.keyStatuses.get(invalid4), undefined, "keystatus value for invalid key should be undefined (4)");
-
- var invalid5 = new Uint8Array(key1.length + 1);
- invalid5.set(key1, 1); // First element will be 0.
- assert_false(mediaKeySession.keyStatuses.has(invalid5), "keystatuses should not have invalid key (5)");
- assert_equals(mediaKeySession.keyStatuses.get(invalid5), undefined, "keystatus value for invalid key should be undefined (5)");
-
- var invalid6 = new Uint8Array(key1.length + 1);
- invalid6.set(key1, 0); // Last element will be 0.
- assert_false(mediaKeySession.keyStatuses.has(invalid6), "keystatuses should not have invalid key (6)");
- assert_equals(mediaKeySession.keyStatuses.get(invalid6), undefined, "keystatus value for invalid key should be undefined (6)");
- }
-
- function processKeyStatusesChange(event)
- {
- if (!closed)
- {
- // The first keystatuseschange (caused by update())
- // should include both keys.
- checkKeyStatusFor2Keys();
-
- mediaKeySession.close().catch(onFailure);
- closed = true;
- }
- else
- {
- // The second keystatuseschange (caused by close())
- // should not have any keys.
- assert_equals(mediaKeySession.keyStatuses.size, 0);
- test.done();
- }
- }
-
- navigator.requestMediaKeySystemAccess(config.keysystem, [configuration]).then(function(access) {
- return access.createMediaKeys();
- }).then(test.step_func(function(mediaKeys) {
- mediaKeySession = mediaKeys.createSession();
-
- // There should be no keys defined yet.
- //verifyKeyStatuses(mediaKeySession.keyStatuses, { expected: [], unexpected: [key1, key2] });
-
- waitForEventAndRunStep('message', mediaKeySession, processMessage, test);
- return mediaKeySession.generateRequest(config.initDataType, config.initData);
- })).catch(onFailure);
- }, testname );
-}
diff --git a/testing/web-platform/tests/encrypted-media/scripts/not-callable-after-createsession.js b/testing/web-platform/tests/encrypted-media/scripts/not-callable-after-createsession.js
deleted file mode 100644
index 2642c71e0..000000000
--- a/testing/web-platform/tests/encrypted-media/scripts/not-callable-after-createsession.js
+++ /dev/null
@@ -1,50 +0,0 @@
- function runTest(config,qualifier) {
- // After creation, the MediaKeySession object is not
- // callable, and we should get a InvalidStateError.
-
- promise_test(function()
- {
- return navigator.requestMediaKeySystemAccess(config.keysystem, getSimpleConfiguration()).then(function(access) {
- return access.createMediaKeys();
- }).then(function(mediaKeys) {
- var mediaKeySession = mediaKeys.createSession();
-
- var arbitraryResponse = new Uint8Array([0x00, 0x11]);
- return mediaKeySession.update(arbitraryResponse).then(function(result) {
- assert_unreached('update() succeeded unexpectedly.');
- }).catch(function(error) {
- assert_equals(error.name, 'InvalidStateError');
- });
- });
- }, testnamePrefix( qualifier, config.keysystem ) + ', temporary, update() immediately after createSession()');
-
- promise_test(function()
- {
- return navigator.requestMediaKeySystemAccess(config.keysystem, getSimpleConfiguration()).then(function(access) {
- return access.createMediaKeys();
- }).then(function(mediaKeys) {
- var mediaKeySession = mediaKeys.createSession();
-
- return mediaKeySession.close().then(function(result) {
- assert_unreached('close() succeeded unexpectedly.');
- }).catch(function(error) {
- assert_equals(error.name, 'InvalidStateError');
- });
- });
- }, testnamePrefix( qualifier, config.keysystem ) + ', temporary, close() immediately after createSession()');
-
- promise_test(function()
- {
- return navigator.requestMediaKeySystemAccess(config.keysystem, getSimpleConfiguration()).then(function(access) {
- return access.createMediaKeys();
- }).then(function(mediaKeys) {
- var mediaKeySession = mediaKeys.createSession();
-
- return mediaKeySession.remove().then(function(result) {
- assert_unreached('remove() succeeded unexpectedly.');
- }).catch(function(error) {
- assert_equals(error.name, 'InvalidStateError');
- });
- });
- }, testnamePrefix( qualifier, config.keysystem ) + ', temporary, remove() immediately after createSession()');
-}
diff --git a/testing/web-platform/tests/encrypted-media/scripts/onencrypted.js b/testing/web-platform/tests/encrypted-media/scripts/onencrypted.js
deleted file mode 100644
index 7c969a9e5..000000000
--- a/testing/web-platform/tests/encrypted-media/scripts/onencrypted.js
+++ /dev/null
@@ -1,47 +0,0 @@
-function runTest(config) {
- var expectedInitData = [];
- expectedInitData.push(stringToUint8Array(atob(config.keys[0].initData)));
- expectedInitData.push(stringToUint8Array(atob(config.keys[1].initData)));
-
- // Will get 2 identical events, one for audio, one for video.
- var expectedEvents = 2;
- var currentData;
-
- async_test(function (test) {
- var video = config.video,
- mediaSource,
- onEncrypted = function (event) {
- currentData = new Uint8Array(event.initData);
- assert_equals(event.target, config.video);
- assert_true(event instanceof window.MediaEncryptedEvent);
- assert_equals(event.type, 'encrypted');
- assert_equals(event.initDataType, 'cenc');
- // At this point we do not know if the event is related to audio or video. So check for both expected init data
- assert_true(checkInitData(currentData, expectedInitData[0]) || checkInitData(currentData, expectedInitData[1]));
-
- if (--expectedEvents === 0) {
- test.done();
- }
- };
-
- waitForEventAndRunStep('encrypted', video, onEncrypted, test);
- return testmediasource(config).then(test.step_func(function (source) {
- mediaSource = source;
- config.video.src = URL.createObjectURL(mediaSource);
- video.play();
- }));
- }, 'encrypted fired on encrypted media file.'
- );
-}
-
-function checkInitData(data, expectedData) {
- if (data.length !== expectedData.length) {
- return false;
- }
- for (var i = 0; i < data.length; i++) {
- if (data[i] !== expectedData[i]) {
- return false;
- }
- }
- return true;
-}
diff --git a/testing/web-platform/tests/encrypted-media/scripts/playback-destroy-persistent-license.js b/testing/web-platform/tests/encrypted-media/scripts/playback-destroy-persistent-license.js
deleted file mode 100644
index 2726d8639..000000000
--- a/testing/web-platform/tests/encrypted-media/scripts/playback-destroy-persistent-license.js
+++ /dev/null
@@ -1,93 +0,0 @@
-function runTest(config,qualifier) {
-
- var testname = testnamePrefix( qualifier, config.keysystem )
- + ', persistent-license, '
- + /video\/([^;]*)/.exec( config.videoType )[ 1 ]
- + ', playback, destroy and acknowledge';
-
- var configuration = { initDataTypes: [ config.initDataType ],
- audioCapabilities: [ { contentType: config.audioType } ],
- videoCapabilities: [ { contentType: config.videoType } ],
- sessionTypes: [ 'persistent-license' ] };
-
- async_test( function(test) {
-
- var _video = config.video,
- _mediaKeys,
- _mediaKeySession,
- _mediaSource,
- _sessionId,
- _startedReleaseSequence = false;
-
- 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');
-
- config.messagehandler(event.messageType, event.message).then(function(response) {
- return _mediaKeySession.update(response);
- }).catch(onFailure);
- }
-
- function onEncrypted(event) {
- assert_equals(event.target, _video);
- assert_true(event instanceof window.MediaEncryptedEvent);
- assert_equals(event.type, 'encrypted');
-
- waitForEventAndRunStep('message', _mediaKeySession, onMessage, test);
- _mediaKeySession.generateRequest( config.initData ? config.initDataType : event.initDataType,
- config.initData || event.initData ).then( test.step_func(function() {
- assert_not_equals( _mediaKeySession.sessionId, undefined, "SessionId should be defined" );
- _sessionId = _mediaKeySession.sessionId;
- })).catch(onFailure);
- }
-
- function onTimeupdate(event) {
- if (_video.currentTime > ( config.duration || 1 ) && !_startedReleaseSequence) {
- _video.removeEventListener('timeupdate', onTimeupdate);
- _video.pause();
- _video.removeAttribute('src');
- _video.load();
-
- _startedReleaseSequence = true;
- _mediaKeySession.closed.then(onClosed);
- _mediaKeySession.remove().catch(onFailure);
- }
- }
-
- function onPlaying(event) {
- // Not using waitForEventAndRunStep() to avoid too many
- // EVENT(onTimeUpdate) logs.
- _video.addEventListener('timeupdate', onTimeupdate, true);
- }
-
- function onClosed() {
- // Try and reload and check this fails
- var mediaKeySession = _mediaKeys.createSession( 'persistent-license' );
- mediaKeySession.load(_sessionId).then( test.step_func(function(success) {
- assert_false( success, "Load of removed session shouold fail" );
- test.done();
- })).catch(onFailure);
- }
-
- navigator.requestMediaKeySystemAccess(config.keysystem, [configuration]).then(function(access) {
- return access.createMediaKeys();
- }).then(function(mediaKeys) {
- _mediaKeys = mediaKeys;
- return _video.setMediaKeys(_mediaKeys);
- }).then(function() {
- _mediaKeySession = _mediaKeys.createSession('persistent-license');
- waitForEventAndRunStep('encrypted', _video, onEncrypted, test);
- waitForEventAndRunStep('playing', _video, onPlaying, test);
- return testmediasource(config);
- }).then(function(source) {
- _mediaSource = source;
- _video.src = URL.createObjectURL(_mediaSource);
- _video.play();
- }).catch(onFailure);
- }, testname);
-}
diff --git a/testing/web-platform/tests/encrypted-media/scripts/playback-persistent-license-events.js b/testing/web-platform/tests/encrypted-media/scripts/playback-persistent-license-events.js
deleted file mode 100644
index e2c0988ba..000000000
--- a/testing/web-platform/tests/encrypted-media/scripts/playback-persistent-license-events.js
+++ /dev/null
@@ -1,128 +0,0 @@
-function runTest(config,qualifier) {
-
- var testname = testnamePrefix(qualifier, config.keysystem)
- + ', persistent-license, '
- + /video\/([^;]*)/.exec(config.videoType)[1]
- + ', playback, check events';
-
- var configuration = { initDataTypes: [ config.initDataType ],
- audioCapabilities: [ { contentType: config.audioType } ],
- videoCapabilities: [ { contentType: config.videoType } ],
- sessionTypes: [ 'persistent-license' ] };
-
-
- async_test(function(test) {
- var _video = config.video,
- _mediaKeys,
- _mediaKeySession,
- _mediaSource,
- _receivedTimeupdateEvent = false,
- _startedReleaseSequence = 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 (!_startedReleaseSequence) {
- assert_in_array(event.messageType, ['license-request', 'individualization-request']);
- } else {
- assert_equals(event.messageType, 'license-release');
- }
-
- 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('updated');
- if (event.messageType === 'license-release') {
- assert_array_equals(_events,
- [
- 'generaterequest',
- 'license-request',
- 'license-request-response',
- 'updated',
- 'keystatuseschange',
- 'playing',
- 'remove',
- 'keystatuseschange',
- 'license-release',
- 'license-release-response',
- 'closed-promise',
- 'updated'
- ],
- "Expected events sequence" );
- test.done();
- }
- })).catch(onFailure);
- }
-
- function onKeyStatusesChange(event) {
- assert_equals(event.target, _mediaKeySession);
- assert_true(event instanceof window.Event);
- assert_equals(event.type, 'keystatuseschange');
- _events.push('keystatuseschange');
- }
-
- function onEncrypted(event) {
- assert_equals(event.target, _video);
- assert_true(event instanceof window.MediaEncryptedEvent);
- assert_equals(event.type, 'encrypted');
-
- _mediaKeySession.generateRequest( config.initData ? config.initDataType : event.initDataType,
- config.initData || event.initData ).then(recordEventFunc('generaterequest')
- ).catch(onFailure);
- }
-
- function onTimeupdate(event) {
- if ( _video.currentTime > ( config.duration || 1 ) && !_receivedTimeupdateEvent ) {
- _receivedTimeupdateEvent = true;
- _video.pause();
- _video.removeAttribute('src');
- _video.load();
-
- _startedReleaseSequence = true;
- _mediaKeySession.remove().then(recordEventFunc('remove')).catch(onFailure);
- }
- }
-
- function onPlaying(event) {
- _events.push( 'playing' );
- }
-
- navigator.requestMediaKeySystemAccess(config.keysystem, [ configuration ]).then(function(access) {
- return access.createMediaKeys();
- }).then(function(mediaKeys) {
- _mediaKeys = mediaKeys;
- return _video.setMediaKeys(_mediaKeys);
- }).then(function() {
- waitForEventAndRunStep('encrypted', _video, onEncrypted, test);
- waitForEventAndRunStep('playing', _video, onPlaying, test);
- // Not using waitForEventAndRunStep() to avoid too many
- // EVENT(onTimeUpdate) logs.
- _video.addEventListener('timeupdate', onTimeupdate, true);
- _mediaKeySession = _mediaKeys.createSession( 'persistent-license' );
- waitForEventAndRunStep('keystatuseschange', _mediaKeySession, onKeyStatusesChange, test);
- waitForEventAndRunStep('message', _mediaKeySession, onMessage, test);
- _mediaKeySession.closed.then( recordEventFunc( 'closed-promise' ) );
- return testmediasource(config);
- }).then(function(source) {
- _mediaSource = source;
- _video.src = URL.createObjectURL(_mediaSource);
- _video.play();
- }).catch(onFailure);
- }, testname);
-}
diff --git a/testing/web-platform/tests/encrypted-media/scripts/playback-persistent-license.js b/testing/web-platform/tests/encrypted-media/scripts/playback-persistent-license.js
deleted file mode 100644
index a1361d88b..000000000
--- a/testing/web-platform/tests/encrypted-media/scripts/playback-persistent-license.js
+++ /dev/null
@@ -1,75 +0,0 @@
-function runTest(config,qualifier) {
-
- var testname = testnamePrefix(qualifier, config.keysystem)
- + ', persistent-license, '
- + /video\/([^;]*)/.exec(config.videoType)[1]
- + 'playback';
-
- var configuration = { initDataTypes: [ config.initDataType ],
- audioCapabilities: [ { contentType: config.audioType } ],
- videoCapabilities: [ { contentType: config.videoType } ],
- sessionTypes: [ 'persistent-license' ] };
-
-
- async_test(function(test) {
- var _video = config.video,
- _mediaKeys,
- _mediaKeySession,
- _mediaSource;
-
- 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');
-
- assert_in_array( event.messageType, [ 'license-request', 'individualization-request' ] );
-
- config.messagehandler(event.messageType, event.message).then( function( response ) {
- return _mediaKeySession.update(response)
- }).catch(onFailure);
- }
-
- function onEncrypted(event) {
- assert_equals(event.target, _video);
- assert_true(event instanceof window.MediaEncryptedEvent);
- assert_equals(event.type, 'encrypted');
-
- waitForEventAndRunStep('message', _mediaKeySession, onMessage, test);
- _mediaKeySession.generateRequest( config.initData ? config.initDataType : event.initDataType,
- config.initData || event.initData ).catch(onFailure);
- }
-
- function onTimeupdate(event) {
- if (_video.currentTime > (config.duration || 1)) {
- _video.pause();
- test.done();
- }
- }
-
- function onPlaying(event) {
- // Not using waitForEventAndRunStep() to avoid too many
- // EVENT(onTimeUpdate) logs.
- _video.addEventListener('timeupdate', onTimeupdate, true);
- }
-
- navigator.requestMediaKeySystemAccess(config.keysystem, [ configuration ]).then(function(access) {
- return access.createMediaKeys();
- }).then(function(mediaKeys) {
- _mediaKeys = mediaKeys;
- return _video.setMediaKeys(_mediaKeys);
- }).then(function() {
- _mediaKeySession = _mediaKeys.createSession( 'persistent-license' );
- waitForEventAndRunStep('encrypted', _video, onEncrypted, test);
- waitForEventAndRunStep('playing', _video, onPlaying, test);
- return testmediasource(config);
- }).then(function(source) {
- _mediaSource = source;
- _video.src = URL.createObjectURL(_mediaSource);
- _video.play();
- }).catch(onFailure);
- }, testname);
-}
diff --git a/testing/web-platform/tests/encrypted-media/scripts/playback-persistent-usage-record-events.js b/testing/web-platform/tests/encrypted-media/scripts/playback-persistent-usage-record-events.js
deleted file mode 100644
index 84e595ecf..000000000
--- a/testing/web-platform/tests/encrypted-media/scripts/playback-persistent-usage-record-events.js
+++ /dev/null
@@ -1,113 +0,0 @@
-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-done');
- if (event.messageType === 'license-release') {
- consoleWrite(_events);
- assert_array_equals(_events,
- [ 'encrypted',
- 'generaterequest-done',
- 'license-request',
- 'license-request-response',
- 'update-done',
- 'keystatuseschange',
- 'playing',
- 'remove-done',
- 'keystatuseschange',
- 'license-release',
- 'license-release-response',
- 'closed-promise',
- 'update-done'
- ],
- "Expected events sequence" );
- 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-done')).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-promise'));
- return config.servercertificate ? _mediaKeys.setServerCertificate(config.servercertificate) : true;
- }).then(function( success ) {
- return testmediasource(config);
- }).then(function(source) {
- _video.src = URL.createObjectURL(source);
- _video.play();
- }).catch(onFailure);
- }, testname);
-}
diff --git a/testing/web-platform/tests/encrypted-media/scripts/playback-persistent-usage-record.js b/testing/web-platform/tests/encrypted-media/scripts/playback-persistent-usage-record.js
deleted file mode 100644
index 966a0ae19..000000000
--- a/testing/web-platform/tests/encrypted-media/scripts/playback-persistent-usage-record.js
+++ /dev/null
@@ -1,102 +0,0 @@
-function runTest(config,qualifier) {
-
- var testname = testnamePrefix(qualifier, config.keysystem)
- + ', persistent-usage-record, '
- + /video\/([^;]*)/.exec(config.videoType)[1]
- + 'playback';
-
- 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,
- _mediaSource,
- _releaseSequence = false;
-
- function onFailure(error) {
- forceTestFailureFromPromise(test, error);
- }
-
- function onMessage(event) {
- assert_equals(event.target, _mediaKeySession);
- // event instance verification failing on CastTV
- // assert_true( event instanceof window.MediaKeyMessageEvent );
- assert_equals(event.type, 'message');
-
- if (!_releaseSequence)
- {
- assert_in_array(event.messageType, ['license-request', 'individualization-request']);
- }
- else
- {
- assert_equals(event.messageType, 'license-release');
- }
-
- config.messagehandler(event.messageType, event.message).then(function(response) {
- return _mediaKeySession.update(response);
- }).then(function() {
- if(event.messageType === 'license-request') {
- return _video.setMediaKeys(_mediaKeys);
- } else if(event.messageType === 'license-release') {
- test.done();
- }
- }).catch(onFailure);
- }
-
- function onEncrypted(event) {
- assert_equals(event.target, _video);
- assert_true(event instanceof window.MediaEncryptedEvent);
- assert_equals(event.type, 'encrypted');
-
- waitForEventAndRunStep('message', _mediaKeySession, onMessage, test);
- _mediaKeySession.generateRequest( config.initData ? config.initDataType : event.initDataType,
- config.initData || event.initData )
- .catch(onFailure);
- }
-
- function onClosed(event) {
- _video.src = "";
- _video.setMediaKeys( null );
- }
-
- function onTimeupdate(event) {
- if (_video.currentTime > ( config.duration || 1) && !_releaseSequence) {
- _video.removeEventListener('timeupdate', onTimeupdate );
- _video.pause();
- _releaseSequence = true;
-
- _mediaKeySession.closed.then(test.step_func(onClosed));
- _mediaKeySession.remove().catch(onFailure);
-
- _video.removeEventListener('timeupdate', onTimeupdate);
- }
- }
-
- function onPlaying(event) {
- // Not using waitForEventAndRunStep() to avoid too many
- // EVENT(onTimeUpdate) logs.
- _video.addEventListener('timeupdate', onTimeupdate, true);
- }
-
- navigator.requestMediaKeySystemAccess(config.keysystem, [ configuration ]).then(function(access) {
- return access.createMediaKeys();
- }).then(function(mediaKeys) {
- _mediaKeys = mediaKeys;
- _mediaKeySession = _mediaKeys.createSession('persistent-usage-record');
- waitForEventAndRunStep('encrypted', _video, onEncrypted, test);
- waitForEventAndRunStep('playing', _video, onPlaying, test);
- return config.servercertificate ? _mediaKeys.setServerCertificate(config.servercertificate) : true;
- }).then(function(success) {
- return testmediasource(config);
- }).then(function(source) {
- _mediaSource = source;
- _video.src = URL.createObjectURL(_mediaSource);
- _video.play();
- }).catch(onFailure);
- }, testname);
-}
diff --git a/testing/web-platform/tests/encrypted-media/scripts/playback-retrieve-persistent-license.js b/testing/web-platform/tests/encrypted-media/scripts/playback-retrieve-persistent-license.js
deleted file mode 100644
index fd58d24f2..000000000
--- a/testing/web-platform/tests/encrypted-media/scripts/playback-retrieve-persistent-license.js
+++ /dev/null
@@ -1,106 +0,0 @@
-function runTest(config,qualifier) {
-
- var testname = testnamePrefix(qualifier, config.keysystem)
- + ', persistent-license, '
- + /video\/([^;]*)/.exec(config.videoType)[1]
- + ', ' + config.testcase;
-
- var configuration = { initDataTypes: [ config.initDataType ],
- audioCapabilities: [ { contentType: config.audioType } ],
- videoCapabilities: [ { contentType: config.videoType } ],
- sessionTypes: [ 'persistent-license' ] };
-
-
- async_test( function(test) {
- var _video = config.video,
- _mediaKeys,
- _mediaKeySession,
- _mediaSource,
- _sessionId;
-
- function onFailure(error) {
- forceTestFailureFromPromise(test, error);
- }
-
- function onEncrypted(event) {
- assert_equals(event.target, _video);
- assert_true(event instanceof window.MediaEncryptedEvent);
- assert_equals(event.type, 'encrypted');
-
- waitForEventAndRunStep('message', _mediaKeySession, onMessage, test);
- _mediaKeySession.generateRequest( config.initData ? config.initDataType : event.initDataType,
- config.initData || event.initData ).then( function() {
- _sessionId = _mediaKeySession.sessionId;
- }).catch(onFailure);
- }
-
- function onMessage(event) {
- assert_equals(event.target, _mediaKeySession);
- assert_true(event instanceof window.MediaKeyMessageEvent);
- assert_equals(event.type, 'message');
-
- assert_in_array(event.messageType, ['license-request', 'individualization-request']);
-
- config.messagehandler(event.messageType, event.message).then(function(response) {
- return _mediaKeySession.update(response);
- }).catch(onFailure);
- }
-
- function onPlaying(event) {
- // Not using waitForEventAndRunStep() to avoid too many
- // EVENT(onTimeUpdate) logs.
- _video.addEventListener('timeupdate', onTimeupdate, true);
- }
-
- function onTimeupdate(event) {
- if (_video.currentTime > (config.duration || 1)) {
- _video.removeEventListener('timeupdate', onTimeupdate);
- _video.pause();
- _video.removeAttribute('src');
- _video.load()
-
- _mediaKeySession.closed.then(test.step_func(onClosed));
- _mediaKeySession.close();
- }
- }
-
- function onClosed() {
- // Open a new window in which we will attempt to play with the persisted license
- var win = window.open(config.windowscript);
-
- // Lisen for an event from the new window containing its test assertions
- window.addEventListener('message', test.step_func(function(messageEvent) {
- messageEvent.data.forEach(test.step_func(function(assertion) {
- assert_equals(assertion.actual, assertion.expected, assertion.message);
- }));
-
- win.close();
- test.done();
- }));
-
- // Delete things which can't be cloned and posted over to the new window
- delete config.video;
- delete config.messagehandler;
-
- // Post the config and session id to the new window when it is ready
- win.onload = function() {
- win.postMessage({config: config, sessionId: _sessionId}, '*');
- }
- }
-
- navigator.requestMediaKeySystemAccess(config.keysystem, [configuration]).then(function(access) {
- return access.createMediaKeys();
- }).then(function(mediaKeys) {
- _mediaKeys = mediaKeys;
- _video.setMediaKeys( mediaKeys );
- _mediaKeySession = _mediaKeys.createSession('persistent-license');
- waitForEventAndRunStep('encrypted', _video, onEncrypted, test);
- waitForEventAndRunStep('playing', _video, onPlaying, test);
- return testmediasource(config);
- }).then(function(source) {
- _mediaSource = source;
- _video.src = URL.createObjectURL(_mediaSource);
- _video.play();
- }).catch(onFailure);
- }, testname);
-}
diff --git a/testing/web-platform/tests/encrypted-media/scripts/playback-retrieve-persistent-usage-record.js b/testing/web-platform/tests/encrypted-media/scripts/playback-retrieve-persistent-usage-record.js
deleted file mode 100644
index 657e02610..000000000
--- a/testing/web-platform/tests/encrypted-media/scripts/playback-retrieve-persistent-usage-record.js
+++ /dev/null
@@ -1,108 +0,0 @@
-function runTest(config,qualifier) {
-
- var testname = testnamePrefix(qualifier, config.keysystem)
- + ', persistent-usage-record, '
- + /video\/([^;]*)/.exec(config.videoType)[1]
- + ', playback, retrieve in new window';
-
- 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,
- _mediaSource,
- _sessionId,
- _isClosing = false;
-
- function onFailure(error) {
- forceTestFailureFromPromise(test, error);
- }
-
- function onEncrypted(event) {
- assert_equals(event.target, _video);
- assert_true(event instanceof window.MediaEncryptedEvent);
- assert_equals(event.type, 'encrypted');
-
- waitForEventAndRunStep('message', _mediaKeySession, onMessage, test);
- _mediaKeySession.generateRequest( config.initDataType || event.initDataType,
- config.initData || event.initData ).then( function() {
- _sessionId = _mediaKeySession.sessionId;
- }).catch(onFailure);
- }
-
- function onMessage(event) {
- assert_equals(event.target, _mediaKeySession);
- assert_true(event instanceof window.MediaKeyMessageEvent);
- assert_equals(event.type, 'message');
-
- assert_in_array( event.messageType,['license-request', 'individualization-request']);
-
- config.messagehandler( event.messageType, event.message ).then(function(response) {
- return _mediaKeySession.update(response);
- }).then(function() {
- _video.setMediaKeys(_mediaKeys);
- }).catch(onFailure);
- }
-
- function onPlaying(event) {
- // Not using waitForEventAndRunStep() to avoid too many
- // EVENT(onTimeUpdate) logs.
- _video.addEventListener('timeupdate', onTimeupdate, true);
- }
-
- function onTimeupdate(event) {
- if (!_isClosing && _video.currentTime > (config.duration || 1)) {
- _isClosing = true;
- _video.removeEventListener('timeupdate', onTimeupdate);
- _video.pause();
- _mediaKeySession.closed.then( test.step_func(onClosed));
- _mediaKeySession.close();
- }
- }
-
- function onClosed(event) {
- _video.src = "";
- _video.setMediaKeys( null );
-
- var win = window.open(config.windowscript);
- window.addEventListener('message', test.step_func(function(event) {
- event.data.forEach(test.step_func(function(assertion) {
- assert_equals(assertion.actual, assertion.expected, assertion.message);
- }));
-
- win.close();
- test.done();
- }));
-
- delete config.video;
- delete config.messagehandler;
-
- win.onload = function() {
- win.postMessage({ config: config, sessionId: _sessionId }, '*');
- }
- }
-
- navigator.requestMediaKeySystemAccess(config.keysystem, [configuration]).then(function(access) {
- return access.createMediaKeys();
- }).then(function(mediaKeys) {
- _mediaKeys = mediaKeys;
- return _video.setMediaKeys(mediaKeys);
- }).then(function(){
- _mediaKeySession = _mediaKeys.createSession( 'persistent-usage-record' );
- waitForEventAndRunStep('encrypted', _video, onEncrypted, test);
- waitForEventAndRunStep('playing', _video, onPlaying, test);
- return config.servercertificate ? _mediaKeys.setServerCertificate(config.servercertificate) : true;
- }).then(function(success) {
- return testmediasource(config);
- }).then(function(source) {
- _mediaSource = source;
- _video.src = URL.createObjectURL(_mediaSource);
- _video.play();
- }).catch(onFailure);
- }, testname);
-}
diff --git a/testing/web-platform/tests/encrypted-media/scripts/playback-temporary-encrypted-clear-sources.js b/testing/web-platform/tests/encrypted-media/scripts/playback-temporary-encrypted-clear-sources.js
deleted file mode 100644
index 66781add3..000000000
--- a/testing/web-platform/tests/encrypted-media/scripts/playback-temporary-encrypted-clear-sources.js
+++ /dev/null
@@ -1,107 +0,0 @@
-function runTest(configEncrypted,configClear,qualifier) {
-
- var testname = testnamePrefix(qualifier, configEncrypted.keysystem)
- + ', temporary, '
- + /video\/([^;]*)/.exec(configEncrypted.videoType)[1]
- + ', playback, encrypted and clear sources';
-
- var configuration = { initDataTypes: [ configEncrypted.initDataType ],
- audioCapabilities: [ { contentType: configEncrypted.audioType } ],
- videoCapabilities: [ { contentType: configEncrypted.videoType } ],
- sessionTypes: [ 'temporary' ] };
-
- async_test(function(test) {
- var playbackCount = 0,
- _video = configEncrypted.video,
- _mediaKeys,
- _mediaKeySession,
- _mediaSource;
-
- 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');
- assert_in_array(event.messageType, ['license-request', 'individualization-request']);
-
- configEncrypted.messagehandler(event.messageType, event.message).then(function(response) {
- return _mediaKeySession.update( response );
- }).catch(onFailure);
- }
-
- function onEncrypted(event) {
- assert_equals(event.target, _video);
- assert_true(event instanceof window.MediaEncryptedEvent);
- assert_equals(event.type, 'encrypted');
-
- waitForEventAndRunStep('message', _mediaKeySession, onMessage, test);
- _mediaKeySession.generateRequest(configEncrypted.initData ? configEncrypted.initDataType : event.initDataType,
- configEncrypted.initData || event.initData).then(function(){
- return _video.setMediaKeys(_mediaKeys);
- }).catch(onFailure);
- }
-
- function onPlaying(event)
- {
- // Not using waitForEventAndRunStep() to avoid too many
- // EVENT(onTimeUpdate) logs.
- _video.addEventListener('timeupdate', onTimeUpdate, true);
- }
-
- function onTimeUpdate(event) {
- if (_video.currentTime < (configEncrypted.duration || 0.5)) {
- return;
- }
-
- _video.removeEventListener('timeupdate', onTimeUpdate, true);
-
- resetSrc().then(function(){
- if (playbackCount >= 2) {
- test.done();
- } else {
- playbackCount++;
- startPlayback();
- }
- }).catch(onFailure);
- }
-
- function resetSrc() {
- _video.pause();
- _video.removeAttribute('src');
- _video.load();
- return _video.setMediaKeys(null);
- }
-
- function startPlayback() {
- // Alternate between encrypted and unencrypted files.
- if (playbackCount % 2) {
- // Unencrypted files don't require MediaKeys
- testmediasource( configClear ).then(function( source ) {
- _mediaSource = source;
- _video.src = URL.createObjectURL(_mediaSource);
- _video.play();
- }).catch(onFailure);
- } else {
- navigator.requestMediaKeySystemAccess(configEncrypted.keysystem, [ configuration ]).then(function(access) {
- return access.createMediaKeys();
- }).then(function(mediaKeys) {
- _mediaKeys = mediaKeys;
- _mediaKeySession = _mediaKeys.createSession( 'temporary' );
- }).then(function() {
- return testmediasource(configEncrypted);
- }).then(function(source) {
- _mediaSource = source;
- _video.src = URL.createObjectURL(_mediaSource);
- _video.play();
- }).catch(onFailure);
- }
- }
-
- waitForEventAndRunStep('encrypted', _video, onEncrypted, test);
- waitForEventAndRunStep('playing', video, onPlaying, test);
- startPlayback();
- }, testname);
-}
diff --git a/testing/web-platform/tests/encrypted-media/scripts/playback-temporary-events.js b/testing/web-platform/tests/encrypted-media/scripts/playback-temporary-events.js
deleted file mode 100644
index dd05ba76c..000000000
--- a/testing/web-platform/tests/encrypted-media/scripts/playback-temporary-events.js
+++ /dev/null
@@ -1,134 +0,0 @@
-function runTest(config,qualifier) {
-
- var testname = testnamePrefix(qualifier, config.keysystem)
- + ', temporary, '
- + /video\/([^;]*)/.exec(config.videoType)[1]
- + ', playback, check events';
-
- var configuration = { initDataTypes: [ config.initDataType ],
- audioCapabilities: [ { contentType: config.audioType } ],
- videoCapabilities: [ { contentType: config.videoType } ],
- sessionTypes: [ 'temporary' ] };
-
- async_test(function(test) {
- var _video = config.video,
- _mediaKeys,
- _mediaKeySession,
- _mediaSource,
- _timeupdateEvent = false,
- _events = [ ];
-
- 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');
-
- assert_in_array( event.messageType, ['license-request', 'individualization-request']);
-
- if (event.messageType !== 'individualization-request') {
- _events.push(event.messageType);
- }
-
- config.messagehandler(event.messageType, event.message).then(function(response) {
- _events.push('license-response');
- waitForEventAndRunStep('keystatuseschange', _mediaKeySession, onKeyStatusesChange, test);
- return _mediaKeySession.update( response );
- }).then(function() {
- _events.push('updated');
- }).catch(onFailure);
- }
-
- function onKeyStatusesChange(event) {
- assert_equals(event.target, _mediaKeySession);
- assert_true(event instanceof window.Event);
- assert_equals(event.type, 'keystatuseschange');
- var hasKeys = false, pendingKeys = false;
- _mediaKeySession.keyStatuses.forEach(function(value, keyid) {
- assert_in_array(value, ['status-pending', 'usable']);
- hasKeys = true;
- pendingKeys = pendingKeys || (value === 'status-pending');
- });
-
- if (!hasKeys) {
- _events.push('emptykeyslist');
- } else if (!pendingKeys ) {
- _events.push('allkeysusable');
- _video.setMediaKeys(_mediaKeys).catch(onFailure);
- } else {
- assert_unreached('unexpected ' + event.type + ' event');
- }
- }
-
- function onEncrypted(event) {
- assert_equals(event.target, _video);
- assert_true(event instanceof window.MediaEncryptedEvent);
- assert_equals(event.type, 'encrypted');
-
- waitForEventAndRunStep('message', _mediaKeySession, onMessage, test);
- _mediaKeySession.generateRequest(config.initData ? config.initDataType : event.initDataType,
- config.initData || event.initData ).then(function() {
- _events.push('generaterequest');
- }).catch(onFailure);
- }
-
- function onClosed(event) {
- _events.push('closed-promise');
- setTimeout(test.step_func(function() {
- assert_array_equals(_events,
- [
- 'generaterequest',
- 'license-request',
- 'license-response',
- 'updated',
- 'allkeysusable',
- 'playing',
- 'closed',
- 'closed-promise',
- 'emptykeyslist'
- ],
- "Expected events sequence");
- test.done();
- } ), 0);
- }
-
- function onTimeupdate(event) {
- if (_video.currentTime > (config.duration || 1) && !_timeupdateEvent) {
- _timeupdateEvent = true;
- _video.pause();
-
- _mediaKeySession.closed.then(test.step_func(onClosed));
- _mediaKeySession.close().then(function() {
- _events.push('closed');
- }).catch(onFailure);
- }
- }
-
- function onPlaying(event) {
- _events.push('playing');
-
- // Not using waitForEventAndRunStep() to avoid too many
- // EVENT(onTimeUpdate) logs.
- _video.addEventListener('timeupdate', onTimeupdate, true);
- }
-
- navigator.requestMediaKeySystemAccess(config.keysystem, [configuration]).then(function(access) {
- return access.createMediaKeys();
- }).then(function(mediaKeys) {
- _mediaKeys = mediaKeys;
- _mediaKeySession = _mediaKeys.createSession('temporary');
-
- waitForEventAndRunStep('encrypted', _video, onEncrypted, test);
- waitForEventAndRunStep('playing', _video, onPlaying, test);
- }).then(function() {
- return testmediasource(config);
- }).then(function(source) {
- _mediaSource = source;
- _video.src = URL.createObjectURL(_mediaSource);
- _video.play();
- }).catch(onFailure);
- }, testname);
-}
diff --git a/testing/web-platform/tests/encrypted-media/scripts/playback-temporary-expired.js b/testing/web-platform/tests/encrypted-media/scripts/playback-temporary-expired.js
deleted file mode 100644
index 76fedbb7d..000000000
--- a/testing/web-platform/tests/encrypted-media/scripts/playback-temporary-expired.js
+++ /dev/null
@@ -1,84 +0,0 @@
-function runTest(config,qualifier) {
-
- var testname = testnamePrefix(qualifier, config.keysystem)
- + ', temporary, '
- + /video\/([^;]*)/.exec(config.videoType)[1]
- + ', expired license';
-
- var configuration = { initDataTypes: [config.initDataType],
- audioCapabilities: [{contentType: config.audioType}],
- videoCapabilities: [{contentType: config.videoType}],
- sessionTypes: ['temporary'] };
-
- async_test(function(test) {
-
- var _video = config.video,
- _mediaKeys,
- _mediaKeySession,
- _mediaSource;
-
- function onFailure(error) {
- forceTestFailureFromPromise(test, error);
- }
-
- function onEncrypted(event) {
- assert_equals(event.target, _video);
- assert_true(event instanceof window.MediaEncryptedEvent);
- assert_equals(event.type, 'encrypted');
-
- // Only create the session for the first encrypted event
- if (_mediaKeySession !== undefined) return;
-
- var initDataType = config.initData ? config.initDataType : event.initDataType;
- var initData = config.initData || event.initData;
-
- _mediaKeySession = _mediaKeys.createSession('temporary');
- waitForEventAndRunStep('message', _mediaKeySession, onMessage, test);
- _mediaKeySession.generateRequest(initDataType, initData).catch(onFailure);
- }
-
- function onMessage(event) {
- assert_equals(event.target, _mediaKeySession);
- assert_true(event instanceof window.MediaKeyMessageEvent);
- assert_equals(event.type, 'message');
-
- assert_in_array(event.messageType, ['license-request', 'individualization-request']);
-
- var expiration = Date.now().valueOf();
- config.messagehandler(event.messageType, event.message, expiration).then(function(response) {
- return event.target.update(response);
- }).then(test.step_func(function(){
- assert_approx_equals(event.target.expiration, expiration, 2000, "expiration attribute should equal provided expiration time");
- test.step_timeout(function() {
- _video.play();
- test.step_timeout(function() { test.done(); }, 2000);
- }, 5000);
- })).catch(onFailure);
- }
-
- function onPlaying(event) {
- // Not using waitForEventAndRunStep() to avoid too many
- // EVENT(onTimeUpdate) logs.
- _video.addEventListener('timeupdate', test.step_func(onTimeupdate), true);
- }
-
- function onTimeupdate(event) {
- _video.pause();
- assert_unreached("Playback should not start with expired license");
- }
-
- navigator.requestMediaKeySystemAccess(config.keysystem, [configuration]).then(function(access) {
- return access.createMediaKeys();
- }).then(function(mediaKeys) {
- _mediaKeys = mediaKeys;
- return _video.setMediaKeys(_mediaKeys);
- }).then(function(){
- waitForEventAndRunStep('encrypted', _video, onEncrypted, test);
- waitForEventAndRunStep('playing', _video, onPlaying, test);
- return testmediasource(config);
- }).then(function(source) {
- _mediaSource = source;
- _video.src = URL.createObjectURL(_mediaSource);
- }).catch(onFailure);
- }, testname);
-}
diff --git a/testing/web-platform/tests/encrypted-media/scripts/playback-temporary-multikey-multisession.js b/testing/web-platform/tests/encrypted-media/scripts/playback-temporary-multikey-multisession.js
deleted file mode 100644
index 8ff98cb05..000000000
--- a/testing/web-platform/tests/encrypted-media/scripts/playback-temporary-multikey-multisession.js
+++ /dev/null
@@ -1,91 +0,0 @@
-function runTest(config,qualifier) {
-
- var testname = testnamePrefix(qualifier, config.keysystem)
- + ', temporary, '
- + /video\/([^;]*)/.exec(config.videoType)[1]
- + ', playback with multiple keys and sessions, '
- + config.testcase;
-
- var configuration = { initDataTypes: [ config.initDataType ],
- audioCapabilities: [ { contentType: config.audioType } ],
- videoCapabilities: [ { contentType: config.videoType } ],
- sessionTypes: [ 'temporary' ] };
-
- async_test(function(test) {
-
- var _video = config.video,
- _mediaKeys,
- _mediaKeySessions = [];
-
- function onFailure(error) {
- forceTestFailureFromPromise(test, error);
- }
-
- function onMessage(event) {
- consoleWrite("message " + event.messageType);
- assert_any(assert_equals, event.target, _mediaKeySessions);
- assert_true(event instanceof window.MediaKeyMessageEvent);
- assert_equals(event.type, 'message');
- assert_in_array(event.messageType, ['license-request', 'individualization-request']);
-
- config.messagehandler(event.messageType, event.message, {variantId: event.target._variantId}).then(function(response) {
- return event.target.update(response);
- }).catch(onFailure);
- }
-
- function onWaitingForKey(event) {
- consoleWrite("waitingforkey");
- }
-
- function onPlaying(event) {
- consoleWrite("playing");
- waitForEventAndRunStep('pause', _video, onStopped, test);
- waitForEventAndRunStep('waiting', _video, onStopped, test);
- waitForEventAndRunStep('stalled', _video, onStopped, test);
- }
-
- function onStopped(event) {
- consoleWrite( event.type );
- if (_mediaKeySessions.length < config.initData.length) {
- var mediaKeySession = _mediaKeys.createSession('temporary');
- waitForEventAndRunStep('message', mediaKeySession, onMessage, test);
- mediaKeySession._variantId = config.variantIds ? config.variantIds[_mediaKeySessions.length] : undefined;
- mediaKeySession.generateRequest(config.initDataType, config.initData[_mediaKeySessions.length]).catch(onFailure);
- _mediaKeySessions.push(mediaKeySession);
- }
- }
-
- function onTimeupdate(event) {
- if ( _video.currentTime > (config.duration || 1)) {
- _video.removeEventListener('timeupdate', onTimeupdate);
- _video.pause();
- test.done();
- }
- }
-
- navigator.requestMediaKeySystemAccess(config.keysystem, [configuration]).then(function(access) {
- return access.createMediaKeys();
- }).then(function(mediaKeys) {
- _mediaKeys = mediaKeys;
- return _video.setMediaKeys(_mediaKeys);
- }).then(function(){
- waitForEventAndRunStep('waitingforkey', _video, onWaitingForKey, test);
- waitForEventAndRunStep('playing', _video, onPlaying, test);
-
- // Not using waitForEventAndRunStep() to avoid too many
- // EVENT(onTimeUpdate) logs.
- _video.addEventListener('timeupdate', onTimeupdate, true);
-
- var mediaKeySession = _mediaKeys.createSession('temporary');
- waitForEventAndRunStep('message', mediaKeySession, onMessage, test);
- _mediaKeySessions.push(mediaKeySession);
- mediaKeySession._variantId = config.variantIds ? config.variantIds[0] : undefined;
- return mediaKeySession.generateRequest(config.initDataType, config.initData[0]);
- }).then(function() {
- return testmediasource(config);
- }).then(function(source) {
- _video.src = URL.createObjectURL(source);
- _video.play();
- }).catch(onFailure);
- }, testname);
-}
diff --git a/testing/web-platform/tests/encrypted-media/scripts/playback-temporary-multikey-sequential.js b/testing/web-platform/tests/encrypted-media/scripts/playback-temporary-multikey-sequential.js
deleted file mode 100644
index 597e8f9b0..000000000
--- a/testing/web-platform/tests/encrypted-media/scripts/playback-temporary-multikey-sequential.js
+++ /dev/null
@@ -1,122 +0,0 @@
-function runTest(config,qualifier) {
-
- // config.initData contains a list of keys. We expect those to be needed in order and get
- // one waitingforkey event for each one.
-
- var testname = testnamePrefix(qualifier, config.keysystem)
- + ', successful playback, temporary, '
- + /video\/([^;]*)/.exec(config.videoType)[1]
- + ', multiple keys, sequential'
- + (config.checkReadyState ? ', readyState' : '');
-
- var configuration = { initDataTypes: [config.initDataType],
- audioCapabilities: [{contentType: config.audioType}],
- videoCapabilities: [{contentType: config.videoType}],
- sessionTypes: ['temporary'] };
-
- async_test(function(test) {
- var _video = config.video,
- _mediaKeys,
- _mediaKeySessions = [],
- _mediaSource,
- _waitingForKey = false,
- _playingCount = 0,
- _canplayCount = 0,
- _timeupdateWhileWaitingCount = 0;
-
- function startNewSession() {
- assert_less_than(_mediaKeySessions.length, config.initData.length);
- var mediaKeySession = _mediaKeys.createSession('temporary');
- waitForEventAndRunStep('message', mediaKeySession, onMessage, test);
- _mediaKeySessions.push(mediaKeySession);
- mediaKeySession.variantId = config.variantIds ? config.variantIds[_mediaKeySessions.length - 1] : undefined;
- mediaKeySession.generateRequest(config.initDataType, config.initData[_mediaKeySessions.length - 1]).catch(onFailure);
- }
-
- function onFailure(error) {
- forceTestFailureFromPromise(test, error);
- }
-
- function onMessage(event) {
- var firstMessage = !_video.src;
- config.messagehandler(event.messageType, event.message, {variantId: event.target.variantId}).then(function(response) {
- return event.target.update(response);
- }).then(function(){
- if (firstMessage) {
- _video.src = URL.createObjectURL(_mediaSource);
- return _mediaSource.done;
- } else if (event.target.keyStatuses.size > 0){
- _waitingForKey = false;
- return Promise.resolve();
- }
- }).then(function(){
- if (firstMessage) {
- _video.play();
- }
- }).catch(onFailure);
- }
-
- function onWaitingForKey(event) {
- _waitingForKey = true;
- if (config.checkReadyState) {
- // This test does not start playing until the first license has been provided,
- // so this event should occur when transitioning between keys.
- // Thus, the frame at the current playback position is available and readyState
- // should be HAVE_CURRENT_DATA.
- assert_equals(_video.readyState, _video.HAVE_CURRENT_DATA, "Video readyState should be HAVE_CURRENT_DATA on watingforkey event");
- }
- startNewSession();
- }
-
- function onPlaying(event) {
- _playingCount++;
- assert_equals(_mediaKeySessions.length, _playingCount, "Should get one 'playing' event per key / session added");
- assert_less_than_equal(_playingCount, 2, "Should not get more than two 'playing' events.");
- }
-
- function onCanPlay(event) {
- _canplayCount++;
- assert_equals(_mediaKeySessions.length, _canplayCount, "Should get one 'canplay' event per key / session added");
- assert_less_than_equal(_canplayCount, 2, "Should not get more than two 'canplay' events.");
- }
-
- function onTimeupdate(event) {
- // We should not receive 'timeupdate' events due to playing while waiting for a key, except
- // when we first start waiting for key we should change the readyState to HAVE_CURRENT_DATA
- // which will trigger the "If the previous ready state was HAVE_FUTURE_DATA or more, and
- // the new ready state is HAVE_CURRENT_DATA or less" case of the readyState change
- // algorithm which requires a "timeupdate" event be fired.
- if (_waitingForKey) {
- assert_equals(++_timeupdateWhileWaitingCount, 1, "Should only receive one timeupdate while waiting for key");
- assert_equals(_video.readyState, _video.HAVE_CURRENT_DATA, "Video readyState should be HAVE_CURRENT_DATA while wating for key");
- }
-
- if (_video.currentTime > config.duration) {
- assert_equals(_mediaKeySessions.length, config.initData.length, "It should require all keys to reach end of content");
- assert_equals(_timeupdateWhileWaitingCount, 1, "Should have only received exactly one timeupdate while waiting for key");
- _video.pause();
- test.done();
- }
- }
-
- navigator.requestMediaKeySystemAccess(config.keysystem, [configuration]).then(function(access) {
- return access.createMediaKeys();
- }).then(function(mediaKeys) {
- _mediaKeys = mediaKeys;
- return _video.setMediaKeys(_mediaKeys);
- }).then(function(){
- // Not using waitForEventAndRunStep() to avoid too many
- // EVENT(onTimeUpdate) logs.
- _video.addEventListener('timeupdate', test.step_func(onTimeupdate), true);
-
- waitForEventAndRunStep('waitingforkey', _video, onWaitingForKey, test);
- waitForEventAndRunStep('playing', _video, onPlaying, test);
- waitForEventAndRunStep('canplay', _video, onCanPlay, test);
-
- return testmediasource(config);
- }).then(function(source) {
- _mediaSource = source;
- startNewSession();
- }).catch(onFailure);
- }, testname);
-}
diff --git a/testing/web-platform/tests/encrypted-media/scripts/playback-temporary-multisession.js b/testing/web-platform/tests/encrypted-media/scripts/playback-temporary-multisession.js
deleted file mode 100644
index 3e9027aea..000000000
--- a/testing/web-platform/tests/encrypted-media/scripts/playback-temporary-multisession.js
+++ /dev/null
@@ -1,74 +0,0 @@
-function runTest(config,qualifier) {
-
- // This test assumes one session is required for each provided initData
-
- var testname = testnamePrefix(qualifier, config.keysystem)
- + ', temporary, '
- + /video\/([^;]*)/.exec(config.videoType)[1]
- + ', playback with multiple sessions, '
- + config.testcase;
-
- var configuration = { initDataTypes: [ config.initDataType ],
- audioCapabilities: [ { contentType: config.audioType } ],
- videoCapabilities: [ { contentType: config.videoType } ],
- sessionTypes: [ 'temporary' ] };
-
- async_test(function(test) {
- var _video = config.video,
- _mediaKeys,
- _mediaKeySessions = [],
- _mediaSource;
-
- function onFailure(error) {
- forceTestFailureFromPromise(test, error);
- }
-
- function onMessage(event) {
- assert_any(assert_equals, event.target, _mediaKeySessions);
- assert_true(event instanceof window.MediaKeyMessageEvent);
- assert_equals(event.type, 'message');
-
- assert_in_array(event.messageType, ['license-request', 'individualization-request']);
-
- config.messagehandler(event.messageType, event.message, {variantId: event.target._variantId}).then(function(response) {
- return event.target.update(response);
- }).catch(onFailure);
- }
-
- function onPlaying(event) {
- // Not using waitForEventAndRunStep() to avoid too many
- // EVENT(onTimeUpdate) logs.
- _video.addEventListener('timeupdate', onTimeupdate, true);
- }
-
- function onTimeupdate(event) {
- if (_video.currentTime > (config.duration || 1)) {
- _video.removeEventListener('timeupdate', onTimeupdate);
- _video.pause();
- test.done();
- }
- }
-
- navigator.requestMediaKeySystemAccess(config.keysystem, [configuration]).then(function(access) {
- return access.createMediaKeys();
- }).then(function(mediaKeys) {
- _mediaKeys = mediaKeys;
- return _video.setMediaKeys(_mediaKeys);
- }).then(function() {
- waitForEventAndRunStep('playing', _video, onPlaying, test);
-
- config.initData.forEach(function(initData,i) {
- var mediaKeySession = _mediaKeys.createSession( 'temporary' );
- mediaKeySession._variantId = config.variantIds ? config.variantIds[i] : undefined;
- waitForEventAndRunStep('message', mediaKeySession, onMessage, test);
- _mediaKeySessions.push(mediaKeySession);
- mediaKeySession.generateRequest(config.initDataType, initData).catch(onFailure);
- } );
- return testmediasource(config);
- }).then(function(source) {
- _mediaSource = source;
- _video.src = URL.createObjectURL(_mediaSource);
- _video.play();
- }).catch(onFailure);
- }, testname);
-}
diff --git a/testing/web-platform/tests/encrypted-media/scripts/playback-temporary-setMediaKeys.js b/testing/web-platform/tests/encrypted-media/scripts/playback-temporary-setMediaKeys.js
deleted file mode 100644
index c3da83c1a..000000000
--- a/testing/web-platform/tests/encrypted-media/scripts/playback-temporary-setMediaKeys.js
+++ /dev/null
@@ -1,103 +0,0 @@
-SETMEDIAKEYS_IMMEDIATELY = 0;
-SETMEDIAKEYS_AFTER_SRC = 1;
-SETMEDIAKEYS_ONENCRYPTED = 2;
-SETMEDIAKEYS_AFTER_UPDATE = 3;
-
-function runTest(config,qualifier) {
-
- var testcase = (config.testcase === SETMEDIAKEYS_IMMEDIATELY) ? 'setMediaKeys first'
- : (config.testcase === SETMEDIAKEYS_AFTER_SRC) ? 'setMediaKeys after setting video.src'
- : (config.testcase === SETMEDIAKEYS_ONENCRYPTED) ? 'setMediaKeys in encrypted event'
- : (config.testcase === SETMEDIAKEYS_AFTER_UPDATE) ? 'setMediaKeys after updating session'
- : 'unknown';
-
- var testname = testnamePrefix(qualifier, config.keysystem)
- + ', temporary, '
- + /video\/([^;]*)/.exec(config.videoType)[1]
- + ', playback, ' + testcase;
-
- var configuration = { initDataTypes: [ config.initDataType ],
- audioCapabilities: [ { contentType: config.audioType } ],
- videoCapabilities: [ { contentType: config.videoType } ],
- sessionTypes: [ 'temporary' ] };
-
- async_test(function(test) {
- var _video = config.video,
- _mediaKeys,
- _mediaKeySession,
- _mediaSource;
-
- 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');
-
- assert_in_array( event.messageType, ['license-request', 'individualization-request']);
-
- config.messagehandler(event.messageType, event.message).then(function(response) {
- return _mediaKeySession.update( response );
- }).then(function() {
- if (config.testcase === SETMEDIAKEYS_AFTER_UPDATE) {
- return _video.setMediaKeys(_mediaKeys);
- }
- }).catch(onFailure);
- }
-
- function onEncrypted(event) {
- assert_equals(event.target, _video);
- assert_true(event instanceof window.MediaEncryptedEvent);
- assert_equals(event.type, 'encrypted');
-
- var promise = ( config.testcase === SETMEDIAKEYS_ONENCRYPTED )
- ? _video.setMediaKeys(_mediaKeys)
- : Promise.resolve();
-
- promise.then( function() {
- waitForEventAndRunStep('message', _mediaKeySession, onMessage, test);
- return _mediaKeySession.generateRequest(config.initData ? config.initDataType : event.initDataType,
- config.initData || event.initData );
- }).catch(onFailure);
- }
-
- function onTimeupdate(event) {
- if (_video.currentTime > (config.duration || 1)) {
- _video.pause();
- test.done();
- }
- }
-
- function onPlaying(event) {
- // Not using waitForEventAndRunStep() to avoid too many
- // EVENT(onTimeUpdate) logs.
- _video.addEventListener('timeupdate', onTimeupdate, true);
- }
-
- navigator.requestMediaKeySystemAccess(config.keysystem, [configuration]).then(function(access) {
- return access.createMediaKeys();
- }).then(test.step_func(function(mediaKeys) {
- _mediaKeys = mediaKeys;
- if ( config.testcase === SETMEDIAKEYS_IMMEDIATELY ) {
- return _video.setMediaKeys( _mediaKeys );
- }
- })).then(function(){
- _mediaKeySession = _mediaKeys.createSession( 'temporary' );
-
- waitForEventAndRunStep('encrypted', _video, onEncrypted, test);
- waitForEventAndRunStep('playing', _video, onPlaying, test);
-
- return testmediasource(config);
- }).then(test.step_func(function(source) {
- _mediaSource = source;
- _video.src = URL.createObjectURL(_mediaSource);
- _video.play();
-
- if (config.testcase === SETMEDIAKEYS_AFTER_SRC) {
- return _video.setMediaKeys(_mediaKeys);
- }
- })).catch(onFailure);
- }, testname);
-}
diff --git a/testing/web-platform/tests/encrypted-media/scripts/playback-temporary-two-videos.js b/testing/web-platform/tests/encrypted-media/scripts/playback-temporary-two-videos.js
deleted file mode 100644
index 7d63cd604..000000000
--- a/testing/web-platform/tests/encrypted-media/scripts/playback-temporary-two-videos.js
+++ /dev/null
@@ -1,81 +0,0 @@
-function runTest(config,qualifier) {
-
- var testname = testnamePrefix(qualifier, config.keysystem)
- + ', temporary, '
- + /video\/([^;]*)/.exec(config.videoType)[1]
- + ', playback two videos';
-
- var configuration = { initDataTypes: [ config.initDataType ],
- audioCapabilities: [ { contentType: config.audioType } ],
- videoCapabilities: [ { contentType: config.videoType } ],
- sessionTypes: [ 'temporary' ] };
-
- promise_test(function(test)
- {
- var promises = config.video.map(function(video) { return play_video_as_promise(test,video); });
- return Promise.all(promises);
-
- }, testname);
-
- function play_video_as_promise(test, _video) {
- var _mediaKeys,
- _mediaKeySession,
- _mediaSource;
-
- 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');
-
- assert_in_array( event.messageType, ['license-request', 'individualization-request']);
-
- config.messagehandler(event.messageType, event.message).then(function(response) {
- return _mediaKeySession.update(response);
- }).catch(onFailure);
- }
-
- function onEncrypted(event) {
- assert_equals(event.target, _video);
- assert_true(event instanceof window.MediaEncryptedEvent);
- assert_equals(event.type, 'encrypted');
-
- waitForEventAndRunStep('message', _mediaKeySession, onMessage, test);
-
- _mediaKeySession.generateRequest(config.initData ? config.initDataType : event.initDataType,
- config.initData || event.initData).catch(onFailure);
- }
-
- function wait_for_timeupdate_message(video)
- {
- return new Promise(function(resolve) {
- video.addEventListener('timeupdate', function listener(event) {
- if (event.target.currentTime > (config.duration || 1))
- {
- video.removeEventListener('timeupdate', listener);
- resolve(event);
- }
- });
- });
- };
-
- return navigator.requestMediaKeySystemAccess(config.keysystem, [configuration]).then(function(access) {
- return access.createMediaKeys();
- }).then(function(mediaKeys) {
- _mediaKeys = mediaKeys;
- return _video.setMediaKeys(_mediaKeys);
- }).then(function() {
- _mediaKeySession = _mediaKeys.createSession('temporary');
- waitForEventAndRunStep('encrypted', _video, onEncrypted, test);
- return testmediasource(config);
- }).then(function(source) {
- _mediaSource = source;
- _video.src = URL.createObjectURL(_mediaSource);
- _video.play();
- return wait_for_timeupdate_message(_video);
- }).catch(onFailure);
- }
-}
diff --git a/testing/web-platform/tests/encrypted-media/scripts/playback-temporary-waitingforkey.js b/testing/web-platform/tests/encrypted-media/scripts/playback-temporary-waitingforkey.js
deleted file mode 100644
index 8fc67bff1..000000000
--- a/testing/web-platform/tests/encrypted-media/scripts/playback-temporary-waitingforkey.js
+++ /dev/null
@@ -1,69 +0,0 @@
-function runTest(config,qualifier) {
-
- // config.initData contains a list of keys. We expect those to be needed in order and get
- // one waitingforkey event for each one.
-
- var testname = testnamePrefix(qualifier, config.keysystem)
- + ', successful playback, temporary, '
- + /video\/([^;]*)/.exec(config.videoType)[1]
- + ', waitingforkey event, '
- + config.initData.length + ' key' + (config.initData.length > 1 ? 's' : '');
-
- var configuration = { initDataTypes: [ config.initDataType ],
- audioCapabilities: [ { contentType: config.audioType } ],
- videoCapabilities: [ { contentType: config.videoType } ],
- sessionTypes: [ 'temporary' ] };
-
- async_test(function(test) {
- var _video = config.video,
- _mediaKeys,
- _mediaKeySessions = [],
- _mediaSource;
-
- function onFailure(error) {
- forceTestFailureFromPromise(test, error);
- }
-
- function onMessage(event) {
- config.messagehandler( event.messageType, event.message ).then( function( response ) {
- return event.target.update( response );
- }).catch(onFailure);
- }
-
- function onWaitingForKey(event) {
- // Expect one waitingforkey event for each initData we were given
- assert_less_than(_mediaKeySessions.length, config.initData.length);
- var mediaKeySession = _mediaKeys.createSession( 'temporary' );
- waitForEventAndRunStep('message', mediaKeySession, onMessage, test);
- _mediaKeySessions.push(mediaKeySession);
- mediaKeySession.generateRequest(config.initDataType, config.initData[_mediaKeySessions.length - 1]).catch(onFailure);
- }
-
- function onTimeupdate(event) {
- if (_video.currentTime > (config.duration || 1)) {
- assert_equals(_mediaKeySessions.length, config.initData.length);
- _video.removeEventListener('timeupdate', onTimeupdate);
- _video.pause();
- test.done();
- }
- }
-
- navigator.requestMediaKeySystemAccess(config.keysystem, [configuration]).then(function(access) {
- return access.createMediaKeys();
- }).then(function(mediaKeys) {
- _mediaKeys = mediaKeys;
- return _video.setMediaKeys(_mediaKeys);
- }).then(function(){
- waitForEventAndRunStep('waitingforkey', _video, onWaitingForKey, test);
-
- // Not using waitForEventAndRunStep() to avoid too many
- // EVENT(onTimeUpdate) logs.
- _video.addEventListener('timeupdate', onTimeupdate, true);
- return testmediasource(config);
- }).then(function(source) {
- _mediaSource = source;
- _video.src = URL.createObjectURL(_mediaSource);
- _video.play();
- }).catch(onFailure);
- }, testname);
-}
diff --git a/testing/web-platform/tests/encrypted-media/scripts/playback-temporary.js b/testing/web-platform/tests/encrypted-media/scripts/playback-temporary.js
deleted file mode 100644
index 53dd3e65d..000000000
--- a/testing/web-platform/tests/encrypted-media/scripts/playback-temporary.js
+++ /dev/null
@@ -1,80 +0,0 @@
-function runTest(config,qualifier) {
-
- var testname = testnamePrefix(qualifier, config.keysystem)
- + ', temporary, '
- + /video\/([^;]*)/.exec(config.videoType)[1]
- + ', playback, ' + config.testcase;
-
- var configuration = { initDataTypes: [ config.initDataType ],
- audioCapabilities: [ { contentType: config.audioType } ],
- videoCapabilities: [ { contentType: config.videoType } ],
- sessionTypes: [ 'temporary' ] };
-
- async_test(function(test) {
-
- var _video = config.video,
- _mediaKeys,
- _mediaKeySession,
- _mediaSource;
-
- function onFailure(error) {
- forceTestFailureFromPromise(test, error);
- }
-
- function onEncrypted(event) {
- assert_equals(event.target, _video);
- assert_true(event instanceof window.MediaEncryptedEvent);
- assert_equals(event.type, 'encrypted');
-
- // Only create the session for the firs encrypted event
- if (_mediaKeySession !== undefined) return;
-
- var initDataType = config.initData ? config.initDataType : event.initDataType;
- var initData = config.initData || event.initData;
-
- _mediaKeySession = _mediaKeys.createSession('temporary');
- waitForEventAndRunStep('message', _mediaKeySession, onMessage, test);
- _mediaKeySession.generateRequest( initDataType, initData ).catch(onFailure);
- }
-
- function onMessage(event) {
- assert_equals(event.target, _mediaKeySession);
- assert_true(event instanceof window.MediaKeyMessageEvent);
- assert_equals(event.type, 'message');
-
- assert_in_array(event.messageType, ['license-request', 'individualization-request']);
-
- config.messagehandler(event.messageType, event.message).then(function(response) {
- return event.target.update(response);
- }).catch(onFailure);
- }
-
- function onPlaying(event) {
- // Not using waitForEventAndRunStep() to avoid too many
- // EVENT(onTimeUpdate) logs.
- _video.addEventListener('timeupdate', onTimeupdate, true);
- }
-
- function onTimeupdate(event) {
- if ( _video.currentTime > (config.duration || 1)) {
- _video.pause();
- test.done();
- }
- }
-
- navigator.requestMediaKeySystemAccess(config.keysystem, [configuration]).then(function(access) {
- return access.createMediaKeys();
- }).then(function(mediaKeys) {
- _mediaKeys = mediaKeys;
- return _video.setMediaKeys(_mediaKeys);
- }).then(function(){
- waitForEventAndRunStep('encrypted', _video, onEncrypted, test);
- waitForEventAndRunStep('playing', _video, onPlaying, test);
- return testmediasource(config);
- }).then(function(source) {
- _mediaSource = source;
- _video.src = URL.createObjectURL(_mediaSource);
- _video.play();
- }).catch(onFailure);
- }, testname);
-}
diff --git a/testing/web-platform/tests/encrypted-media/scripts/requestmediakeysystemaccess.js b/testing/web-platform/tests/encrypted-media/scripts/requestmediakeysystemaccess.js
deleted file mode 100644
index 98be50bb8..000000000
--- a/testing/web-platform/tests/encrypted-media/scripts/requestmediakeysystemaccess.js
+++ /dev/null
@@ -1,320 +0,0 @@
-function runTest(config, qualifier) {
-
- var prefix = testnamePrefix(qualifier, config.keysystem) + ', requestMediaKeySystemAccess: ';
-
- function expect_error(keySystem, configurations, expectedError, testname) {
-
- var audioCapabilities = configurations.length ? configurations[0].audioCapabilities : undefined,
- videoCapabilities = configurations.length ? configurations[0].videoCapabilities : undefined,
- audiocontenttypes = audioCapabilities ? audioCapabilities.map( function(ac) { return "'" + ac.contentType + "'"; } ).join(',') : '',
- videocontenttypes = videoCapabilities ? videoCapabilities.map( function(ac) { return "'" + ac.contentType + "'"; } ).join(',') : '',
- modifiedtestname = testname.replace( '%ks', keySystem ).replace( '%audiocontenttype', audiocontenttypes ).replace( '%videocontenttype', videocontenttypes );
-
- promise_test(function(test) {
- return navigator.requestMediaKeySystemAccess(keySystem, configurations).then(function(a) {
- assert_unreached('Unexpected requestMediaKeySystemAccess() success.');
- }, function(e) {
- assert_equals(e.name, expectedError);
- });
- }, prefix + modifiedtestname + ' should result in ' + expectedError );
- }
-
- function assert_subset(actual, expected, path) {
- if (typeof expected == 'string') {
- assert_equals(actual, expected, path);
- } else {
- if (expected.hasOwnProperty('length')) {
- assert_equals(actual.length, expected.length, path + '.length');
- }
- for (property in expected) {
- assert_subset(actual[property], expected[property], path + '.' + property);
- }
- }
- }
-
- function expect_config(keySystem, configurations, expectedConfiguration, testname) {
- promise_test(function(test) {
- return navigator.requestMediaKeySystemAccess(keySystem, configurations).then(function(a) {
- assert_subset(a.getConfiguration(), expectedConfiguration, testname + ': ');
- });
- }, testname);
- }
-
- // Tests for Key System.
- expect_error('', [{}], 'InvalidAccessError', 'Empty Key System (%ks)');
- expect_error('com.example.unsupported', [{}], 'NotSupportedError', 'Unsupported Key System (%ks)');
- expect_error(config.keysystem + '.', [{}], 'NotSupportedError', 'Key System ending in "." (%ks)');
- expect_error(config.keysystem.toUpperCase(), [{}], 'NotSupportedError', 'Capitalized Key System (%ks)');
- expect_error(config.keysystem + '\u028F', [{}], 'NotSupportedError', 'Non-ASCII Key System (%ks)');
-
- // Parent of Clear Key not supported.
- expect_error(config.keysystem.match(/^(.*?)\./)[1], [{}], 'NotSupportedError', 'Root domain of Key System alone (%ks)');
- expect_error(config.keysystem.match(/^(.*?)\./)[0], [{}], 'NotSupportedError', 'Root domain of Key System, with dot (%ks)');
- expect_error(config.keysystem.match(/^(.*?\..*?)\./)[1], [{}], 'NotSupportedError', 'Domain of Key System along (%ks)');
- expect_error(config.keysystem.match(/^(.*?\..*?)\./)[0], [{}], 'NotSupportedError', 'Domain of Key System, with dot (%ks)');
-
- // Child of Clear Key not supported.
- expect_error(config.keysystem+'.foo', [{}], 'NotSupportedError', 'Child of Key System');
-
- // Prefixed Clear Key not supported.
- expect_error('webkit-'+config.keysystem, [{}], 'NotSupportedError', 'Prefixed Key System');
-
- // Incomplete names.
- expect_error(config.keysystem.substr(0,7)+config.keysystem.substr(8), [{}], 'NotSupportedError', 'Incomplete Key System name (%ks)');
- expect_error(config.keysystem.substr(0,config.keysystem.length-1), [{}], 'NotSupportedError', 'Incomplete Key System name (%ks)');
-
- // Spaces in key system name not supported.
- expect_error(' '+config.keysystem, [{}], 'NotSupportedError', 'Leading space in Key System name (%ks)');
- expect_error(config.keysystem.substr(0,6) + ' ' + config.keysystem.substr(6), [{}], 'NotSupportedError', 'Extra space in Key System name (%ks)');
- expect_error(config.keysystem + ' ', [{}], 'NotSupportedError', 'Trailing space in Key System name (%ks)');
-
- // Extra dots in key systems names not supported.
- expect_error('.' + config.keysystem, [{}], 'NotSupportedError', 'Leading dot in Key System name (%ks)');
- expect_error(config.keysystem.substr(0,6) + '.' + config.keysystem.substr(6), [{}], 'NotSupportedError', 'Trailing dot in Key System name (%ks)');
- expect_error(config.keysystem + '.', [{}], 'NotSupportedError', 'Trailing dot in Key System name (%ks)');
-
- // Key system name is case sensitive.
- if (config.keysystem !== config.keysystem.toUpperCase()) {
- expect_error(config.keysystem.toUpperCase(), [{}], 'NotSupportedError', 'Key System name is case sensitive (%ks)');
- }
-
- if (config.keysystem !== config.keysystem.toLowerCase()) {
- expect_error(config.keysystem.toLowerCase(), [{}], 'NotSupportedError', 'Key System name is case sensitive (%ks)');
- }
-
- // Tests for trivial configurations.
- expect_error(config.keysystem, [], 'InvalidAccessError', 'Empty supportedConfigurations');
- expect_config(config.keysystem, [{}], {}, 'Empty configuration');
-
- // Various combinations of supportedConfigurations.
- expect_config(config.keysystem, [{
- initDataTypes: [config.initDataType],
- audioCapabilities: [{contentType: config.audioType}],
- videoCapabilities: [{contentType: config.videoType}],
- }], {
- initDataTypes: [config.initDataType],
- audioCapabilities: [{contentType: config.audioType}],
- videoCapabilities: [{contentType: config.videoType}],
- }, 'Basic supported configuration');
-
- expect_config(config.keysystem, [{
- initDataTypes: ['fakeidt', config.initDataType],
- audioCapabilities: [{contentType: 'audio/fake'}, {contentType: config.audioType}],
- videoCapabilities: [{contentType: 'video/fake'}, {contentType: config.videoType}],
- }], {
- initDataTypes: [config.initDataType],
- audioCapabilities: [{contentType: config.audioType}],
- videoCapabilities: [{contentType: config.videoType}],
- }, 'Partially supported configuration');
-
- expect_config(config.keysystem, [{
- audioCapabilities: [{contentType: config.audioType}],
- }], {
- audioCapabilities: [{contentType: config.audioType}],
- }, 'Supported audio codec');
-
- expect_config(config.keysystem, [{
- audioCapabilities: [{contentType: config.audioType.replace(/^(.*?);(.*)/, "$1; $2")}],
- }], {
- audioCapabilities: [{contentType: config.audioType.replace(/^(.*?);(.*)/, "$1; $2")}],
- }, 'ContentType formatting must be preserved');
-
- expect_error(config.keysystem, [{
- audioCapabilities: [{contentType: 'audio/webm; codecs=fake'}],
- }], 'NotSupportedError', 'Unsupported audio codec (%audiocontenttype)');
-
- expect_error(config.keysystem, [{
- audioCapabilities: [{contentType: 'video/webm; codecs=fake'}],
- }], 'NotSupportedError', 'Unsupported video codec (%videocontenttype)');
-
- expect_error(config.keysystem, [{
- audioCapabilities: [
- {contentType: 'audio/webm; codecs=mp4a'},
- {contentType: 'audio/webm; codecs=mp4a.40.2'}
- ],
- }], 'NotSupportedError', 'Mismatched audio container/codec (%audiocontenttype)');
-
- expect_error(config.keysystem, [{
- audioCapabilities: [{contentType: config.videoType}],
- }], 'NotSupportedError', 'Video codec specified in audio field (%audiocontenttype)');
-
- expect_error(config.keysystem, [{
- videoCapabilities: [{contentType: config.audioType}],
- }], 'NotSupportedError', 'Audio codec specified in video field (%videocontenttype)');
-
- expect_error(config.keysystem, [{
- audioCapabilities: [
- {contentType: 'audio/webm; codecs=avc1'},
- {contentType: 'audio/webm; codecs=avc1.42e01e'}
- ],
- }], 'NotSupportedError', 'Mismatched audio container/codec (%audiocontenttype)');
-
- expect_error(config.keysystem, [{
- audioCapabilities: [
- {contentType: 'audio/mp4; codecs=vorbis'}
- ],
- }], 'NotSupportedError', 'Mismatched audio container/codec (%audiocontenttype)');
-
- expect_config(config.keysystem, [
- {initDataTypes: ['fakeidt']},
- {initDataTypes: [config.initDataType]}
- ], {initDataTypes: [config.initDataType]}, 'Two configurations, one supported');
-
- expect_config(config.keysystem, [
- {initDataTypes: [config.initDataType]},
- {}
- ], {initDataTypes: [config.initDataType]}, 'Two configurations, both supported');
-
- // Audio MIME type does not support video codecs.
- expect_error(config.keysystem, [{
- audioCapabilities: [
- {contentType: 'audio/webm; codecs="vp8,vorbis"'},
- {contentType: 'audio/webm; codecs="vorbis, vp8"'},
- {contentType: 'audio/webm; codecs="vp8"'}
- ],
- }], 'NotSupportedError', 'Audio MIME type does not support video codecs (webm) (%audiocontenttype)');
-
- expect_error(config.keysystem, [{
- audioCapabilities: [
- {contentType: 'audio/mp4; codecs="avc1"'},
- {contentType: 'audio/mp4; codecs="avc1.4d401e"'},
- ],
- }], 'NotSupportedError', 'Audio MIME type does not support video codecs (mp4) (%audiocontenttype)');
-
- // Video MIME type does not support audio codecs.
- expect_error(config.keysystem, [{
- videoCapabilities: [
- {contentType: 'video/webm; codecs="vp8,vorbis"'},
- {contentType: 'video/webm; codecs="vorbis, vp8"'},
- {contentType: 'video/webm; codecs="vorbis"'}
- ],
- }], 'NotSupportedError', 'Video MIME type does not support audio codecs (webm) (%videocontenttype)');
-
- expect_error(config.keysystem, [{
- videoCapabilities: [
- {contentType: 'video/mp4; codecs="mp4a"'},
- {contentType: 'video/mp4; codecs="mp4a.40.2"'}
- ],
- }], 'NotSupportedError', 'Video MIME type does not support audio codecs (mp4) (%videocontenttype)');
-
- // WebM does not support AVC1/AAC.
- expect_error(config.keysystem, [{
- audioCapabilities: [
- {contentType: 'audio/webm; codecs="aac"'},
- {contentType: 'audio/webm; codecs="avc1"'},
- {contentType: 'audio/webm; codecs="vp8,aac"'}
- ],
- }], 'NotSupportedError', 'WebM audio does not support AVC1/AAC (%audiocontenttype)');
-
- expect_error(config.keysystem, [{
- videoCapabilities: [
- {contentType: 'video/webm; codecs="aac"'},
- {contentType: 'video/webm; codecs="avc1"'},
- {contentType: 'video/webm; codecs="vp8,aac"'}
- ],
- }], 'NotSupportedError', 'WebM video does not support AVC1/AAC (%videocontenttype)');
-
- // Extra space is allowed in contentType.
- expect_config(config.keysystem, [{
- videoCapabilities: [{contentType: ' ' + config.videoType}],
- }], {
- videoCapabilities: [{contentType: ' ' + config.videoType}],
- }, 'Leading space in contentType');
-
- expect_config(config.keysystem, [{
- videoCapabilities: [{contentType: config.videoType.replace( /^(.*?);(.*)/, "$1 ;$2")}],
- }], {
- videoCapabilities: [{contentType: config.videoType.replace( /^(.*?);(.*)/, "$1 ;$2")}],
- }, 'Space before ; in contentType');
-
-
- expect_config(config.keysystem, [{
- videoCapabilities: [{contentType: config.videoType + ' '}],
- }], {
- videoCapabilities: [{contentType: config.videoType + ' '}],
- }, 'Trailing space in contentType');
-
- expect_config(config.keysystem, [{
- videoCapabilities: [{contentType: config.videoType.replace( /^(.*?codecs=\")(.*)/, "$1 $2")}],
- }], {
- videoCapabilities: [{contentType: config.videoType.replace( /^(.*?codecs=\")(.*)/, "$1 $2")}],
- }, 'Space at start of codecs parameter');
-
- expect_config(config.keysystem, [{
- videoCapabilities: [{contentType: config.videoType.replace( /^(.*?codecs=\".*)\"/, "$1 \"")}],
- }], {
- videoCapabilities: [{contentType: config.videoType.replace( /^(.*?codecs=\".*)\"/, "$1 \"")}],
- }, 'Space at end of codecs parameter');
-
- // contentType is not case sensitive (except the codec names).
- expect_config(config.keysystem, [{
- videoCapabilities: [{contentType: 'V' + config.videoType.substr(1)}],
- }], {
- videoCapabilities: [{contentType: 'V' + config.videoType.substr(1)}],
- }, 'Video/' );
-
- expect_config(config.keysystem, [{
- videoCapabilities: [{contentType: config.videoType.replace( /^(.*?)c(odecs.*)/, "$1C$2")}],
- }], {
- videoCapabilities: [{contentType: config.videoType.replace( /^(.*?)c(odecs.*)/, "$1C$2")}],
- }, 'Codecs=');
-
- var t = config.videoType.match(/(.*?)(;.*)/);
- expect_config(config.keysystem, [{
- videoCapabilities: [{contentType: t[1].toUpperCase() + t[2]}],
- }], {
- videoCapabilities: [{contentType: t[1].toUpperCase() + t[2]}],
- }, 'Upper case MIME type');
-
- t = config.videoType.match(/(.*?)codecs(.*)/);
- expect_config(config.keysystem, [{
- videoCapabilities: [{contentType: t[1] + 'CODECS' + t[2]}],
- }], {
- videoCapabilities: [{contentType: t[1] + 'CODECS' + t[2]}],
- }, 'CODECS=');
-
- // Unrecognized attributes are not allowed.
- expect_error(config.keysystem, [{
- videoCapabilities: [{contentType: 'video/webm; foo="bar"'}],
- }], 'NotSupportedError', 'Unrecognized foo with webm (%videocontenttype)');
-
- expect_error(config.keysystem, [{
- videoCapabilities: [{contentType: 'video/mp4; foo="bar"'}],
- }], 'NotSupportedError', 'Unrecognized foo with mp4 (%videocontenttype)');
-
- expect_error(config.keysystem, [{
- videoCapabilities: [{contentType: config.videoType + '; foo="bar"'}],
- }], 'NotSupportedError', 'Unrecognized foo with codecs (%videocontenttype)');
-
- // Invalid contentTypes.
- expect_error(config.keysystem, [{
- videoCapabilities: [{contentType: 'fake'}],
- }], 'NotSupportedError', 'contentType: %videocontenttype');
-
- expect_error(config.keysystem, [{
- audioCapabilities: [{contentType: 'audio/fake'}],
- }], 'NotSupportedError', 'contentType: %audiocontenttype');
-
- expect_error(config.keysystem, [{
- videoCapabilities: [{contentType: 'video/fake'}],
- }], 'NotSupportedError', 'contentType: %videocontenttype');
-
- // The actual codec names are case sensitive.
- t = config.videoType.match( /(.*?codecs=\")(.*?\")(.*)/ );
- if (t[2] !== t[2].toUpperCase()) {
- expect_error(config.keysystem, [{
- videoCapabilities: [{contentType: t[1] + t[2].toUpperCase() + t[3] }],
- }], 'NotSupportedError', 'contentType: %videocontenttype');
- }
-
- if (t[2] !== t[2].toLowerCase()) {
- expect_error(config.keysystem, [{
- videoCapabilities: [{contentType: t[1] + t[2].toLowerCase() + t[3] }],
- }], 'NotSupportedError', 'contentType: %videocontenttype');
- }
-
- // Extra comma is not allowed in codecs.
- expect_error(config.keysystem, [{
- videoCapabilities: [{contentType: t[1] + ',' + t[2] + t[3] }],
- }], 'NotSupportedError', 'contentType: %videocontenttype');
-}
diff --git a/testing/web-platform/tests/encrypted-media/scripts/reset-src-after-setmediakeys.js b/testing/web-platform/tests/encrypted-media/scripts/reset-src-after-setmediakeys.js
deleted file mode 100644
index acddd8dd5..000000000
--- a/testing/web-platform/tests/encrypted-media/scripts/reset-src-after-setmediakeys.js
+++ /dev/null
@@ -1,61 +0,0 @@
-function runTest(config)
-{
- async_test(function(test) {
- var mediaKeys;
- var mediaSource;
- var encryptedEventIndex = 0;
- var video = config.video;
- var keysystem = config.keysystem;
- var configuration = {
- initDataTypes: [config.initDataType],
- audioCapabilities: [{
- contentType: config.audioType
- }],
- videoCapabilities: [{
- contentType: config.videoType
- }],
- sessionTypes: ['temporary']
- };
-
- assert_not_equals(video, null);
-
- var onEncrypted = function(event) {
- ++encryptedEventIndex;
- assert_equals(video.mediaKeys, mediaKeys);
-
- // This event is fired once for the audio stream and once
- // for the video stream each time .src is set.
- if (encryptedEventIndex === 2) {
- // Finished first video; Create new media source and wait for two more encrypted events
- return testmediasource(config).then(function (source) {
- video.src = URL.createObjectURL(source);
- }).catch(function (error) {
- forceTestFailureFromPromise(test, error)
- });
- } else if (encryptedEventIndex === 4) {
- // Finished second video.
- test.done();
- }
- };
-
- // Create a MediaKeys object and assign it to video.
- return navigator.requestMediaKeySystemAccess(keysystem, [configuration]).then(test.step_func(function (access) {
- assert_equals(access.keySystem, keysystem);
- return access.createMediaKeys();
- })).then(test.step_func(function (result) {
- mediaKeys = result;
- assert_not_equals(mediaKeys, null);
- return video.setMediaKeys(mediaKeys);
- })).then(test.step_func(function () {
- assert_equals(video.mediaKeys, mediaKeys);
- return testmediasource(config);
- })).then(function (source) {
- waitForEventAndRunStep('encrypted', video, onEncrypted, test);
- mediaSource = source;
- video.src = URL.createObjectURL(mediaSource);
- }).catch(function (error) {
- forceTestFailureFromPromise(test, error);
- });
-
- }, 'Reset src after setMediaKeys().');
-}
diff --git a/testing/web-platform/tests/encrypted-media/scripts/setmediakeys-again-after-playback.js b/testing/web-platform/tests/encrypted-media/scripts/setmediakeys-again-after-playback.js
deleted file mode 100644
index 772bfcaa8..000000000
--- a/testing/web-platform/tests/encrypted-media/scripts/setmediakeys-again-after-playback.js
+++ /dev/null
@@ -1,79 +0,0 @@
-function runTest(config, qualifier) {
- var testname = testnamePrefix(qualifier, config.keysystem)
- + ', setmediakeys again after playback';
-
- var configuration = getSimpleConfigurationForContent(config.content);
-
- if (config.initDataType && config.initData) {
- configuration.initDataTypes = [config.initDataType];
- }
-
- async_test(function(test) {
- var _video = config.video,
- _access,
- _mediaKeys,
- _mediaKeySession,
- _mediaSource;
-
- function onFailure(error) {
- forceTestFailureFromPromise(test, error);
- }
-
- function onMessage(event) {
- config.messagehandler(event.messageType, event.message).then( function(response) {
- _mediaKeySession.update(response).catch(onFailure).then(function() {
- _video.play();
- });
- });
- }
-
- function onEncrypted(event) {
- waitForEventAndRunStep('message', _mediaKeySession, onMessage, test);
- _mediaKeySession.generateRequest( config.initData ? config.initDataType : event.initDataType,
- config.initData || event.initData )
- .catch(onFailure);
- }
-
- function playVideo()
- {
- return new Promise(function(resolve) {
- _mediaKeySession = _mediaKeys.createSession('temporary');
- waitForEventAndRunStep('encrypted', _video, onEncrypted, test);
- _video.src = URL.createObjectURL(_mediaSource);
- resolve('success');
- });
- }
-
- navigator.requestMediaKeySystemAccess(config.keysystem, [configuration]).then(function(access) {
- _access = access;
- return _access.createMediaKeys();
- }).then(function(result) {
- _mediaKeys = result;
- return _video.setMediaKeys(_mediaKeys);
- }).then(function() {
- return config.servercertificate ? _mediaKeys.setServerCertificate( config.servercertificate ) : true;
- }).then(function( success ) {
- return testmediasource(config);
- }).then(function(source) {
- _mediaSource = source;
- return playVideo();
- }).then(function(results) {
- return _access.createMediaKeys();
- }).then(function(result) {
- _mediaKeys = result;
- return waitForEvent('playing', _video);
- }).then(test.step_func(function(result) {
- assert_false(_video.ended);
- return _video.setMediaKeys(_mediaKeys);
- })).then(function() {
- // Able to change MediaKeys while playing.
- // This is not required to fail.
- _video.src='';
- test.done();
- }, test.step_func(function(error) {
- assert_in_array(error.name, ['InvalidStateError','NotSupportedError']);
- _video.src='';
- test.done();
- })).catch(onFailure);
- }, testname);
-} \ No newline at end of file
diff --git a/testing/web-platform/tests/encrypted-media/scripts/setmediakeys-again-after-resetting-src.js b/testing/web-platform/tests/encrypted-media/scripts/setmediakeys-again-after-resetting-src.js
deleted file mode 100644
index a87060098..000000000
--- a/testing/web-platform/tests/encrypted-media/scripts/setmediakeys-again-after-resetting-src.js
+++ /dev/null
@@ -1,79 +0,0 @@
-function runTest(config, qualifier) {
- var testname = testnamePrefix(qualifier, config.keysystem)
- + ', setmediakeys again after resetting src';
-
- var configuration = getSimpleConfigurationForContent(config.content);
-
- if (config.initDataType && config.initData) {
- configuration.initDataTypes = [config.initDataType];
- }
-
- async_test(function(test) {
- var _video = config.video,
- _access,
- _mediaKeys,
- _mediaKeySession,
- _mediaSource;
-
- function onFailure(error) {
- forceTestFailureFromPromise(test, error);
- }
-
- function onMessage(event) {
- config.messagehandler(event.messageType, event.message).then(function(response) {
- _mediaKeySession.update(response).catch(onFailure).then(function() {
- _video.play();
- });
- });
- }
-
- function onEncrypted(event) {
- waitForEventAndRunStep('message', _mediaKeySession, onMessage, test);
- _mediaKeySession.generateRequest( config.initData ? config.initDataType : event.initDataType,
- config.initData || event.initData )
- .catch(onFailure);
- }
-
- function playVideoAndWaitForTimeupdate()
- {
- return new Promise(function(resolve) {
- testmediasource(config).then(function(source) {
- _mediaKeySession = _mediaKeys.createSession('temporary');
- _video.src = URL.createObjectURL(source);
- });
- _video.addEventListener('timeupdate', function listener(event) {
- if (event.target.currentTime < (config.duration || 1))
- return;
- _video.removeEventListener('timeupdate', listener);
- resolve('success');
- });
- });
- }
-
- waitForEventAndRunStep('encrypted', _video, onEncrypted, test);
- navigator.requestMediaKeySystemAccess(config.keysystem, [configuration]).then(function(access) {
- _access = access;
- return _access.createMediaKeys();
- }).then(function(result) {
- _mediaKeys = result;
- return _video.setMediaKeys(_mediaKeys);
- }).then(function() {
- return config.servercertificate ? _mediaKeys.setServerCertificate( config.servercertificate ) : true;
- }).then(function( success ) {
- return playVideoAndWaitForTimeupdate();
- }).then(function(results) {
- return _access.createMediaKeys();
- }).then(function(result) {
- _mediaKeys = result;
- _video.src = '';
- return _video.setMediaKeys(_mediaKeys);
- }).then(function() {
- return config.servercertificate ? _mediaKeys.setServerCertificate( config.servercertificate ) : true;
- }).then(function( success ) {
- return playVideoAndWaitForTimeupdate();
- }).then(function() {
- _video.src = '';
- test.done();
- }).catch(onFailure);
- }, testname);
-} \ No newline at end of file
diff --git a/testing/web-platform/tests/encrypted-media/scripts/setmediakeys-at-same-time.js b/testing/web-platform/tests/encrypted-media/scripts/setmediakeys-at-same-time.js
deleted file mode 100644
index 6d67d95b1..000000000
--- a/testing/web-platform/tests/encrypted-media/scripts/setmediakeys-at-same-time.js
+++ /dev/null
@@ -1,59 +0,0 @@
-function runTest(config, qualifier) {
- var testname = testnamePrefix(qualifier, config.keysystem)
- + ', setmediakeys at same time';
-
- var configuration = getSimpleConfigurationForContent(config.content);
-
- async_test(function(test) {
- var _video = config.video,
- _access,
- _mediaKeys1,
- _mediaKeys2,
- _mediaKeys3,
- _mediaKeys4,
- _mediaKeys5;
-
- // Test MediaKeys assignment.
- assert_equals(_video.mediaKeys, null);
- assert_equals(typeof _video.setMediaKeys, 'function');
-
- function onFailure(error) {
- forceTestFailureFromPromise(test, error);
- }
-
- function setMediaKeys(mediaKeys) {
- return _video.setMediaKeys(mediaKeys)
- .then(function() {return 1}, function() {return 0})
- }
-
- navigator.requestMediaKeySystemAccess(config.keysystem, [configuration]).then(function(access) {
- _access = access;
- return _access.createMediaKeys();
- }).then(function(result) {
- _mediaKeys1 = result;
- return _access.createMediaKeys();
- }).then(function(result) {
- _mediaKeys2 = result;
- return _access.createMediaKeys();
- }).then(function(result) {
- _mediaKeys3 = result;
- return _access.createMediaKeys();
- }).then(function(result) {
- _mediaKeys4 = result;
- return _access.createMediaKeys();
- }).then(function(result) {
- _mediaKeys5 = result;
- return Promise.all([
- setMediaKeys(_mediaKeys1),
- setMediaKeys(_mediaKeys2),
- setMediaKeys(_mediaKeys3),
- setMediaKeys(_mediaKeys4),
- setMediaKeys(_mediaKeys5)
- ]);
- }).then(function(results) {
- var sum = results.reduce((a, b) => a + b, 0);
- assert_in_array(sum,[1,5]);
- test.done();
- }).catch(onFailure);
- }, testname);
-} \ No newline at end of file
diff --git a/testing/web-platform/tests/encrypted-media/scripts/setmediakeys-multiple-times-with-different-mediakeys.js b/testing/web-platform/tests/encrypted-media/scripts/setmediakeys-multiple-times-with-different-mediakeys.js
deleted file mode 100644
index 6f0bd93f2..000000000
--- a/testing/web-platform/tests/encrypted-media/scripts/setmediakeys-multiple-times-with-different-mediakeys.js
+++ /dev/null
@@ -1,86 +0,0 @@
-function runTest(config, qualifier) {
- var testname = testnamePrefix( qualifier, config.keysystem )
- + ', setmediakeys multiple times with different mediakeys';
-
- var configuration = getSimpleConfigurationForContent( config.content );
-
- async_test (function (test) {
- var _video = config.video,
- _access,
- _mediaKeys1,
- _mediaKeys2,
- fail;
-
- // Test MediaKeys assignment.
- assert_equals(_video.mediaKeys, null);
- assert_equals(typeof _video.setMediaKeys, 'function');
-
- function onFailure(error) {
- forceTestFailureFromPromise(test, error);
- }
-
- navigator.requestMediaKeySystemAccess(config.keysystem, [configuration]).then(function(access) {
- _access = access;
- return _access.createMediaKeys();
- }).then(test.step_func(function(result) {
- _mediaKeys1 = result;
- assert_not_equals(_mediaKeys1, null);
- // Create a second mediaKeys.
- return _access.createMediaKeys();
- })).then(test.step_func(function(result) {
- _mediaKeys2 = result;
- assert_not_equals(_mediaKeys2, null);
- // Set _mediaKeys1 on video.
- return _video.setMediaKeys(_mediaKeys1);
- })).then(test.step_func(function() {
- assert_equals(_video.mediaKeys, _mediaKeys1);
- // Set _mediaKeys2 on video (switching MediaKeys).
- return _video.setMediaKeys(_mediaKeys2);
- })).then(test.step_func(function() {
- assert_equals(_video.mediaKeys, _mediaKeys2);
- // Clear mediaKeys from video.
- return _video.setMediaKeys(null);
- })).then(test.step_func(function() {
- assert_equals(_video.mediaKeys, null);
- // Set _mediaKeys1 on video again.
- return _video.setMediaKeys(_mediaKeys1);
- })).then(test.step_func(function() {
- assert_equals(_video.mediaKeys, _mediaKeys1);
- return testmediasource(config);
- })).then(function(source) {
- // Set src attribute on Video Element
- _video.src = URL.createObjectURL(source);
- // Set mediaKeys2 on video element (switching MediaKeys) need not
- // fail after src attribute is set.
- return _video.setMediaKeys(_mediaKeys2);
- })).then(test.step_func(function() {
- // Switching setMediaKeys after setting src attribute on video element
- // is not required to fail.
- assert_equals(_video2.mediaKeys, _mediaKeys2);
- fail = false;
- return Promise.resolve();
- }, test.step_func(function(error) {
- fail = true;
- assert_equals(_video.mediaKeys, _mediaKeys1);
- assert_in_array(error.name, ['InvalidStateError','NotSupportedError']);
- assert_not_equals(error.message, '');
- // Return something so the promise resolves properly.
- return Promise.resolve();
- })).then(function() {
- // Set null mediaKeys on video (clearing MediaKeys) not
- // supported after src attribute is set.
- return _video.setMediaKeys(null);
- }).then(test.step_func(function() {
- assert_unreached('Clearing mediaKeys after setting src should have failed.');
- }), test.step_func(function(error) {
- if(fail) {
- assert_equals(_video.mediaKeys, _mediaKeys1);
- } else {
- assert_equals(_video.mediaKeys, _mediaKeys2);
- }
- assert_is_array(error.name, ['InvalidStateError','ReferenceError']);
- assert_not_equals(error.message, '');
- test.done();
- })).catch(onFailure);
- }, testname);
-} \ No newline at end of file
diff --git a/testing/web-platform/tests/encrypted-media/scripts/setmediakeys-multiple-times-with-the-same-mediakeys.js b/testing/web-platform/tests/encrypted-media/scripts/setmediakeys-multiple-times-with-the-same-mediakeys.js
deleted file mode 100644
index f6af8267f..000000000
--- a/testing/web-platform/tests/encrypted-media/scripts/setmediakeys-multiple-times-with-the-same-mediakeys.js
+++ /dev/null
@@ -1,46 +0,0 @@
-function runTest(config, qualifier) {
- var testname = testnamePrefix( qualifier, config.keysystem )
- + ', setmediakeys multiple times with the same mediakeys';
-
- var configuration = getSimpleConfigurationForContent( config.content );
-
- if ( config.initDataType && config.initData ) {
- configuration.initDataTypes = [ config.initDataType ];
- }
-
- async_test (function (test) {
- var _video = config.video,
- _mediaKeys;
-
- // Test MediaKeys assignment.
- assert_equals(_video.mediaKeys, null);
- assert_equals(typeof _video.setMediaKeys, 'function');
-
- function onFailure(error) {
- forceTestFailureFromPromise(test, error);
- }
-
- navigator.requestMediaKeySystemAccess(config.keysystem, [configuration]).then(function(access) {
- return access.createMediaKeys();
- }).then(function(result) {
- _mediaKeys = result;
- // Set mediaKeys for first time on video should work.
- return _video.setMediaKeys(_mediaKeys);
- }).then(function(result) {
- assert_equals(_video.mediaKeys, _mediaKeys);
- // Set mediaKeys on video again should return a resolved promise.
- return _video.setMediaKeys(_mediaKeys);
- }).then(function (result) {
- assert_equals(_video.mediaKeys, _mediaKeys);
- return testmediasource(config);
- }).then(function(source) {
- // Set src attribute on Video Element
- _video.src = URL.createObjectURL(source);
- // Set mediaKeys again on video should still return a resolved promise.
- return _video.setMediaKeys(_mediaKeys);
- }).then(function() {
- assert_equals(_video.mediaKeys, _mediaKeys);
- test.done();
- }).catch(onFailure);
- }, testname);
-} \ No newline at end of file
diff --git a/testing/web-platform/tests/encrypted-media/scripts/setmediakeys-to-multiple-video-elements.js b/testing/web-platform/tests/encrypted-media/scripts/setmediakeys-to-multiple-video-elements.js
deleted file mode 100644
index d98f33f0c..000000000
--- a/testing/web-platform/tests/encrypted-media/scripts/setmediakeys-to-multiple-video-elements.js
+++ /dev/null
@@ -1,54 +0,0 @@
-function runTest(config, qualifier) {
- var testname = testnamePrefix(qualifier, config.keysystem)
- + ', setMediaKeys to multiple video elements';
-
- var configuration = getSimpleConfigurationForContent(config.content);
-
- if ( config.initDataType && config.initData ) {
- configuration.initDataTypes = [ config.initDataType ];
- }
-
- async_test (function (test) {
- var _video1 = config.video1,
- _video2 = config.video2,
- _mediaKeys;
-
- function onFailure(error) {
- forceTestFailureFromPromise(test, error);
- }
-
- navigator.requestMediaKeySystemAccess(config.keysystem, [configuration]).then(function(access) {
- assert_equals(access.keySystem, config.keysystem)
- return access.createMediaKeys();
- }).then(function(result) {
- _mediaKeys = result;
- assert_not_equals(_mediaKeys, null);
- assert_equals(typeof _mediaKeys.createSession, 'function');
- return _video1.setMediaKeys(_mediaKeys);
- }).then(function(result) {
- assert_not_equals(_video1.mediaKeys, null);
- assert_true(_video1.mediaKeys === _mediaKeys);
- // The specification allows this to fail, but it is not required to fail.
- return _video2.setMediaKeys(_mediaKeys);
- }).then(function(result) {
- // Second setMediaKeys is not required to fail.
- assert_true(_video2.mediaKeys === _mediaKeys);
- return Promise.resolve();
- }, function(error) {
- assert_equals(error.name, 'QuotaExceededError');
- assert_not_equals(error.message, '');
- // Return something so the promise resolves properly.
- return Promise.resolve();
- }).then(function() {
- // Now clear it from video1.
- return _video1.setMediaKeys(null);
- }).then(function() {
- // Should be assignable to video2.
- return _video2.setMediaKeys(_mediaKeys);
- }).then(function(result) {
- assert_not_equals(_video2.mediaKeys, null);
- assert_true(_video2.mediaKeys === _mediaKeys);
- test.done();
- }).catch(onFailure);
- }, testname);
-} \ No newline at end of file
diff --git a/testing/web-platform/tests/encrypted-media/scripts/setmediakeys.js b/testing/web-platform/tests/encrypted-media/scripts/setmediakeys.js
deleted file mode 100644
index 34b124e31..000000000
--- a/testing/web-platform/tests/encrypted-media/scripts/setmediakeys.js
+++ /dev/null
@@ -1,49 +0,0 @@
-function runTest(config, qualifier) {
- var testname = testnamePrefix( qualifier, config.keysystem )
- + ', setMediaKeys';
-
- var configuration = getSimpleConfigurationForContent( config.content );
-
- if ( config.initDataType && config.initData ) {
- configuration.initDataTypes = [ config.initDataType ];
- }
-
- async_test (function (test) {
- var _video = config.video,
- _mediaKeys;
-
- // Test MediaKeys assignment.
- assert_equals(_video.mediaKeys, null);
- assert_equals(typeof _video.setMediaKeys, 'function');
-
- function onFailure(error) {
- forceTestFailureFromPromise(test, error);
- }
-
- // Try setting mediaKeys to null.
- _video.setMediaKeys(null).then(function(result) {
- assert_equals(_video.mediaKeys, null);
-
- // setMediaKeys should fail when setting to the wrong type of object - Date.
- return _video.setMediaKeys(new Date());
- }).then(function (result) {
- assert_unreached('setMediaKeys should fail when setting to wrong kind of object (Date)');
- }, function(error) {
- // The error should be TypeError.
- assert_equals(error.name, 'setMediaKeys should return a TypeError when setting to wrong kind of object (Date)');
- return navigator.requestMediaKeySystemAccess(config.keysystem, [configuration]);
- }).then(function(access) {
- assert_equals(access.keySystem, config.keysystem)
- return access.createMediaKeys();
- }).then(function(result) {
- _mediaKeys = result;
- assert_not_equals(_mediaKeys, null);
- assert_equals(typeof _mediaKeys.createSession, 'function');
- return _video.setMediaKeys(_mediaKeys);
- }).then(function(result) {
- assert_not_equals(_video.mediaKeys, null);
- assert_equals(_video.mediaKeys, _mediaKeys);
- test.done();
- }).catch(onFailure);
- }, testname);
-}
diff --git a/testing/web-platform/tests/encrypted-media/scripts/syntax-mediakeys.js b/testing/web-platform/tests/encrypted-media/scripts/syntax-mediakeys.js
deleted file mode 100644
index 4ec6551e8..000000000
--- a/testing/web-platform/tests/encrypted-media/scripts/syntax-mediakeys.js
+++ /dev/null
@@ -1,184 +0,0 @@
-function runTest(config) {
- var keysystem = config.keysystem;
- var testname = testnamePrefix(null, config.keysystem);
- var initDataType = config.initDataType;
- var configuration = {
- initDataTypes: [config.initDataType],
- audioCapabilities: [{contentType: config.audioType}],
- videoCapabilities: [{contentType: config.videoType}],
- sessionTypes: ['temporary']
- };
-
- function createMediaKeysAttributeTest() {
- return new Promise(function (resolve, reject) {
- var access;
- isInitDataTypeSupported(keysystem, initDataType).then(function (isTypeSupported) {
- assert_equals(typeof navigator.requestMediaKeySystemAccess, 'function');
- assert_true(isTypeSupported, "initDataType should be supported");
- return navigator.requestMediaKeySystemAccess(keysystem, [configuration]);
- }).then(function (result) {
- access = result;
- assert_equals(access.keySystem, keysystem);
- return access.createMediaKeys();
- }).then(function (mediaKeys) {
- assert_not_equals(mediaKeys, null);
- assert_equals(typeof mediaKeys, 'object');
- assert_equals(typeof mediaKeys.createSession, 'function');
- assert_equals(typeof mediaKeys.setServerCertificate, 'function');
-
- // Test creation of a second MediaKeys.
- // The extra parameter is ignored.
- return access.createMediaKeys('extra');
- }).then(function (mediaKeys) {
- assert_not_equals(mediaKeys, null);
- assert_equals(typeof mediaKeys, 'object');
- assert_equals(typeof mediaKeys.createSession, 'function');
- assert_equals(typeof mediaKeys.setServerCertificate, 'function');
- resolve();
- }).catch(function (error) {
- reject(error);
- });
- })
- }
-
- promise_test(function() {
- return createMediaKeysAttributeTest();
- }, testname + ' test MediaKeys attribute syntax');
-
- var kSetServerCertificateExceptionsTestCases = [
- // Too few parameters.
- {
- exception: 'TypeError',
- func: function (mk) {
- return mk.setServerCertificate();
- }
- },
- // Invalid parameters.
- {
- exception: 'TypeError',
- func: function (mk) {
- return mk.setServerCertificate('');
- }
- },
- {
- exception: 'TypeError',
- func: function (mk) {
- return mk.setServerCertificate(null);
- }
- },
- {
- exception: 'TypeError',
- func: function (mk) {
- return mk.setServerCertificate(undefined);
- }
- },
- {
- exception: 'TypeError',
- func: function (mk) {
- return mk.setServerCertificate(1);
- }
- },
- // Empty array.
- {
- exception: 'TypeError',
- func: function (mk) {
- return mk.setServerCertificate(new Uint8Array(0));
- }
- }
- ];
-
-
- function setServerCertificateTestExceptions() {
- return new Promise(function(resolve, reject) {
- isInitDataTypeSupported(keysystem, initDataType).then(function (isTypeSupported) {
- assert_equals(typeof navigator.requestMediaKeySystemAccess, 'function');
- assert_true(isTypeSupported, "initDataType not supported");
- return navigator.requestMediaKeySystemAccess(keysystem, [configuration]);
- }).then(function (access) {
- return access.createMediaKeys();
- }).then(function (mediaKeys) {
- var promises = kSetServerCertificateExceptionsTestCases.map(function (testCase) {
- return test_exception(testCase, mediaKeys);
- });
- assert_not_equals(promises.length, 0);
- return Promise.all(promises);
- }).then(function () {
- resolve();
- }).catch(function (error) {
- reject(error);
- });
- })
- }
- promise_test(function() {
- return setServerCertificateTestExceptions();
- }, testname + ' test MediaKeys setServerCertificate() exceptions.');
-
- // All calls to |func| in this group resolve. setServerCertificate with these cert may either resolve with true
- // for clearkey or throw a DOMException.
- var kSetServerCertificateTestCases = [
- {
- // Pass in ArrayBufferView
- func: function (mk) {
- var cert = new Uint8Array(200);
- assert_true(ArrayBuffer.isView(cert));
-
- return new Promise(function (resolve, reject) {
- mk.setServerCertificate(cert).then(function (value) {
- resolve(value);
- }).catch(function (error) {
- if (Object.prototype.toString.call(error) === "[object DOMException]") {
- resolve(false);
- }
- });
- })
- },
- expected: false
- },
- {
- // Pass in ArrayBuffer.
- func: function (mk) {
- var cert = new ArrayBuffer(200);
- assert_false(ArrayBuffer.isView(cert));
- return new Promise(function (resolve) {
- mk.setServerCertificate(cert).then(function (resolveValue) {
- resolve(resolveValue);
- }).catch(function (error) {
- if (Object.prototype.toString.call(error) === "[object DOMException]") {
- resolve(false);
- }
- });
- })
- },
- expected: false
- }
- ];
- function setServerCertificateTest(){
- return new Promise(function(resolve, reject){
- var expected_result;
- isInitDataTypeSupported(keysystem, initDataType).then(function (isTypeSupported) {
- assert_equals(typeof navigator.requestMediaKeySystemAccess, 'function');
- assert_true(isTypeSupported, "initDataType not supported");
- return navigator.requestMediaKeySystemAccess(keysystem, [configuration]);
- }).then(function (access) {
- return access.createMediaKeys();
- }).then(function (mediaKeys) {
- var promises = kSetServerCertificateTestCases.map(function (testCase) {
- return testCase.func.call(null, mediaKeys);
- });
- expected_result = kSetServerCertificateTestCases.map(function (testCase) {
- return testCase.expected;
- });
- assert_not_equals(promises.length, 0);
- return Promise.all(promises);
- }).then(function (result) {
- assert_array_equals(result, expected_result);
- resolve();
- }).catch(function (error) {
- reject(error);
- });
- })
- }
- promise_test(function() {
- return setServerCertificateTest();
- }, testname + ' test MediaKeys setServerCertificate() syntax with non-empty certificate.');
-}
diff --git a/testing/web-platform/tests/encrypted-media/scripts/syntax-mediakeysession.js b/testing/web-platform/tests/encrypted-media/scripts/syntax-mediakeysession.js
deleted file mode 100644
index 3663a7b93..000000000
--- a/testing/web-platform/tests/encrypted-media/scripts/syntax-mediakeysession.js
+++ /dev/null
@@ -1,445 +0,0 @@
-function runTest(config) {
- var keysystem = config.keysystem;
- var testname = testnamePrefix(null, config.keysystem);
- var initDataType = config.initDataType;
- var initData = config.initData;
- var configuration = {
- initDataTypes: [config.initDataType],
- audioCapabilities: [{contentType: config.audioType}],
- videoCapabilities: [{contentType: config.videoType}],
- sessionTypes: ['temporary']
- };
-
- var kTypeSpecificGenerateRequestExceptionsTestCases = [
- // Tests in this set use a shortened parameter name due to
- // format_value() only returning the first 60 characters as the
- // result. With a longer name the first 60 characters is not
- // enough to determine which test failed. Even with the
- // shortened name, the error message for the last couple of
- // tests is the same.
-
- // Too few parameters.
- {
- exception: 'TypeError',
- func: function (mk1, type) {
- return mk1.createSession().generateRequest(type);
- }
- },
- // Invalid parameters.
- {
- exception: 'TypeError',
- func: function (mk2, type) {
- return mk2.createSession().generateRequest(type, '');
- }
- },
- {
- exception: 'TypeError',
- func: function (mk3, type) {
- return mk3.createSession().generateRequest(type, null);
- }
- },
- {
- exception: 'TypeError',
- func: function (mk4, type) {
- return mk4.createSession().generateRequest(type, undefined);
- }
- },
- {
- exception: 'TypeError',
- func: function (mk5, type) {
- return mk5.createSession().generateRequest(type, 1);
- }
- },
- // (new Uint8Array(0)) returns empty array. So 'TypeError' should
- // be returned.
- {
- exception: 'TypeError',
- func: function (mk6, type) {
- return mk6.createSession().generateRequest(type, new Uint8Array(0));
- }
- }
- ];
- function generateRequestTestExceptions(){
- return new Promise(function(resolve, reject){
- isInitDataTypeSupported(keysystem, initDataType).then(function (isTypeSupported) {
- assert_true(isTypeSupported, "initDataType not supported");
- return navigator.requestMediaKeySystemAccess(keysystem, [configuration]);
- }).then(function (access) {
- return access.createMediaKeys();
- }).then(function (mediaKeys) {
- var mp4SessionPromises = kTypeSpecificGenerateRequestExceptionsTestCases.map(function (testCase) {
- return test_exception(testCase, mediaKeys, initDataType, initData);
- });
- assert_not_equals(mp4SessionPromises.length, 0);
- return Promise.all(mp4SessionPromises);
- }).then(function (result) {
- resolve();
- }).catch(function (error) {
- reject(error);
- });
- })
- }
- promise_test(function() {
- return generateRequestTestExceptions();
- }, testname + ' test MediaKeySession generateRequest() exceptions.');
-
- var kLoadExceptionsTestCases = [
- // Too few parameters.
- {
- exception: 'TypeError',
- func: function (mk1) {
- return mk1.createSession('temporary').load();
- }
- },
- {
- exception: 'TypeError',
- func: function (mk3) {
- return mk3.createSession('temporary').load('');
- }
- },
- {
- exception: 'TypeError',
- func: function (mk4) {
- return mk4.createSession('temporary').load(1);
- }
- },
- {
- exception: 'TypeError',
- func: function (mk5) {
- return mk5.createSession('temporary').load('!@#$%^&*()');
- }
- },
- {
- exception: 'TypeError',
- func: function (mk6) {
- return mk6.createSession('temporary').load('1234');
- }
- }
- ];
- function loadTestExceptions(){
- return new Promise(function(resolve, reject){
- isInitDataTypeSupported(keysystem, initDataType).then(function (isTypeSupported) {
- assert_true(isTypeSupported, "initDataType not supported");
- return navigator.requestMediaKeySystemAccess(keysystem, [configuration]);
- }).then(function (access) {
- return access.createMediaKeys();
- }).then(function (mediaKeys) {
- var sessionPromises = kLoadExceptionsTestCases.map(function (testCase) {
- return test_exception(testCase, mediaKeys);
- });
- assert_not_equals(sessionPromises.length, 0);
- return Promise.all(sessionPromises);
- }).then(function () {
- resolve();
- }).catch(function (error) {
- reject(error);
- });
- })
- }
- promise_test(function() {
- return loadTestExceptions();
- }, testname + ' test MediaKeySession load() exceptions.');
-
- // All calls to |func| in this group are supposed to succeed.
- // However, the spec notes that some things are optional for
- // Clear Key. In particular, support for persistent sessions
- // is optional. Since some implementations won't support some
- // features, a NotSupportedError is treated as a success
- // if |isNotSupportedAllowed| is true.
- var kCreateSessionTestCases = [
- // Use the default sessionType.
- {
- func: function(mk) { return mk.createSession(); },
- isNotSupportedAllowed: false
- },
- // Try variations of sessionType.
- {
- func: function(mk) { return mk.createSession('temporary'); },
- isNotSupportedAllowed: false
- },
- {
- func: function(mk) { return mk.createSession(undefined); },
- isNotSupportedAllowed: false
- },
- {
- // Since this is optional, some Clear Key implementations
- // will succeed, others will return a "NotSupportedError".
- // Both are allowed results.
- func: function(mk) { return mk.createSession('persistent-license'); },
- isNotSupportedAllowed: true
- },
- // Try additional parameter, which should be ignored.
- {
- func: function(mk) { return mk.createSession('temporary', 'extra'); },
- isNotSupportedAllowed: false
- }
- ];
- // This function checks that calling generateRequest() works for
- // various sessions. |testCase.func| creates a MediaKeySession
- // object, and then generateRequest() is called on that object. It
- // allows for an NotSupportedError to be generated and treated as a
- // success, if allowed. See comment above kCreateSessionTestCases.
- function test_generateRequest(testCase, mediaKeys, type, initData) {
- var mediaKeySession;
- try {
- mediaKeySession = testCase.func.call(null, mediaKeys);
- } catch (e) {
- assert_true(testCase.isNotSupportedAllowed);
- assert_equals(e.name, 'NotSupportedError');
- return Promise.resolve('not supported');
- }
- return mediaKeySession.generateRequest(type, initData);
- }
- function generateRequestForVariousSessions(){
- return new Promise(function(resolve, reject){
- isInitDataTypeSupported(keysystem, initDataType).then(function (isTypeSupported) {
- assert_true(isTypeSupported, "initDataType should be supported");
- return navigator.requestMediaKeySystemAccess(keysystem, [configuration]);
- }).then(function (access) {
- return access.createMediaKeys();
- }).then(function (mediaKeys) {
- var mp4SessionPromises = kCreateSessionTestCases.map(function (testCase) {
- return test_generateRequest(testCase, mediaKeys, initDataType, initData);
- });
- assert_not_equals(mp4SessionPromises.length, 0);
- return Promise.all(mp4SessionPromises);
- }).then(function () {
- resolve();
- }).catch(function (error) {
- reject(error);
- });
- })
- }
- promise_test(function() {
- return generateRequestForVariousSessions();
- }, testname + ' test if MediaKeySession generateRequest() resolves for various sessions');
-
- var kUpdateSessionExceptionsTestCases = [
- // Tests in this set use a shortened parameter name due to
- // format_value() only returning the first 60 characters as the
- // result. With a longer name (mediaKeySession) the first 60
- // characters is not enough to determine which test failed.
-
- // Too few parameters.
- {
- exception: 'TypeError',
- func: function (s) {
- return s.update();
- }
- },
- // Invalid parameters.
- {
- exception: 'TypeError',
- func: function (s) {
- return s.update('');
- }
- },
- {
- exception: 'TypeError',
- func: function (s) {
- return s.update(null);
- }
- },
- {
- exception: 'TypeError',
- func: function (s) {
- return s.update(undefined);
- }
- },
- {
- exception: 'TypeError',
- func: function (s) {
- return s.update(1);
- }
- },
- // (new Uint8Array(0)) returns empty array. So 'TypeError' should
- // be returned.
- {
- exception: 'TypeError',
- func: function (s) {
- return s.update(new Uint8Array(0));
- }
- }
- ];
-
- function updateTestExceptions(){
- return new Promise(function(resolve, reject){
- isInitDataTypeSupported(keysystem, initDataType).then(function (isTypeSupported) {
- assert_true(isTypeSupported, "initDataType not supported");
- return navigator.requestMediaKeySystemAccess(keysystem, [configuration]);
- }).then(function (access) {
- return access.createMediaKeys();
- }).then(function (mediaKeys) {
- var mp4SessionPromises = kUpdateSessionExceptionsTestCases.map(function (testCase) {
- var mediaKeySession = mediaKeys.createSession();
- return mediaKeySession.generateRequest(initDataType, initData).then(function (result) {
- return test_exception(testCase, mediaKeySession);
- });
- });
- assert_not_equals(mp4SessionPromises.length, 0);
- return Promise.all(mp4SessionPromises);
- }).then(function () {
- resolve();
- }).catch(function (error) {
- reject(error);
- });
- })
- }
- promise_test(function() {
- return updateTestExceptions();
- }, testname + ' test MediaKeySession update() exceptions.');
-
- function create_close_exception_test(mediaKeys) {
- var mediaKeySession = mediaKeys.createSession();
- return mediaKeySession.close().then(function (result) {
- assert_unreached('close() should not succeed if session uninitialized');
- }).catch(function (error) {
- assert_equals(error.name, 'InvalidStateError');
- // Return something so the promise resolves.
- return Promise.resolve();
- });
- }
- function closeTestExceptions(){
- return new Promise(function(resolve, reject){
- isInitDataTypeSupported(keysystem, initDataType).then(function (isTypeSupported) {
- assert_true(isTypeSupported, "initDataType not supported");
- return navigator.requestMediaKeySystemAccess(keysystem, [configuration]);
- }).then(function (access) {
- return access.createMediaKeys();
- }).then(function (mediaKeys) {
- return create_close_exception_test(mediaKeys);
- }).then(function () {
- resolve();
- }).catch(function (error) {
- reject(error);
- });
- });
- }
- promise_test(function() {
- return closeTestExceptions();
- }, testname + ' test MediaKeySession close() exceptions.');
-
- function create_remove_exception_test(mediaKeys, type, initData) {
- // remove() on an uninitialized session should fail.
- var mediaKeySession = mediaKeys.createSession('temporary');
- return mediaKeySession.remove().then(function (result) {
- assert_unreached('remove() should not succeed if session uninitialized');
- }, function (error) {
- assert_equals(error.name, 'InvalidStateError');
- });
- }
- function removeTestException(){
- return new Promise(function(resolve, reject){
- isInitDataTypeSupported(keysystem, initDataType).then(function (isTypeSupported) {
- assert_true(isTypeSupported, "initDataType not supported");
- return navigator.requestMediaKeySystemAccess(keysystem, [configuration]);
- }).then(function (access) {
- return access.createMediaKeys();
- }).then(function (mediaKeys) {
- return create_remove_exception_test(mediaKeys, initDataType, initData);
- }).then(function () {
- resolve();
- }).catch(function (error) {
- reject(error);
- });
- });
- }
- promise_test(function() {
- return removeTestException();
- }, testname + ' test MediaKeySession remove() exceptions.');
-
- // All calls to |func| in this group are supposed to succeed.
- // However, the spec notes that some things are optional for
- // Clear Key. In particular, support for persistent sessions
- // is optional. Since some implementations won't support some
- // features, a NotSupportedError is treated as a success
- // if |isNotSupportedAllowed| is true.
- var kCreateSessionTestCases = [
- // Use the default sessionType.
- {
- func: function (mk) {
- return mk.createSession();
- },
- isNotSupportedAllowed: false
- },
- // Try variations of sessionType.
- {
- func: function (mk) {
- return mk.createSession('temporary');
- },
- isNotSupportedAllowed: false
- },
- {
- func: function (mk) {
- return mk.createSession(undefined);
- },
- isNotSupportedAllowed: false
- },
- {
- // Since this is optional, some Clear Key implementations
- // will succeed, others will return a "NotSupportedError".
- // Both are allowed results.
- func: function (mk) {
- return mk.createSession('persistent-license');
- },
- isNotSupportedAllowed: true
- },
- // Try additional parameter, which should be ignored.
- {
- func: function (mk) {
- return mk.createSession('temporary', 'extra');
- },
- isNotSupportedAllowed: false
- }
- ];
-
- // This function checks that calling |testCase.func| creates a
- // MediaKeySession object with some default values. It also
- // allows for an NotSupportedError to be generated and treated as a
- // success, if allowed. See comment above kCreateSessionTestCases.
- function test_createSession(testCase, mediaKeys) {
- var mediaKeySession;
- try {
- mediaKeySession = testCase.func.call(null, mediaKeys);
- } catch (e) {
- assert_true(testCase.isNotSupportedAllowed);
- return;
- }
- assert_equals(typeof mediaKeySession, 'object');
- assert_equals(typeof mediaKeySession.addEventListener, 'function');
- assert_equals(typeof mediaKeySession.sessionId, 'string');
- assert_equals(typeof mediaKeySession.expiration, 'number');
- assert_equals(typeof mediaKeySession.closed, 'object');
- assert_equals(typeof mediaKeySession.keyStatuses, 'object');
- assert_equals(typeof mediaKeySession.onkeystatuseschange, 'object');
- assert_equals(typeof mediaKeySession.onmessage, 'object');
- assert_equals(typeof mediaKeySession.generateRequest, 'function');
- assert_equals(typeof mediaKeySession.load, 'function');
- assert_equals(typeof mediaKeySession.update, 'function');
- assert_equals(typeof mediaKeySession.close, 'function');
- assert_equals(typeof mediaKeySession.remove, 'function');
- assert_equals(mediaKeySession.sessionId, '');
- }
- function createSessionTest(){
- return new Promise(function(resolve, reject){
- isInitDataTypeSupported(keysystem, initDataType).then(function (isTypeSupported) {
- assert_true(isTypeSupported, "initDataType not supported");
- return navigator.requestMediaKeySystemAccess(keysystem, [configuration]);
- }).then(function (access) {
- return access.createMediaKeys();
- }).then(function (mediaKeys) {
- kCreateSessionTestCases.map(function (testCase) {
- test_createSession(testCase, mediaKeys);
- });
- resolve();
- }).catch(function (error) {
- reject(error);
- });
- })
- }
- promise_test(function() {
- return createSessionTest();
- }, testname + ' test MediaKeySession attribute syntax.');
-
-
-}
diff --git a/testing/web-platform/tests/encrypted-media/scripts/syntax-mediakeysystemaccess.js b/testing/web-platform/tests/encrypted-media/scripts/syntax-mediakeysystemaccess.js
deleted file mode 100644
index 045494164..000000000
--- a/testing/web-platform/tests/encrypted-media/scripts/syntax-mediakeysystemaccess.js
+++ /dev/null
@@ -1,144 +0,0 @@
-function runTest(config) {
- var keysystem = config.keysystem;
- var testname = testnamePrefix(null, config.keysystem);
- var initDataType = config.initDataType;
- var configuration = {
- initDataTypes: [config.initDataType],
- audioCapabilities: [{contentType: config.audioType}],
- videoCapabilities: [{contentType: config.videoType}],
- sessionTypes: ['temporary']
- };
-
- var kRequestMediaKeySystemAccessExceptionsTestCases = [
- // Too few parameters.
- {
- exception: 'TypeError',
- func: function () {
- return navigator.requestMediaKeySystemAccess();
- }
- },
- {
- exception: 'TypeError',
- func: function () {
- return navigator.requestMediaKeySystemAccess(keysystem);
- }
- },
- // Invalid key systems. Note that JavaScript converts all these
- // values into strings by calling toString(), so they fail due
- // to the key system not being supported, not due to the type.
- {
- exception: 'NotSupportedError',
- func: function () {
- return navigator.requestMediaKeySystemAccess(null, [{}]);
- }
- },
- {
- exception: 'NotSupportedError',
- func: function () {
- return navigator.requestMediaKeySystemAccess(undefined, [{}]);
- }
- },
- {
- exception: 'NotSupportedError',
- func: function () {
- return navigator.requestMediaKeySystemAccess(1, [{}]);
- }
- },
- {
- exception: 'NotSupportedError',
- func: function () {
- return navigator.requestMediaKeySystemAccess(new Uint8Array(0), [{}]);
- }
- },
- {
- exception: 'NotSupportedError',
- func: function () {
- return navigator.requestMediaKeySystemAccess('', [{}]);
- }
- },
- {
- exception: 'NotSupportedError',
- func: function () {
- return navigator.requestMediaKeySystemAccess('unsupported', [{}]);
- }
- },
- // Non-ASCII names.
- {
- exception: 'NotSupportedError',
- func: function () {
- return navigator.requestMediaKeySystemAccess(keysystem + '\u263A', [{}]);
- }
- },
- // Empty sequence of MediaKeySystemConfiguration.
- {
- exception: 'NotSupportedError',
- func: function () {
- return navigator.requestMediaKeySystemAccess(keysystem, []);
- }
- },
- // Invalid sequences of MediaKeySystemConfigurations.
- {
- exception: 'NotSupportedError',
- func: function () {
- return navigator.requestMediaKeySystemAccess(keysystem, {});
- }
- },
- {
- exception: 'NotSupportedError',
- func: function () {
- return navigator.requestMediaKeySystemAccess(keysystem, "invalid");
- }
- },
- {
- exception: 'NotSupportedError',
- func: function () {
- return navigator.requestMediaKeySystemAccess(keysystem, [{}, 6]);
- }
- },
- {
- exception: 'NotSupportedError',
- func: function () {
- return navigator.requestMediaKeySystemAccess(keysystem, ["invalid", "upsupported"]);
- }
- }
- ];
-
- function requestMediaKeySystemAccessTestExceptions(){
- return new Promise(function(resolve, reject){
- var createPromises = kRequestMediaKeySystemAccessExceptionsTestCases.map(function (testCase) {
- return test_exception(testCase);
- });
- Promise.all(createPromises).then(function (result) {
- resolve();
- }).catch(function (error) {
- reject(error);
- });
- })
- }
- promise_test(function() {
- return requestMediaKeySystemAccessTestExceptions();
- }, testname + ' test requestMediaKeySystemAccess() exceptions.');
-
- function requestMediaKeySystemAccessTestAttributes(){
- return new Promise(function(resolve, reject){
- isInitDataTypeSupported(keysystem, initDataType).then(function (isTypeSupported) {
- assert_equals(typeof navigator.requestMediaKeySystemAccess, 'function');
- assert_true(isTypeSupported, "initDataType not supported");
- return navigator.requestMediaKeySystemAccess(keysystem, [configuration]);
- }).then(function (access) {
- assert_not_equals(access, null);
- assert_equals(typeof access, 'object');
- assert_equals(access.keySystem, keysystem);
- assert_equals(typeof access.getConfiguration, 'function');
- assert_equals(typeof access.createMediaKeys, 'function');
- resolve();
- }).catch(function(error){
- reject(error);
- })
- })
- }
- promise_test(function() {
- return requestMediaKeySystemAccessTestAttributes();
- }, testname + ' test MediaKeySystemAccess attribute syntax.');
-
-}
diff --git a/testing/web-platform/tests/encrypted-media/scripts/temporary-license-type.js b/testing/web-platform/tests/encrypted-media/scripts/temporary-license-type.js
deleted file mode 100644
index cb0b0e67f..000000000
--- a/testing/web-platform/tests/encrypted-media/scripts/temporary-license-type.js
+++ /dev/null
@@ -1,61 +0,0 @@
-function runTest(config,qualifier) {
-
- var testname = testnamePrefix(qualifier, config.keysystem) + ', cannot load persistent license into temporary session';
-
- var configuration = getSimpleConfigurationForContent(config.content);
-
- if (config.initDataType && config.initData) {
- configuration.initDataTypes = [config.initDataType];
- }
-
- async_test(function(test)
- {
- var initDataType;
- var initData;
- var mediaKeySession;
-
- function onFailure(error) {
- forceTestFailureFromPromise(test, error);
- }
-
- function processMessage(event)
- {
- assert_true(event instanceof window.MediaKeyMessageEvent);
- assert_equals(event.target, mediaKeySession);
- assert_equals(event.type, 'message');
- assert_in_array(event.messageType, ['license-request', 'individualization-request']);
-
- config.messagehandler(event.messageType, event.message).then( function(response) {
- mediaKeySession.update(response).then( test.step_func( function() {
- if ( event.messageType !== 'license-request' ) {
- return;
- }
- assert_unreached( "Update with incorrect license type should fail" )
- } ) ).catch( test.step_func( function( error ) {
- if ( event.messageType !== 'license-request' ) {
- forceTestFailureFromPromise(test, error);
- return;
- }
-
- assert_equals(error.name, 'TypeError' );
- test.done();
- } ) );
- }).catch(onFailure);
- }
-
- navigator.requestMediaKeySystemAccess(config.keysystem, [configuration]).then(function(access) {
- initDataType = access.getConfiguration().initDataTypes[0];
- if (config.initDataType && config.initData) {
- initData = config.initData;
- } else {
- initData = getInitData(config.content, initDataType);
- }
- return access.createMediaKeys();
- }).then(test.step_func(function(mediaKeys) {
- mediaKeySession = mediaKeys.createSession('temporary');
- waitForEventAndRunStep('message', mediaKeySession, test.step_func(processMessage), test);
- return mediaKeySession.generateRequest(initDataType, initData);
- })).catch(onFailure);
- }, testname );
-
-}
diff --git a/testing/web-platform/tests/encrypted-media/scripts/unique-origin.js b/testing/web-platform/tests/encrypted-media/scripts/unique-origin.js
deleted file mode 100644
index 523eb84a6..000000000
--- a/testing/web-platform/tests/encrypted-media/scripts/unique-origin.js
+++ /dev/null
@@ -1,64 +0,0 @@
-function runTest(config) {
- // When the sandbox attribute is present on an iframe, it will
- // treat the content as being from a unique origin. So try to
- // call createMediaKeys() inside an iframe and it should fail.
-
- function load_iframe(src, sandbox) {
- return new Promise(function (resolve) {
- var iframe = document.createElement('iframe');
- iframe.onload = function () {
- resolve(iframe);
- };
- iframe.sandbox = sandbox;
- iframe.src = src;
- document.documentElement.appendChild(iframe);
- });
- }
-
- function wait_for_message() {
- return new Promise(function (resolve) {
- self.addEventListener('message', function listener(e) {
- resolve(e.data);
- self.removeEventListener('message', listener);
- });
- });
- }
-
- promise_test(function (test) {
- var script = 'data:text/html,' +
- '<script>' +
- ' window.onmessage = function(e) {' +
- ' navigator.requestMediaKeySystemAccess("' + config.keysystem + '", [{' +
- ' initDataTypes: [\"' + config.initDataType + '\"],' +
- ' audioCapabilities: [' +
- ' { contentType:\'' + config.audioType + '\'},' +
- ' ]' +
- ' }]).then(function(access) {' +
- ' return access.createMediaKeys();' +
- ' }).then(function(mediaKeys) {' +
- ' window.parent.postMessage({result: \'allowed\'}, \'*\');' +
- ' }, function(error) {' +
- ' window.parent.postMessage({result: \'failed\'}, \'*\');' +
- ' });' +
- ' };' +
- '<\/script>';
-
- // Verify that this page can create a MediaKeys first.
- navigator.requestMediaKeySystemAccess(config.keysystem, [{
- initDataTypes: [config.initDataType],
- audioCapabilities: [
- {contentType: config.audioType},
- ]
- }]).then(function (access) {
- return access.createMediaKeys();
- }).then(function (mediaKeys) {
- // Success, so now create the iframe and try there.
- return load_iframe(script, 'allow-scripts')
- }).then(function (iframe) {
- iframe.contentWindow.postMessage({}, '*');
- return wait_for_message();
- }).then(function (message) {
- assert_equals(message.result, 'failed');
- });
- }, 'Unique origin is unable to create MediaKeys');
-}
diff --git a/testing/web-platform/tests/encrypted-media/scripts/update-disallowed-input.js b/testing/web-platform/tests/encrypted-media/scripts/update-disallowed-input.js
deleted file mode 100644
index b5adaf7f1..000000000
--- a/testing/web-platform/tests/encrypted-media/scripts/update-disallowed-input.js
+++ /dev/null
@@ -1,45 +0,0 @@
-function runTest(config)
-{
- // This test passes |response| to update() as a JSON Web Key Set.
- // CDMs other than Clear Key won't expect |response| in this format.
- promise_test(function(test) {
- var initDataType;
- var initData;
- var keySystem = config.keysystem;
- var mediaKeySession;
-
- function createReallyLongJWKSet()
- {
- // This is just a standard JWKSet with a lot of
- // extra items added to the end. Key ID and key
- // doesn't really matter.
- var jwkSet = '{"keys":[{'
- + '"kty":"oct",'
- + '"k":"MDEyMzQ1Njc4OTAxMjM0NQ",'
- + '"kid":"MDEyMzQ1Njc4OTAxMjM0NQ"'
- + '}]';
- return jwkSet + ',"test":"unknown"'.repeat(4000) + '}';
- }
-
- return navigator.requestMediaKeySystemAccess(keySystem, getSimpleConfiguration()).then(function(access) {
- initDataType = access.getConfiguration().initDataTypes[0];
- initData = getInitData(initDataType);
- return access.createMediaKeys();
- }).then(function(mediaKeys) {
- mediaKeySession = mediaKeys.createSession();
- var eventWatcher = new EventWatcher(test, mediaKeySession, ['message']);
- var promise = eventWatcher.wait_for('message');
- mediaKeySession.generateRequest(initDataType, initData);
- return promise;
- }).then(function () {
- var jwkSet = createReallyLongJWKSet();
- assert_greater_than(jwkSet.length, 65536);
- var jwkSetArray = stringToUint8Array(jwkSet);
- return mediaKeySession.update(jwkSetArray);
- }).then(function () {
- assert_unreached('update() with a response longer than 64Kb succeed');
- }).catch(function (error) {
- assert_equals(error.name, 'TypeError');
- });
- }, 'update() with invalid response (longer than 64Kb characters) should fail.');
-}
diff --git a/testing/web-platform/tests/encrypted-media/scripts/waiting-for-a-key.js b/testing/web-platform/tests/encrypted-media/scripts/waiting-for-a-key.js
deleted file mode 100644
index fee70e24a..000000000
--- a/testing/web-platform/tests/encrypted-media/scripts/waiting-for-a-key.js
+++ /dev/null
@@ -1,166 +0,0 @@
-function runTest(config)
-{
- // For debugging timeouts, keep track of the number of the
- // various events received.
- var debugEncryptedEventFired = false;
- var debugWaitingForKeyEventFired = false;
- var debugTimeUpdateEventCount = 0;
- var debugMessage = '';
-
- // Set global option explicit_timeout to true and control
- // the timeout in the promise test below.
- setup({
- explicit_timeout: true
- });
-
- promise_test(function (test) {
- var video = config.video;
- var keysystem = config.keysystem;
- var configuration = {
- initDataTypes: [config.initDataType],
- audioCapabilities: [{
- contentType: config.audioType
- }],
- videoCapabilities: [{
- contentType: config.videoType
- }],
- sessionTypes: ['temporary']
- };
- var initData;
- var initDataType;
- var mediaKeySession;
- // As this code doesn't wait for the 'message' event for clearkey to avoid
- // race conditions with 'waitingforkey', specify the key ID and
- // key used by the encrypted content.
- var keyId = new Uint8Array(config.content.keys[0].kid);
- var rawKey = new Uint8Array(config.content.keys[0].key);
- // Use the message handler for non clearkey drm
- var handler = config.messageHandler || null;
-
- // Override timeout() to use custom message instead of default
- // message "Test timed out"
- test.timeout = function () {
- var message = 'timeout. message = ' + debugMessage
- + ', encrypted: ' + debugEncryptedEventFired
- + ', waitingforkey: ' + debugWaitingForKeyEventFired
- + ', timeupdate count: ' + debugTimeUpdateEventCount;
-
- this.timeout_id = null;
- this.set_status(this.TIMEOUT, message);
- this.phase = this.phases.HAS_RESULT;
- this.done();
- };
-
- return navigator.requestMediaKeySystemAccess(keysystem, [configuration]).then(function (access) {
- debugMessage = 'createMediaKeys()';
- return access.createMediaKeys();
- }).then(function (mediaKeys) {
- debugMessage = 'setMediaKeys()';
- return video.setMediaKeys(mediaKeys);
- }).then(function () {
- return testmediasource(config);
- }).then(function (source) {
- debugMessage = 'wait_for_encrypted_event()';
- mediaSource = source;
- video.src = URL.createObjectURL(mediaSource);
- video.play();
- return wait_for_encrypted_event(video);
- }).then(function (e) {
- // Received the 'encrypted' event(s), so keep a copy of
- // the initdata for use when creating the session later.
- initDataType = config.initData ? config.initDataType : e.initDataType;
- initData = config.initData || e.initData;
- // Wait until the video indicates that it needs a key to
- // continue.
- debugMessage = 'wait_for_waitingforkey_event()';
- return wait_for_waitingforkey_event(video);
- }).then(function () {
- // Make sure the video is NOT paused and not progressing
- // before a key is provided. This requires the video
- // to NOT have a clear lead.
- assert_false(video.paused);
- assert_less_than(video.currentTime, 0.2);
- // Create a session.
- mediaKeySession = video.mediaKeys.createSession('temporary');
- debugMessage = 'generateRequest()';
- return mediaKeySession.generateRequest(initDataType, initData);
- }).then(function () {
- // generateRequest() will cause a 'message' event to
- // occur specifying the keyId that is needed
- // Add the key needed to decrypt.
- return wait_for_message_event(mediaKeySession, handler);
- }).then(function () {
- // Video should start playing now that it can decrypt the
- // streams, so wait until a little bit of the video has
- // played.
- debugMessage = 'wait_for_timeupdate_event()';
- return wait_for_timeupdate_event(video);
- }).catch(function (error) {
- assert_unreached('Error: ' + error.name);
- });
-
- // Typical test duration is 6 seconds on release builds
- // (12 seconds on debug).
- }, 'Waiting for a key.', {timeout: 20000});
-
- // Wait for an 'encrypted' event
- function wait_for_encrypted_event(video)
- {
- return new Promise(function (resolve) {
- video.addEventListener('encrypted', function listener(e) {
- assert_equals(e.target, video);
- assert_true(e instanceof window.MediaEncryptedEvent);
- assert_equals(e.type, 'encrypted');
- debugEncryptedEventFired = true;
- video.removeEventListener('encrypted', listener);
- resolve(e);
- });
- });
- };
-
- // Wait for a 'waitingforkey' event. Promise resolved when the
- // event is received.
- function wait_for_waitingforkey_event(video)
- {
- return new Promise(function (resolve) {
- video.addEventListener('waitingforkey', function listener(e) {
- assert_equals(e.target, video);
- assert_equals(e.type, 'waitingforkey');
- debugWaitingForKeyEventFired = true;
- video.removeEventListener('waitingforkey', listener);
- resolve(e);
- });
- });
- };
-
- // Wait for a 'timeupdate' event. Promise resolved if |video| has
- // played for more than 0.2 seconds.
- function wait_for_timeupdate_event(video)
- {
- return new Promise(function (resolve) {
- video.addEventListener('timeupdate', function listener(e) {
- assert_equals(e.target, video);
- ++debugTimeUpdateEventCount;
- if (video.currentTime < 0.2)
- return;
- video.removeEventListener('timeupdate', listener);
- resolve(e);
- });
- });
- };
-
- // We need to wait for the message even if for non clearkey DRMs.
- function wait_for_message_event(mediaKeySession, handler)
- {
- return new Promise(function (resolve, reject) {
- mediaKeySession.addEventListener('message', function listener(e) {
- assert_equals(e.target, mediaKeySession);
- assert_equals(e.type, 'message');
- video.removeEventListener('message', listener);
- return handler(e.messageType, e.message).then(function (response) {
- return e.target.update(response)
- }).then(resolve, reject);
- });
- });
- }
-}
diff --git a/testing/web-platform/tests/encrypted-media/util/clearkey-messagehandler.js b/testing/web-platform/tests/encrypted-media/util/clearkey-messagehandler.js
deleted file mode 100644
index c91a57f6d..000000000
--- a/testing/web-platform/tests/encrypted-media/util/clearkey-messagehandler.js
+++ /dev/null
@@ -1,64 +0,0 @@
-// Expect utf8decoder and utf8decoder to be TextEncoder('utf-8') and TextDecoder('utf-8') respectively
-
-function MessageHandler( keysystem, content ) {
- this._keysystem = keysystem;
- this._content = content;
- this.messagehandler = MessageHandler.prototype.messagehandler.bind( this );
- this.servercertificate = undefined;
-}
-
-MessageHandler.prototype.messagehandler = function messagehandler( messageType, message )
-{
- if ( messageType === 'license-request' )
- {
- var request = fromUtf8( message );
-
- var keys = request.kids.map( function( kid ) {
-
- var key;
- for( var i=0; i < this._content.keys.length; ++i )
- {
- if ( base64urlEncode( this._content.keys[ i ].kid ) === kid )
- {
- key = base64urlEncode( this._content.keys[ i ].key );
- break;
- }
- }
-
- return { kty: 'oct', kid: kid, k: key };
-
- }.bind( this ) );
-
- return Promise.resolve( toUtf8( { keys: keys } ) );
- }
- else if ( messageType === 'license-release' )
- {
- var release = fromUtf8( message );
-
- // TODO: Check the license release message here
-
- return Promise.resolve( toUtf8( { kids: release.kids } ) );
- }
-
- throw new TypeError( 'Unsupported message type for ClearKey' );
-};
-
-MessageHandler.prototype.createJWKSet = function createJWKSet(keyId, key) {
- var jwkSet = '{"keys":[';
- for (var i = 0; i < arguments.length; i++) {
- if (i != 0)
- jwkSet += ',';
- jwkSet += arguments[i];
- }
- jwkSet += ']}';
- return jwkSet;
-};
-
-MessageHandler.prototype.createJWK = function createJWK(keyId, key) {
- var jwk = '{"kty":"oct","alg":"A128KW","kid":"';
- jwk += base64urlEncode(keyId);
- jwk += '","k":"';
- jwk += base64urlEncode(key);
- jwk += '"}';
- return jwk;
-}; \ No newline at end of file
diff --git a/testing/web-platform/tests/encrypted-media/util/drm-messagehandler.js b/testing/web-platform/tests/encrypted-media/util/drm-messagehandler.js
deleted file mode 100644
index 256c069e5..000000000
--- a/testing/web-platform/tests/encrypted-media/util/drm-messagehandler.js
+++ /dev/null
@@ -1,262 +0,0 @@
-(function(){
-// Expect utf8decoder and utf8decoder to be TextEncoder('utf-8') and TextDecoder('utf-8') respectively
-//
-// drmconfig format:
-// { <keysystem> : { "serverURL" : <the url for the server>,
-// "httpRequestHeaders" : <map of HTTP request headers>,
-// "servertype" : "microsoft" | "drmtoday", // affects how request parameters are formed
-// "certificate" : <base64 encoded server certificate> } }
-//
-
-drmtodaysecret = Uint8Array.from( [144, 34, 109, 76, 134, 7, 97, 107, 98, 251, 140, 28, 98, 79, 153, 222, 231, 245, 154, 226, 193, 1, 213, 207, 152, 204, 144, 15, 13, 2, 37, 236] );
-
-drmconfig = {
- "com.widevine.alpha": [ {
- "serverURL": "https://lic.staging.drmtoday.com/license-proxy-widevine/cenc/",
- "servertype" : "drmtoday",
- "merchant" : "w3c-eme-test",
- "secret" : drmtodaysecret
- } ],
- "com.microsoft.playready": [ {
- "serverURL": "http://playready-testserver.azurewebsites.net/rightsmanager.asmx",
- "servertype": "microsoft",
- "sessionTypes" : [ "persistent-usage-record" ],
- "certificate" : "Q0hBSQAAAAEAAAUEAAAAAAAAAAJDRVJUAAAAAQAAAfQAAAFkAAEAAQAAAFjt9G6KdSncCkrjbTQPN+/2AAAAAAAAAAAAAAAJIPbrW9dj0qydQFIomYFHOwbhGZVGP2ZsPwcvjh+NFkP/////AAAAAAAAAAAAAAAAAAAAAAABAAoAAABYxw6TjIuUUmvdCcl00t4RBAAAADpodHRwOi8vcGxheXJlYWR5LmRpcmVjdHRhcHMubmV0L3ByL3N2Yy9yaWdodHNtYW5hZ2VyLmFzbXgAAAAAAQAFAAAADAAAAAAAAQAGAAAAXAAAAAEAAQIAAAAAADBRmRRpqV4cfRLcWz9WoXIGZ5qzD9xxJe0CSI2mXJQdPHEFZltrTkZtdmurwVaEI2etJY0OesCeOCzCqmEtTkcAAAABAAAAAgAAAAcAAAA8AAAAAAAAAAVEVEFQAAAAAAAAABVNZXRlcmluZyBDZXJ0aWZpY2F0ZQAAAAAAAAABAAAAAAABAAgAAACQAAEAQGHic/IPbmLCKXxc/MH20X/RtjhXH4jfowBWsQE1QWgUUBPFId7HH65YuQJ5fxbQJCT6Hw0iHqKzaTkefrhIpOoAAAIAW+uRUsdaChtq/AMUI4qPlK2Bi4bwOyjJcSQWz16LAFfwibn5yHVDEgNA4cQ9lt3kS4drx7pCC+FR/YLlHBAV7ENFUlQAAAABAAAC/AAAAmwAAQABAAAAWMk5Z0ovo2X0b2C9K5PbFX8AAAAAAAAAAAAAAARTYd1EkpFovPAZUjOj2doDLnHiRSfYc89Fs7gosBfar/////8AAAAAAAAAAAAAAAAAAAAAAAEABQAAAAwAAAAAAAEABgAAAGAAAAABAAECAAAAAABb65FSx1oKG2r8AxQjio+UrYGLhvA7KMlxJBbPXosAV/CJufnIdUMSA0DhxD2W3eRLh2vHukIL4VH9guUcEBXsAAAAAgAAAAEAAAAMAAAABwAAAZgAAAAAAAAAgE1pY3Jvc29mdAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAgFBsYXlSZWFkeSBTTDAgTWV0ZXJpbmcgUm9vdCBDQQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAgDEuMC4wLjEAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAEACAAAAJAAAQBArAKJsEIDWNG5ulOgLvSUb8I2zZ0c5lZGYvpIO56Z0UNk/uC4Mq3jwXQUUN6m/48V5J/vuLDhWu740aRQc1dDDAAAAgCGTWHP8iVuQixWizwoABz7PhUnZYWEugUht5sYKNk23h2Cao/D5uf6epDVyilG8fZKLvufXc/+fkNOtEKT+sWr"
- },
- {
- "serverURL": "http://playready.directtaps.net/pr/svc/rightsmanager.asmx",
- "servertype": "microsoft",
- "sessionTypes" : [ "persistent-usage-record" ],
- "certificate" : "Q0hBSQAAAAEAAAUEAAAAAAAAAAJDRVJUAAAAAQAAAfQAAAFkAAEAAQAAAFjt9G6KdSncCkrjbTQPN+/2AAAAAAAAAAAAAAAJIPbrW9dj0qydQFIomYFHOwbhGZVGP2ZsPwcvjh+NFkP/////AAAAAAAAAAAAAAAAAAAAAAABAAoAAABYxw6TjIuUUmvdCcl00t4RBAAAADpodHRwOi8vcGxheXJlYWR5LmRpcmVjdHRhcHMubmV0L3ByL3N2Yy9yaWdodHNtYW5hZ2VyLmFzbXgAAAAAAQAFAAAADAAAAAAAAQAGAAAAXAAAAAEAAQIAAAAAADBRmRRpqV4cfRLcWz9WoXIGZ5qzD9xxJe0CSI2mXJQdPHEFZltrTkZtdmurwVaEI2etJY0OesCeOCzCqmEtTkcAAAABAAAAAgAAAAcAAAA8AAAAAAAAAAVEVEFQAAAAAAAAABVNZXRlcmluZyBDZXJ0aWZpY2F0ZQAAAAAAAAABAAAAAAABAAgAAACQAAEAQGHic/IPbmLCKXxc/MH20X/RtjhXH4jfowBWsQE1QWgUUBPFId7HH65YuQJ5fxbQJCT6Hw0iHqKzaTkefrhIpOoAAAIAW+uRUsdaChtq/AMUI4qPlK2Bi4bwOyjJcSQWz16LAFfwibn5yHVDEgNA4cQ9lt3kS4drx7pCC+FR/YLlHBAV7ENFUlQAAAABAAAC/AAAAmwAAQABAAAAWMk5Z0ovo2X0b2C9K5PbFX8AAAAAAAAAAAAAAARTYd1EkpFovPAZUjOj2doDLnHiRSfYc89Fs7gosBfar/////8AAAAAAAAAAAAAAAAAAAAAAAEABQAAAAwAAAAAAAEABgAAAGAAAAABAAECAAAAAABb65FSx1oKG2r8AxQjio+UrYGLhvA7KMlxJBbPXosAV/CJufnIdUMSA0DhxD2W3eRLh2vHukIL4VH9guUcEBXsAAAAAgAAAAEAAAAMAAAABwAAAZgAAAAAAAAAgE1pY3Jvc29mdAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAgFBsYXlSZWFkeSBTTDAgTWV0ZXJpbmcgUm9vdCBDQQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAgDEuMC4wLjEAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAEACAAAAJAAAQBArAKJsEIDWNG5ulOgLvSUb8I2zZ0c5lZGYvpIO56Z0UNk/uC4Mq3jwXQUUN6m/48V5J/vuLDhWu740aRQc1dDDAAAAgCGTWHP8iVuQixWizwoABz7PhUnZYWEugUht5sYKNk23h2Cao/D5uf6epDVyilG8fZKLvufXc/+fkNOtEKT+sWr"
- },
- {
- "serverURL": "https://lic.staging.drmtoday.com/license-proxy-headerauth/drmtoday/RightsManager.asmx",
- "servertype" : "drmtoday",
- "sessionTypes" : [ "temporary", "persistent-usage-record", "persistent-license" ],
- "merchant" : "w3c-eme-test",
- "secret" : drmtodaysecret
- } ]
-};
-
-
-var keySystemWrappers = {
- // Key System wrappers map messages and pass to a handler, then map the response and return to caller
- //
- // function wrapper(handler, messageType, message, params)
- //
- // where:
- // Promise<response> handler(messageType, message, responseType, headers, params);
- //
-
- 'com.widevine.alpha': function(handler, messageType, message, params) {
- return handler.call(this, messageType, new Uint8Array(message), 'json', null, params).then(function(response){
- return base64DecodeToUnit8Array(response.license);
- });
- },
-
- 'com.microsoft.playready': function(handler, messageType, message, params) {
- var msg, xmlDoc;
- var licenseRequest = null;
- var headers = {};
- var parser = new DOMParser();
- var dataview = new Uint16Array(message);
-
- msg = String.fromCharCode.apply(null, dataview);
- xmlDoc = parser.parseFromString(msg, 'application/xml');
-
- if (xmlDoc.getElementsByTagName('Challenge')[0]) {
- var challenge = xmlDoc.getElementsByTagName('Challenge')[0].childNodes[0].nodeValue;
- if (challenge) {
- licenseRequest = atob(challenge);
- }
- }
-
- var headerNameList = xmlDoc.getElementsByTagName('name');
- var headerValueList = xmlDoc.getElementsByTagName('value');
- for (var i = 0; i < headerNameList.length; i++) {
- headers[headerNameList[i].childNodes[0].nodeValue] = headerValueList[i].childNodes[0].nodeValue;
- }
- // some versions of the PlayReady CDM return 'Content' instead of 'Content-Type',
- // but the license server expects 'Content-Type', so we fix it up here.
- if (headers.hasOwnProperty('Content')) {
- headers['Content-Type'] = headers.Content;
- delete headers.Content;
- }
-
- return handler.call(this, messageType, licenseRequest, 'arraybuffer', headers, params).catch(function(response){
- return response.text().then( function( error ) { throw error; } );
- });
- }
-};
-
-const requestConstructors = {
- // Server request construction functions
- //
- // Promise<request> constructRequest(config, sessionType, content, messageType, message, params)
- //
- // request = { url: ..., headers: ..., body: ... }
- //
- // content = { assetId: ..., variantId: ..., key: ... }
- // params = { expiration: ... }
-
- 'drmtoday': function(config, sessionType, content, messageType, message, headers, params) {
- var optData = JSON.stringify({merchant: config.merchant, userId:"12345", sessionId:""});
- var crt = {};
- if (messageType === 'license-request') {
- crt = {assetId: content.assetId,
- outputProtection: {digital : false, analogue: false, enforce: false},
- storeLicense: (sessionType === 'persistent-license')};
-
- if (!params || params.expiration === undefined) {
- crt.profile = {purchase: {}};
- } else {
- crt.profile = {rental: {absoluteExpiration: (new Date(params.expiration)).toISOString(),
- playDuration: 3600000 } };
- }
-
- if (content.variantId !== undefined) {
- crt.variantId = content.variantId;
- }
- }
-
- return JWT.encode("HS256", {optData: optData, crt: JSON.stringify([crt])}, config.secret).then(function(jwt){
- headers = headers || {};
- headers['x-dt-auth-token'] = jwt;
- return {url: config.serverURL, headers: headers, body: message};
- });
- },
-
- 'microsoft': function(config, sessionType, content, messageType, message, headers, params) {
- var url = config.serverURL;
- if (messageType === 'license-request') {
- url += "?";
- if (sessionType === 'temporary' || sessionType === 'persistent-usage-record') {
- url += "UseSimpleNonPersistentLicense=1&";
- }
- if (sessionType === 'persistent-usage-record') {
- url += "SecureStop=1&";
- }
- url += "PlayEnablers=B621D91F-EDCC-4035-8D4B-DC71760D43E9&"; // disable output protection
- url += "ContentKey=" + btoa(String.fromCharCode.apply(null, content.key));
- return url;
- }
-
- // TODO: Include expiration time in URL
- return Promise.resolve({url: url, headers: headers, body: message});
- }
-};
-
-MessageHandler = function(keysystem, content, sessionType) {
- sessionType = sessionType || "temporary";
-
- this._keysystem = keysystem;
- this._content = content;
- this._sessionType = sessionType;
- try {
- this._drmconfig = drmconfig[this._keysystem].filter(function(drmconfig) {
- return drmconfig.sessionTypes === undefined || (drmconfig.sessionTypes.indexOf(sessionType) !== -1);
- })[0];
- this._requestConstructor = requestConstructors[this._drmconfig.servertype];
-
- this.messagehandler = keySystemWrappers[keysystem].bind(this, MessageHandler.prototype.messagehandler);
-
- if (this._drmconfig && this._drmconfig.certificate) {
- this.servercertificate = stringToUint8Array(atob(this._drmconfig.certificate));
- }
- } catch(e) {
- return null;
- }
-}
-
-MessageHandler.prototype.messagehandler = function messagehandler(messageType, message, responseType, headers, params) {
-
- var variantId = params ? params.variantId : undefined;
- var key;
- if( variantId ) {
- var keys = this._content.keys.filter(function(k){return k.variantId === variantId;});
- if (keys[0]) key = keys[0].key;
- }
- if (!key) {
- key = this._content.keys[0].key;
- }
-
- var content = {assetId: this._content.assetId,
- variantId: variantId,
- key: key};
-
- return this._requestConstructor(this._drmconfig, this._sessionType, content, messageType, message, headers, params).then(function(request){
- return fetch(request.url, {
- method: 'POST',
- headers: request.headers,
- body: request.body });
- }).then(function(fetchresponse){
- if(fetchresponse.status !== 200) {
- throw fetchresponse;
- }
-
- if(responseType === 'json') {
- return fetchresponse.json();
- } else if(responseType === 'arraybuffer') {
- return fetchresponse.arrayBuffer();
- }
- });
-}
-
-})();
-
-(function() {
-
- var subtlecrypto = window.crypto.subtle;
-
- // Encoding / decoding utilities
- function b64pad(b64) { return b64+"==".substr(0,(b64.length%4)?(4-b64.length%4):0); }
- function str2b64url(str) { return btoa(str).replace(/=+$/g, '').replace(/\+/g, "-").replace(/\//g, "_"); }
- function b64url2str(b64) { return atob(b64pad(b64.replace(/\-/g, "+").replace(/\_/g, "/"))); }
- function str2ab(str) { return Uint8Array.from( str.split(''), function(s){return s.charCodeAt(0)} ); }
- function ab2str(ab) { return String.fromCharCode.apply(null, new Uint8Array(ab)); }
-
- function jwt2webcrypto(alg) {
- if (alg === "HS256") return {name: "HMAC", hash: "SHA-256", length: 256};
- else if (alg === "HS384") return { name: "HMAC", hash: "SHA-384", length: 384};
- else if (alg === "HS512") return { name: "HMAC", hash: "SHA-512", length: 512};
- else throw new Error("Unrecognized JWT algorithm: " + alg);
- }
-
- JWT = {
- encode: function encode(alg, claims, secret) {
- var algorithm = jwt2webcrypto(alg);
- if (secret.byteLength !== algorithm.length / 8) throw new Error("Unexpected secret length: " + secret.byteLength);
-
- if (!claims.iat) claims.iat = (Date.now() / 1000) | 0;
- if (!claims.jti) {
- var nonce = new Uint8Array(16);
- window.crypto.getRandomValues(nonce);
- claims.jti = str2b64url( ab2str(nonce) );
- }
-
- var header = {typ: "JWT", alg: alg};
- var plaintext = str2b64url(JSON.stringify(header)) + '.' + str2b64url(JSON.stringify(claims));
- return subtlecrypto.importKey("raw", secret, algorithm, false, [ "sign" ]).then( function(key) {
- return subtlecrypto.sign(algorithm, key, str2ab(plaintext));
- }).then(function(hmac){
- return plaintext + '.' + str2b64url(ab2str(hmac));
- });
- },
-
- decode: function decode(jwt, secret) {
- var jwtparts = jwt.split('.');
- var header = JSON.parse( b64url2str(jwtparts[0]));
- var claims = JSON.parse( b64url2str(jwtparts[1]));
- var hmac = str2ab(b64url2str(jwtparts[2]));
- var algorithm = jwt2webcrypto(header.alg);
- if (secret.byteLength !== algorithm.length / 8) throw new Error("Unexpected secret length: " + secret.byteLength);
-
- return subtlecrypto.importKey("raw", secret, algorithm, false, ["sign", "verify"]).then(function(key) {
- return subtlecrypto.verify(algorithm, key, hmac, str2ab(jwtparts[0] + '.' + jwtparts[1]));
- }).then(function(success){
- if (!success) throw new Error("Invalid signature");
- return claims;
- });
- }
- };
-})();
diff --git a/testing/web-platform/tests/encrypted-media/util/fetch.js b/testing/web-platform/tests/encrypted-media/util/fetch.js
deleted file mode 100644
index d14d00bdb..000000000
--- a/testing/web-platform/tests/encrypted-media/util/fetch.js
+++ /dev/null
@@ -1,456 +0,0 @@
-// https://github.com/github/fetch
-//
-// Copyright (c) 2014-2016 GitHub, Inc.
-//
-// Permission is hereby granted, free of charge, to any person obtaining
-// a copy of this software and associated documentation files (the
-// "Software"), to deal in the Software without restriction, including
-// without limitation the rights to use, copy, modify, merge, publish,
-// distribute, sublicense, and/or sell copies of the Software, and to
-// permit persons to whom the Software is furnished to do so, subject to
-// the following conditions:
-//
-// The above copyright notice and this permission notice shall be
-// included in all copies or substantial portions of the Software.
-//
-// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
-// EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
-// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
-// NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
-// LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
-// OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
-// WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
-
-(function(self) {
- 'use strict';
-
- if (self.fetch) {
- return
- }
-
- var support = {
- searchParams: 'URLSearchParams' in self,
- iterable: 'Symbol' in self && 'iterator' in Symbol,
- blob: 'FileReader' in self && 'Blob' in self && (function() {
- try {
- new Blob()
- return true
- } catch(e) {
- return false
- }
- })(),
- formData: 'FormData' in self,
- arrayBuffer: 'ArrayBuffer' in self
- }
-
- function normalizeName(name) {
- if (typeof name !== 'string') {
- name = String(name)
- }
- if (/[^a-z0-9\-#$%&'*+.\^_`|~]/i.test(name)) {
- throw new TypeError('Invalid character in header field name')
- }
- return name.toLowerCase()
- }
-
- function normalizeValue(value) {
- if (typeof value !== 'string') {
- value = String(value)
- }
- return value
- }
-
- // Build a destructive iterator for the value list
- function iteratorFor(items) {
- var iterator = {
- next: function() {
- var value = items.shift()
- return {done: value === undefined, value: value}
- }
- }
-
- if (support.iterable) {
- iterator[Symbol.iterator] = function() {
- return iterator
- }
- }
-
- return iterator
- }
-
- function Headers(headers) {
- this.map = {}
-
- if (headers instanceof Headers) {
- headers.forEach(function(value, name) {
- this.append(name, value)
- }, this)
-
- } else if (headers) {
- Object.getOwnPropertyNames(headers).forEach(function(name) {
- this.append(name, headers[name])
- }, this)
- }
- }
-
- Headers.prototype.append = function(name, value) {
- name = normalizeName(name)
- value = normalizeValue(value)
- var list = this.map[name]
- if (!list) {
- list = []
- this.map[name] = list
- }
- list.push(value)
- }
-
- Headers.prototype['delete'] = function(name) {
- delete this.map[normalizeName(name)]
- }
-
- Headers.prototype.get = function(name) {
- var values = this.map[normalizeName(name)]
- return values ? values[0] : null
- }
-
- Headers.prototype.getAll = function(name) {
- return this.map[normalizeName(name)] || []
- }
-
- Headers.prototype.has = function(name) {
- return this.map.hasOwnProperty(normalizeName(name))
- }
-
- Headers.prototype.set = function(name, value) {
- this.map[normalizeName(name)] = [normalizeValue(value)]
- }
-
- Headers.prototype.forEach = function(callback, thisArg) {
- Object.getOwnPropertyNames(this.map).forEach(function(name) {
- this.map[name].forEach(function(value) {
- callback.call(thisArg, value, name, this)
- }, this)
- }, this)
- }
-
- Headers.prototype.keys = function() {
- var items = []
- this.forEach(function(value, name) { items.push(name) })
- return iteratorFor(items)
- }
-
- Headers.prototype.values = function() {
- var items = []
- this.forEach(function(value) { items.push(value) })
- return iteratorFor(items)
- }
-
- Headers.prototype.entries = function() {
- var items = []
- this.forEach(function(value, name) { items.push([name, value]) })
- return iteratorFor(items)
- }
-
- if (support.iterable) {
- Headers.prototype[Symbol.iterator] = Headers.prototype.entries
- }
-
- function consumed(body) {
- if (body.bodyUsed) {
- return Promise.reject(new TypeError('Already read'))
- }
- body.bodyUsed = true
- }
-
- function fileReaderReady(reader) {
- return new Promise(function(resolve, reject) {
- reader.onload = function() {
- resolve(reader.result)
- }
- reader.onerror = function() {
- reject(reader.error)
- }
- })
- }
-
- function readBlobAsArrayBuffer(blob) {
- var reader = new FileReader()
- reader.readAsArrayBuffer(blob)
- return fileReaderReady(reader)
- }
-
- function readBlobAsText(blob) {
- var reader = new FileReader()
- reader.readAsText(blob)
- return fileReaderReady(reader)
- }
-
- function Body() {
- this.bodyUsed = false
-
- this._initBody = function(body) {
- this._bodyInit = body
- if (typeof body === 'string') {
- this._bodyText = body
- } else if (support.blob && Blob.prototype.isPrototypeOf(body)) {
- this._bodyBlob = body
- } else if (support.formData && FormData.prototype.isPrototypeOf(body)) {
- this._bodyFormData = body
- } else if (support.searchParams && URLSearchParams.prototype.isPrototypeOf(body)) {
- this._bodyText = body.toString()
- } else if (!body) {
- this._bodyText = ''
- } else if (support.arrayBuffer && ArrayBuffer.prototype.isPrototypeOf(body)) {
- // Only support ArrayBuffers for POST method.
- // Receiving ArrayBuffers happens via Blobs, instead.
- } else {
- throw new Error('unsupported BodyInit type')
- }
-
- if (!this.headers.get('content-type')) {
- if (typeof body === 'string') {
- this.headers.set('content-type', 'text/plain;charset=UTF-8')
- } else if (this._bodyBlob && this._bodyBlob.type) {
- this.headers.set('content-type', this._bodyBlob.type)
- } else if (support.searchParams && URLSearchParams.prototype.isPrototypeOf(body)) {
- this.headers.set('content-type', 'application/x-www-form-urlencoded;charset=UTF-8')
- }
- }
- }
-
- if (support.blob) {
- this.blob = function() {
- var rejected = consumed(this)
- if (rejected) {
- return rejected
- }
-
- if (this._bodyBlob) {
- return Promise.resolve(this._bodyBlob)
- } else if (this._bodyFormData) {
- throw new Error('could not read FormData body as blob')
- } else {
- return Promise.resolve(new Blob([this._bodyText]))
- }
- }
-
- this.arrayBuffer = function() {
- return this.blob().then(readBlobAsArrayBuffer)
- }
-
- this.text = function() {
- var rejected = consumed(this)
- if (rejected) {
- return rejected
- }
-
- if (this._bodyBlob) {
- return readBlobAsText(this._bodyBlob)
- } else if (this._bodyFormData) {
- throw new Error('could not read FormData body as text')
- } else {
- return Promise.resolve(this._bodyText)
- }
- }
- } else {
- this.text = function() {
- var rejected = consumed(this)
- return rejected ? rejected : Promise.resolve(this._bodyText)
- }
- }
-
- if (support.formData) {
- this.formData = function() {
- return this.text().then(decode)
- }
- }
-
- this.json = function() {
- return this.text().then(JSON.parse)
- }
-
- return this
- }
-
- // HTTP methods whose capitalization should be normalized
- var methods = ['DELETE', 'GET', 'HEAD', 'OPTIONS', 'POST', 'PUT']
-
- function normalizeMethod(method) {
- var upcased = method.toUpperCase()
- return (methods.indexOf(upcased) > -1) ? upcased : method
- }
-
- function Request(input, options) {
- options = options || {}
- var body = options.body
- if (Request.prototype.isPrototypeOf(input)) {
- if (input.bodyUsed) {
- throw new TypeError('Already read')
- }
- this.url = input.url
- this.credentials = input.credentials
- if (!options.headers) {
- this.headers = new Headers(input.headers)
- }
- this.method = input.method
- this.mode = input.mode
- if (!body) {
- body = input._bodyInit
- input.bodyUsed = true
- }
- } else {
- this.url = input
- }
-
- this.credentials = options.credentials || this.credentials || 'omit'
- if (options.headers || !this.headers) {
- this.headers = new Headers(options.headers)
- }
- this.method = normalizeMethod(options.method || this.method || 'GET')
- this.mode = options.mode || this.mode || null
- this.referrer = null
-
- if ((this.method === 'GET' || this.method === 'HEAD') && body) {
- throw new TypeError('Body not allowed for GET or HEAD requests')
- }
- this._initBody(body)
- }
-
- Request.prototype.clone = function() {
- return new Request(this)
- }
-
- function decode(body) {
- var form = new FormData()
- body.trim().split('&').forEach(function(bytes) {
- if (bytes) {
- var split = bytes.split('=')
- var name = split.shift().replace(/\+/g, ' ')
- var value = split.join('=').replace(/\+/g, ' ')
- form.append(decodeURIComponent(name), decodeURIComponent(value))
- }
- })
- return form
- }
-
- function headers(xhr) {
- var head = new Headers()
- var pairs = (xhr.getAllResponseHeaders() || '').trim().split('\n')
- pairs.forEach(function(header) {
- var split = header.trim().split(':')
- var key = split.shift().trim()
- var value = split.join(':').trim()
- head.append(key, value)
- })
- return head
- }
-
- Body.call(Request.prototype)
-
- function Response(bodyInit, options) {
- if (!options) {
- options = {}
- }
-
- this.type = 'default'
- this.status = options.status
- this.ok = this.status >= 200 && this.status < 300
- this.statusText = options.statusText
- this.headers = options.headers instanceof Headers ? options.headers : new Headers(options.headers)
- this.url = options.url || ''
- this._initBody(bodyInit)
- }
-
- Body.call(Response.prototype)
-
- Response.prototype.clone = function() {
- return new Response(this._bodyInit, {
- status: this.status,
- statusText: this.statusText,
- headers: new Headers(this.headers),
- url: this.url
- })
- }
-
- Response.error = function() {
- var response = new Response(null, {status: 0, statusText: ''})
- response.type = 'error'
- return response
- }
-
- var redirectStatuses = [301, 302, 303, 307, 308]
-
- Response.redirect = function(url, status) {
- if (redirectStatuses.indexOf(status) === -1) {
- throw new RangeError('Invalid status code')
- }
-
- return new Response(null, {status: status, headers: {location: url}})
- }
-
- self.Headers = Headers
- self.Request = Request
- self.Response = Response
-
- self.fetch = function(input, init) {
- return new Promise(function(resolve, reject) {
- var request
- if (Request.prototype.isPrototypeOf(input) && !init) {
- request = input
- } else {
- request = new Request(input, init)
- }
-
- var xhr = new XMLHttpRequest()
-
- function responseURL() {
- if ('responseURL' in xhr) {
- return xhr.responseURL
- }
-
- // Avoid security warnings on getResponseHeader when not allowed by CORS
- if (/^X-Request-URL:/m.test(xhr.getAllResponseHeaders())) {
- return xhr.getResponseHeader('X-Request-URL')
- }
-
- return
- }
-
- xhr.onload = function() {
- var options = {
- status: xhr.status,
- statusText: xhr.statusText,
- headers: headers(xhr),
- url: responseURL()
- }
- var body = 'response' in xhr ? xhr.response : xhr.responseText
- resolve(new Response(body, options))
- }
-
- xhr.onerror = function() {
- reject(new TypeError('Network request failed'))
- }
-
- xhr.ontimeout = function() {
- reject(new TypeError('Network request failed'))
- }
-
- xhr.open(request.method, request.url, true)
-
- if (request.credentials === 'include') {
- xhr.withCredentials = true
- }
-
- if ('responseType' in xhr && support.blob) {
- xhr.responseType = 'blob'
- }
-
- request.headers.forEach(function(value, name) {
- xhr.setRequestHeader(name, value)
- })
-
- xhr.send(typeof request._bodyInit === 'undefined' ? null : request._bodyInit)
- })
- }
- self.fetch.polyfill = true
-})(typeof self !== 'undefined' ? self : this); \ No newline at end of file
diff --git a/testing/web-platform/tests/encrypted-media/util/testmediasource.js b/testing/web-platform/tests/encrypted-media/util/testmediasource.js
deleted file mode 100644
index 62c2d577d..000000000
--- a/testing/web-platform/tests/encrypted-media/util/testmediasource.js
+++ /dev/null
@@ -1,43 +0,0 @@
-function testmediasource(config) {
-
- return new Promise(function(resolve, reject) {
- // Fetch the media resources
- var fetches = [config.audioPath, config.videoPath].map(function(path) {
- return fetch(path).then(function(response) {
- if (!response.ok) throw new Error('Resource fetch failed');
- return response.arrayBuffer();
- });
- });
-
- Promise.all(fetches).then(function(resources) {
- config.audioMedia = resources[0];
- config.videoMedia = resources[1];
-
- // Create media source
- var source = new MediaSource();
-
- // Create and fill source buffers when the media source is opened
- source.addEventListener('sourceopen', onSourceOpen);
-
- function onSourceOpen(event) {
- var audioSourceBuffer = source.addSourceBuffer(config.audioType),
- videoSourceBuffer = source.addSourceBuffer(config.videoType);
-
- audioSourceBuffer.appendBuffer(config.audioMedia);
- videoSourceBuffer.appendBuffer(config.videoMedia);
-
- function endOfStream() {
- if (audioSourceBuffer.updating || videoSourceBuffer.updating) {
- setTimeout(endOfStream, 250);
- } else {
- source.endOfStream();
- }
- }
-
- endOfStream();
- }
-
- resolve(source);
- });
- });
-} \ No newline at end of file
diff --git a/testing/web-platform/tests/encrypted-media/util/utf8.js b/testing/web-platform/tests/encrypted-media/util/utf8.js
deleted file mode 100644
index 5b1176013..000000000
--- a/testing/web-platform/tests/encrypted-media/util/utf8.js
+++ /dev/null
@@ -1,22 +0,0 @@
-if ( typeof TextEncoder !== "undefined" && typeof TextDecoder !== "undefined" )
-{
- utf8encoder = new TextEncoder('utf-8');
- utf8decoder = new TextDecoder('utf-8');
-}
-else
-{
- utf8encoder = { encode: function( text )
- {
- var result = new Uint8Array(text.length);
- for(var i = 0; i < text.length; i++) { result[i] = text.charCodeAt(i); }
- return result;
- } };
-
- utf8decoder = { decode: function( buffer )
- {
- return String.fromCharCode.apply(null, new Uint8Array(buffer));
- } };
-}
-
-toUtf8 = function( o ) { return utf8encoder.encode( JSON.stringify( o ) ); }
-fromUtf8 = function( t ) { return JSON.parse( utf8decoder.decode( t ) ); } \ No newline at end of file
diff --git a/testing/web-platform/tests/encrypted-media/util/utils.js b/testing/web-platform/tests/encrypted-media/util/utils.js
deleted file mode 100644
index 98ac8c44a..000000000
--- a/testing/web-platform/tests/encrypted-media/util/utils.js
+++ /dev/null
@@ -1,271 +0,0 @@
-function testnamePrefix( qualifier, keysystem ) {
- return ( qualifier || '' ) + ( keysystem === 'org.w3.clearkey' ? keysystem : 'drm' );
-}
-
-function getInitData(initDataType) {
-
- // FIXME: This is messed up, because here we are hard coding the key ids for the different content
- // that we use for clearkey testing: webm and mp4. For keyids we return the mp4 one
- //
- // The content used with the DRM today servers has a different key id altogether
-
- if (initDataType == 'webm') {
- return new Uint8Array([
- 0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07,
- 0x08, 0x09, 0x0A, 0x0B, 0x0C, 0x0D, 0x0E, 0x0F
- ]);
- }
-
- if (initDataType == 'cenc') {
- return new Uint8Array([
- 0x00, 0x00, 0x00, 0x34, // size
- 0x70, 0x73, 0x73, 0x68, // 'pssh'
- 0x01, // version = 1
- 0x00, 0x00, 0x00, // flags
- 0x10, 0x77, 0xEF, 0xEC, 0xC0, 0xB2, 0x4D, 0x02, // Common SystemID
- 0xAC, 0xE3, 0x3C, 0x1E, 0x52, 0xE2, 0xFB, 0x4B,
- 0x00, 0x00, 0x00, 0x01, // key count
- 0x00, 0x00, 0x00, 0x00, 0x03, 0xd2, 0xfc, 0x41, // key id
- 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
- 0x00, 0x00, 0x00, 0x00 // datasize
- ]);
- }
- if (initDataType == 'keyids') {
- var keyId = new Uint8Array([
- 0x00, 0x00, 0x00, 0x00, 0x03, 0xd2, 0xfc, 0x41,
- 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00
- ]);
- return stringToUint8Array(createKeyIDs(keyId));
- }
- throw 'initDataType ' + initDataType + ' not supported.';
-}
-
-function stringToUint8Array(str)
-{
- var result = new Uint8Array(str.length);
- for(var i = 0; i < str.length; i++) {
- result[i] = str.charCodeAt(i);
- }
- return result;
-}
-// Encodes |data| into base64url string. There is no '=' padding, and the
-// characters '-' and '_' must be used instead of '+' and '/', respectively.
-function base64urlEncode(data) {
- var result = btoa(String.fromCharCode.apply(null, data));
- return result.replace(/=+$/g, '').replace(/\+/g, "-").replace(/\//g, "_");
-}
-// Decode |encoded| using base64url decoding.
-function base64urlDecode(encoded) {
- return atob(encoded.replace(/\-/g, "+").replace(/\_/g, "/"));
-}
-// Decode |encoded| using base64 to a Uint8Array
-function base64DecodeToUnit8Array(encoded) {
- return new Uint8Array( atob( encoded ).split('').map( function(c){return c.charCodeAt(0);} ) );
-}
-// Clear Key can also support Key IDs Initialization Data.
-// ref: http://w3c.github.io/encrypted-media/keyids-format.html
-// Each parameter is expected to be a key id in an Uint8Array.
-function createKeyIDs() {
- var keyIds = '{"kids":["';
- for (var i = 0; i < arguments.length; i++) {
- if (i != 0) keyIds += '","';
- keyIds += base64urlEncode(arguments[i]);
- }
- keyIds += '"]}';
- return keyIds;
-}
-
-function getSupportedKeySystem() {
- var userAgent = navigator.userAgent.toLowerCase();
- var keysystem = undefined;
- if (userAgent.indexOf('edge') > -1 ) {
- keysystem = 'com.microsoft.playready';
- } else if ( userAgent.indexOf('chrome') > -1 || userAgent.indexOf('firefox') > -1 ) {
- keysystem = 'com.widevine.alpha';
- }
- return keysystem;
-}
-
-function waitForEventAndRunStep(eventName, element, func, stepTest)
-{
- var eventCallback = function(event) {
- if (func)
- func(event);
- }
-
- element.addEventListener(eventName, stepTest.step_func(eventCallback), true);
-}
-
-function waitForEvent(eventName, element) {
- return new Promise(function(resolve) {
- element.addEventListener(eventName, resolve, true);
- })
-}
-
-var consoleDiv = null;
-
-function consoleWrite(text)
-{
- if (!consoleDiv && document.body) {
- consoleDiv = document.createElement('div');
- document.body.appendChild(consoleDiv);
- }
- var span = document.createElement('span');
- span.appendChild(document.createTextNode(text));
- span.appendChild(document.createElement('br'));
- consoleDiv.appendChild(span);
-}
-
-function forceTestFailureFromPromise(test, error, message)
-{
- // Promises convert exceptions into rejected Promises. Since there is
- // currently no way to report a failed test in the test harness, errors
- // are reported using force_timeout().
- if (message)
- consoleWrite(message + ': ' + error.message);
- else if (error)
- consoleWrite(error);
-
- test.force_timeout();
- test.done();
-}
-
-// Returns an array of audioCapabilities that includes entries for a set of
-// codecs that should cover all user agents.
-function getPossibleAudioCapabilities()
-{
- return [
- { contentType: 'audio/mp4; codecs="mp4a.40.2"' },
- { contentType: 'audio/webm; codecs="opus"' },
- ];
-}
-
-// Returns a trivial MediaKeySystemConfiguration that should be accepted,
-// possibly as a subset of the specified capabilities, by all user agents.
-function getSimpleConfiguration()
-{
- return [ {
- initDataTypes : [ 'webm', 'cenc', 'keyids' ],
- audioCapabilities: getPossibleAudioCapabilities()
- } ];
-}
-
-// Returns a MediaKeySystemConfiguration for |initDataType| that should be
-// accepted, possibly as a subset of the specified capabilities, by all
-// user agents.
-function getSimpleConfigurationForInitDataType(initDataType)
-{
- return [ {
- initDataTypes: [ initDataType ],
- audioCapabilities: getPossibleAudioCapabilities()
- } ];
-}
-
-// Returns a promise that is fulfilled with true if |initDataType| is supported,
-// by keysystem or false if not.
-function isInitDataTypeSupported(keysystem,initDataType)
-{
- return navigator.requestMediaKeySystemAccess(
- keysystem, getSimpleConfigurationForInitDataType(initDataType))
- .then(function() { return true; }, function() { return false; });
-}
-
-function getSupportedInitDataTypes( keysystem )
-{
- return [ 'cenc', 'keyids', 'webm' ].filter( isInitDataTypeSupported.bind( null, keysystem ) );
-}
-
-function arrayBufferAsString(buffer)
-{
- var array = [];
- Array.prototype.push.apply( array, new Uint8Array( buffer ) );
- return '0x' + array.map( function( x ) { return x < 16 ? '0'+x.toString(16) : x.toString(16); } ).join('');
-}
-
-function dumpKeyStatuses(keyStatuses)
-{
- var userAgent = navigator.userAgent.toLowerCase();
- if (userAgent.indexOf('edge') === -1) {
- consoleWrite("for (var entry of keyStatuses)");
- for (var entry of keyStatuses) {
- consoleWrite(arrayBufferAsString(entry[0]) + ": " + entry[1]);
- }
- consoleWrite("for (var keyId of keyStatuses.keys())");
- for (var keyId of keyStatuses.keys()) {
- consoleWrite(arrayBufferAsString(keyId));
- }
- consoleWrite("for (var status of keyStatuses.values())");
- for (var status of keyStatuses.values()) {
- consoleWrite(status);
- }
- consoleWrite("for (var entry of keyStatuses.entries())");
- for (var entry of keyStatuses.entries()) {
- consoleWrite(arrayBufferAsString(entry[0]) + ": " + entry[1]);
- }
- consoleWrite("keyStatuses.forEach()");
- keyStatuses.forEach(function(status, keyId) {
- consoleWrite(arrayBufferAsString(keyId) + ": " + status);
- });
- } else {
- consoleWrite("keyStatuses.forEach()");
- keyStatuses.forEach(function(keyId, status) {
- consoleWrite(arrayBufferAsString(keyId) + ": " + status);
- });
- }
-}
-
-// Verify that |keyStatuses| contains just the keys in |keys.expected|
-// and none of the keys in |keys.unexpected|. All keys should have status
-// 'usable'. Example call: verifyKeyStatuses(mediaKeySession.keyStatuses,
-// { expected: [key1], unexpected: [key2] });
-function verifyKeyStatuses(keyStatuses, keys)
-{
- var expected = keys.expected || [];
- var unexpected = keys.unexpected || [];
-
- // |keyStatuses| should have same size as number of |keys.expected|.
- assert_equals(keyStatuses.size, expected.length, "keystatuses should have expected size");
-
- // All |keys.expected| should be found.
- expected.map(function(key) {
- assert_true(keyStatuses.has(key), "keystatuses should have the expected keys");
- assert_equals(keyStatuses.get(key), 'usable', "keystatus value should be 'usable'");
- });
-
- // All |keys.unexpected| should not be found.
- unexpected.map(function(key) {
- assert_false(keyStatuses.has(key), "keystatuses should not have unexpected keys");
- assert_equals(keyStatuses.get(key), undefined, "keystatus for unexpected key should be undefined");
- });
-}
-
-// This function checks that calling |testCase.func| returns a
-// rejected Promise with the error.name equal to
-// |testCase.exception|.
-function test_exception(testCase /*...*/) {
- var func = testCase.func;
- var exception = testCase.exception;
- var args = Array.prototype.slice.call(arguments, 1);
-
- // Currently blink throws for TypeErrors rather than returning
- // a rejected promise (http://crbug.com/359386).
- // FIXME: Remove try/catch once they become failed promises.
- try {
- return func.apply(null, args).then(
- function (result) {
- assert_unreached(format_value(func));
- },
- function (error) {
- assert_equals(error.name, exception, format_value(func));
- assert_not_equals(error.message, "", format_value(func));
- }
- );
- } catch (e) {
- // Only allow 'TypeError' exceptions to be thrown.
- // Everything else should be a failed promise.
- assert_equals('TypeError', exception, format_value(func));
- assert_equals(e.name, exception, format_value(func));
- }
-}
-
-