diff options
Diffstat (limited to 'dom/base/test/test_audioNotification.html')
-rw-r--r-- | dom/base/test/test_audioNotification.html | 71 |
1 files changed, 71 insertions, 0 deletions
diff --git a/dom/base/test/test_audioNotification.html b/dom/base/test/test_audioNotification.html new file mode 100644 index 0000000000..a7f42f106b --- /dev/null +++ b/dom/base/test/test_audioNotification.html @@ -0,0 +1,71 @@ +<!DOCTYPE HTML> +<html> +<head> + <title>Test for audio controller in windows</title> + <script type="application/javascript" src="/tests/SimpleTest/SimpleTest.js"></script> + <link rel="stylesheet" type="text/css" href="/tests/SimpleTest/test.css"/> +</head> +<body> +<pre id="test"> +</pre> + +<script type="application/javascript"> + +SimpleTest.waitForExplicitFinish(); + +var expectedNotification = null; + +var observer = { + observe: function(subject, topic, data) { + is(topic, "audio-playback", "audio-playback received"); + is(data, expectedNotification, "This is the right notification"); + runTest(); + } +}; + +var observerService = SpecialPowers.Cc["@mozilla.org/observer-service;1"] + .getService(SpecialPowers.Ci.nsIObserverService); + +var audio = new Audio(); +audio.src = "audio.ogg"; + +var tests = [ + function() { + observerService.addObserver(observer, "audio-playback", false); + ok(true, "Observer set"); + runTest(); + }, + + function() { + expectedNotification = 'active'; + audio.play(); + }, + + function() { + expectedNotification = 'inactive-pause'; + audio.pause(); + }, + + function() { + observerService.removeObserver(observer, "audio-playback"); + ok(true, "Observer removed"); + runTest(); + } +]; + +function runTest() { + if (!tests.length) { + SimpleTest.finish(); + return; + } + + var test = tests.shift(); + test(); +} + +runTest(); + +</script> +</body> +</html> + |