зеркало из https://github.com/mozilla/gecko-dev.git
Bug 1207546 - Integrate WebRTC with audio channels, r=roc
--HG-- rename : dom/base/test/test_audioNotification.html => dom/base/test/test_audioNotificationStream.html
This commit is contained in:
Родитель
877ef122ef
Коммит
022d787457
|
@ -269,6 +269,8 @@ support-files =
|
||||||
[test_audioWindowUtils.html]
|
[test_audioWindowUtils.html]
|
||||||
[test_audioNotification.html]
|
[test_audioNotification.html]
|
||||||
skip-if = buildapp == 'mulet'
|
skip-if = buildapp == 'mulet'
|
||||||
|
[test_audioNotificationStream.html]
|
||||||
|
skip-if = buildapp == 'mulet'
|
||||||
[test_audioNotificationStopOnNavigation.html]
|
[test_audioNotificationStopOnNavigation.html]
|
||||||
skip-if = buildapp == 'mulet'
|
skip-if = buildapp == 'mulet'
|
||||||
[test_audioNotificationWithEarlyPlay.html]
|
[test_audioNotificationWithEarlyPlay.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.srcObject = (new AudioContext()).createMediaStreamDestination().stream;
|
||||||
|
|
||||||
|
var tests = [
|
||||||
|
function() {
|
||||||
|
observerService.addObserver(observer, "audio-playback", false);
|
||||||
|
ok(true, "Observer set");
|
||||||
|
runTest();
|
||||||
|
},
|
||||||
|
|
||||||
|
function() {
|
||||||
|
expectedNotification = 'active';
|
||||||
|
audio.play();
|
||||||
|
},
|
||||||
|
|
||||||
|
function() {
|
||||||
|
expectedNotification = 'inactive';
|
||||||
|
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>
|
||||||
|
|
|
@ -4730,7 +4730,8 @@ HTMLMediaElement::UpdateAudioChannelPlayingState()
|
||||||
(HasAttr(kNameSpaceID_None, nsGkAtoms::loop) ||
|
(HasAttr(kNameSpaceID_None, nsGkAtoms::loop) ||
|
||||||
(mReadyState >= nsIDOMHTMLMediaElement::HAVE_CURRENT_DATA &&
|
(mReadyState >= nsIDOMHTMLMediaElement::HAVE_CURRENT_DATA &&
|
||||||
!IsPlaybackEnded()) ||
|
!IsPlaybackEnded()) ||
|
||||||
mPlayingThroughTheAudioChannelBeforeSeek));
|
mPlayingThroughTheAudioChannelBeforeSeek ||
|
||||||
|
mSrcAttrStream));
|
||||||
if (playingThroughTheAudioChannel != mPlayingThroughTheAudioChannel) {
|
if (playingThroughTheAudioChannel != mPlayingThroughTheAudioChannel) {
|
||||||
mPlayingThroughTheAudioChannel = playingThroughTheAudioChannel;
|
mPlayingThroughTheAudioChannel = playingThroughTheAudioChannel;
|
||||||
|
|
||||||
|
|
Загрузка…
Ссылка в новой задаче