diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-07 17:32:43 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-07 17:32:43 +0000 |
commit | 6bf0a5cb5034a7e684dcc3500e841785237ce2dd (patch) | |
tree | a68f146d7fa01f0134297619fbe7e33db084e0aa /dom/media/test/test_clone_media_element.html | |
parent | Initial commit. (diff) | |
download | thunderbird-upstream.tar.xz thunderbird-upstream.zip |
Adding upstream version 1:115.7.0.upstream/1%115.7.0upstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'dom/media/test/test_clone_media_element.html')
-rw-r--r-- | dom/media/test/test_clone_media_element.html | 54 |
1 files changed, 54 insertions, 0 deletions
diff --git a/dom/media/test/test_clone_media_element.html b/dom/media/test/test_clone_media_element.html new file mode 100644 index 0000000000..35e5cd69d0 --- /dev/null +++ b/dom/media/test/test_clone_media_element.html @@ -0,0 +1,54 @@ +<!DOCTYPE HTML> +<html> +<head> + <title>Test: cloned media element should continue to play to the end even after the source of the original element is cleared</title> + <script src="/tests/SimpleTest/SimpleTest.js"></script> + <link rel="stylesheet" type="text/css" href="/tests/SimpleTest/test.css" /> + <script type="text/javascript" src="manifest.js"></script> +</head> +<body> +<pre id="test"> +<script class="testbody" type="text/javascript"> + +// tests must run in sequence otherwise concurrent running test will also +// update media cache which will hide the fact media cache not updated +// after changes in media cache streams. +PARALLEL_TESTS = 1; + +function startTest(test, token) { + manager.started(token); + info("Trying to load " + token); + var v = document.createElement('video'); + v.preload = "metadata"; + v.token = token; + v.src = test.name; + + v.onloadedmetadata = function(evt) { + info(evt.target.token + " metadata loaded."); + evt.target.onloadedmetadata = null; + var clone = evt.target.cloneNode(false); + clone.token = evt.target.token; + clone.play(); + + clone.onloadstart = function(event) { + info("cloned " + event.target.token + " start loading."); + event.target.onloadstart = null; + removeNodeAndSource(v); + } + + clone.onended = function(event) { + ok(true, "cloned " + event.target.token + " ended."); + event.target.onended = null; + removeNodeAndSource(event.target); + manager.finished(event.target.token); + } + } +} + +var manager = new MediaTestManager; +manager.runTests(gSmallTests.concat(gPlayedTests), startTest); + +</script> +</pre> +</body> +</html> |