mirror of
https://github.com/mozilla/gecko-dev.git
synced 2025-01-26 23:23:33 +00:00
Bug 796892 - Create Mochitest for Audio only connection (send/disconnect). r=jesup
--HG-- extra : rebase_source : 3bb5261272dd2cb69f51811273a3ed723fcdc0bf
This commit is contained in:
parent
c844b04c48
commit
06aa691210
@ -25,6 +25,7 @@ ifdef MOZ_WEBRTC_LEAKING_TESTS
|
||||
MOCHITEST_FILES += \
|
||||
test_getUserMedia_basicAudio.html \
|
||||
test_getUserMedia_basicVideoAudio.html \
|
||||
test_peerConnection_basicAudio.html \
|
||||
test_peerConnection_basicVideo.html \
|
||||
$(NULL)
|
||||
endif
|
||||
|
110
dom/media/tests/mochitest/test_peerConnection_basicAudio.html
Normal file
110
dom/media/tests/mochitest/test_peerConnection_basicAudio.html
Normal file
@ -0,0 +1,110 @@
|
||||
<!DOCTYPE HTML>
|
||||
<html>
|
||||
<!--
|
||||
https://bugzilla.mozilla.org/show_bug.cgi?id=796892
|
||||
-->
|
||||
<head>
|
||||
<meta charset="utf-8">
|
||||
<title>Basic audio-only peer connection</title>
|
||||
<link rel="stylesheet" type="text/css" href="/tests/SimpleTest/test.css"/>
|
||||
<script type="application/javascript" src="/tests/SimpleTest/SimpleTest.js"></script>
|
||||
<script type="application/javascript" src="head.js"></script>
|
||||
<script type="application/javascript" src="pc.js"></script>
|
||||
</head>
|
||||
<body>
|
||||
<a target="_blank" href="https://bugzilla.mozilla.org/show_bug.cgi?id=796888">Basic audio-only peer connection</a>
|
||||
<p id="display"></p>
|
||||
<div id="content" style="">
|
||||
<audio id="audioPCLocal" controls></audio>
|
||||
<audio id="audioPCRemote" controls></audio>
|
||||
<audio id="audioLocal" controls></audio>
|
||||
</div>
|
||||
<pre id="test">
|
||||
<script type="application/javascript">
|
||||
var audioLocal;
|
||||
var audioPCLocal;
|
||||
var audioPCRemote;
|
||||
|
||||
var pcLocal;
|
||||
var pcRemote;
|
||||
|
||||
var test_data = {
|
||||
pcLocal: { audio: [], video: []},
|
||||
pcRemote: { audio: [], video: []}
|
||||
};
|
||||
|
||||
runTest(function () {
|
||||
audioLocal = document.getElementById("audioLocal");
|
||||
audioPCLocal = document.getElementById("audioPCLocal");
|
||||
audioPCRemote = document.getElementById("audioPCRemote");
|
||||
|
||||
pcLocal = new mozRTCPeerConnection();
|
||||
pcRemote = new mozRTCPeerConnection();
|
||||
|
||||
pcLocal.onaddstream = function (aObj) {
|
||||
test_data.pcLocal[aObj.type].push(aObj.stream);
|
||||
|
||||
if (aObj.type === "audio") {
|
||||
audioPCRemote.mozSrcObject = aObj.stream;
|
||||
audioPCRemote.play();
|
||||
}
|
||||
};
|
||||
|
||||
pcRemote.onaddstream = function (aObj) {
|
||||
test_data.pcRemote[aObj.type].push(aObj.stream);
|
||||
|
||||
if (aObj.type === "audio") {
|
||||
audioPCLocal.mozSrcObject = aObj.stream;
|
||||
audioPCLocal.play();
|
||||
}
|
||||
};
|
||||
|
||||
navigator.mozGetUserMedia({audio: true, fake: true}, function onSuccess(aLocalInputStream) {
|
||||
pcLocal.addStream(aLocalInputStream);
|
||||
|
||||
navigator.mozGetUserMedia({audio: true, fake: true}, function onSuccess(aRemoteInputStream) {
|
||||
pcRemote.addStream(aRemoteInputStream);
|
||||
|
||||
audioLocal.mozSrcObject = aLocalInputStream;
|
||||
audioLocal.play();
|
||||
|
||||
PeerConnection.handShake(pcLocal, pcRemote, function () {
|
||||
is(pcLocal.localStreams.length, 1,
|
||||
"A single local stream has been attached to the local peer");
|
||||
is(pcRemote.localStreams.length, 1,
|
||||
"A single local stream has been attached to the remote peer");
|
||||
|
||||
// Bug 816780 - onaddstream() gets called twice even if only audio or audio is requested
|
||||
is(test_data.pcLocal.audio.length, 1,
|
||||
"A remote audio stream has been attached to the local peer");
|
||||
todo_is(test_data.pcLocal.video.length, 0,
|
||||
"No remote video stream has been attached to the local peer");
|
||||
is(test_data.pcRemote.audio.length, 1,
|
||||
"A remote audio stream has been attached to the remote peer");
|
||||
todo_is(test_data.pcRemote.video.length, 0,
|
||||
"No remote video stream has been attached to the remote peer");
|
||||
|
||||
is(test_data.pcLocal.audio[0], pcLocal.remoteStreams[0],
|
||||
"Remote stream for local peer is accessible");
|
||||
is(test_data.pcRemote.audio[0], pcRemote.remoteStreams[0],
|
||||
"Remote stream for remote peer is accessible");
|
||||
|
||||
info("For now simply disconnect. We will add checks for media in a follow-up bug");
|
||||
disconnect();
|
||||
});
|
||||
}, unexpectedCallbackAndFinish);
|
||||
}, unexpectedCallbackAndFinish);
|
||||
});
|
||||
|
||||
function disconnect() {
|
||||
pcLocal.close();
|
||||
pcRemote.close();
|
||||
|
||||
info("We can't run any checks and clean-up code due to a crash (see bug 820072)");
|
||||
|
||||
SimpleTest.finish();
|
||||
}
|
||||
</script>
|
||||
</pre>
|
||||
</body>
|
||||
</html>
|
@ -30,8 +30,8 @@ https://bugzilla.mozilla.org/show_bug.cgi?id=796888
|
||||
var pcRemote;
|
||||
|
||||
var test_data = {
|
||||
pcLocal: [],
|
||||
pcRemote: []
|
||||
pcLocal: { audio: [], video: []},
|
||||
pcRemote: { audio: [], video: []}
|
||||
};
|
||||
|
||||
runTest(function () {
|
||||
@ -43,7 +43,7 @@ https://bugzilla.mozilla.org/show_bug.cgi?id=796888
|
||||
pcRemote = new mozRTCPeerConnection();
|
||||
|
||||
pcLocal.onaddstream = function (aObj) {
|
||||
test_data['pcLocal'].push(aObj);
|
||||
test_data.pcLocal[aObj.type].push(aObj.stream);
|
||||
|
||||
if (aObj.type === "video") {
|
||||
videoPCRemote.mozSrcObject = aObj.stream;
|
||||
@ -52,7 +52,7 @@ https://bugzilla.mozilla.org/show_bug.cgi?id=796888
|
||||
};
|
||||
|
||||
pcRemote.onaddstream = function (aObj) {
|
||||
test_data['pcRemote'].push(aObj);
|
||||
test_data.pcRemote[aObj.type].push(aObj.stream);
|
||||
|
||||
if (aObj.type === "video") {
|
||||
videoPCLocal.mozSrcObject = aObj.stream;
|
||||
@ -70,17 +70,25 @@ https://bugzilla.mozilla.org/show_bug.cgi?id=796888
|
||||
videoLocal.play();
|
||||
|
||||
PeerConnection.handShake(pcLocal, pcRemote, function () {
|
||||
is(pcLocal.localStreams.length, 1, "A single local stream has been attached to the local peer");
|
||||
is(pcRemote.localStreams.length, 1, "A single local stream has been attached to the remote peer");
|
||||
is(pcLocal.localStreams.length, 1,
|
||||
"A single local stream has been attached to the local peer");
|
||||
is(pcRemote.localStreams.length, 1,
|
||||
"A single local stream has been attached to the remote peer");
|
||||
|
||||
// Bug 816780 - onaddstream() gets called twice even if only video or audio is requested
|
||||
todo_is(test_data.pcLocal.length, 1, "Only one stream has been attached to the local peer");
|
||||
todo_is(test_data.pcLocal[0].type, "video", "Video stream has been attached to the local peer");
|
||||
todo_is(test_data.pcRemote.length, 1, "Only one stream has been attached to the remote peer");
|
||||
todo_is(test_data.pcRemote[0].type, "video", "Video stream has been attached to the remote peer");
|
||||
is(test_data.pcLocal.video.length, 1,
|
||||
"A remote audio stream has been attached to the local peer");
|
||||
todo_is(test_data.pcLocal.audio.length, 0,
|
||||
"No remote video stream has been attached to the local peer");
|
||||
is(test_data.pcRemote.video.length, 1,
|
||||
"A remote audio stream has been attached to the remote peer");
|
||||
todo_is(test_data.pcRemote.audio.length, 0,
|
||||
"No remote video stream has been attached to the remote peer");
|
||||
|
||||
is(test_data.pcLocal[0].stream, pcLocal.remoteStreams[0], "Remote stream for local peer is accessible");
|
||||
is(test_data.pcRemote[0].stream, pcRemote.remoteStreams[0], "Remote stream for remote peer is accessible");
|
||||
todo_is(test_data.pcLocal.video[0], pcLocal.remoteStreams[0],
|
||||
"Remote stream for local peer is accessible");
|
||||
todo_is(test_data.pcRemote.video[0], pcRemote.remoteStreams[0],
|
||||
"Remote stream for remote peer is accessible");
|
||||
|
||||
info("For now simply disconnect. We will add checks for media in a follow-up bug");
|
||||
disconnect();
|
||||
|
Loading…
x
Reference in New Issue
Block a user