Chromium Code Reviews| Index: chrome/test/data/webrtc/peerconnection_rtp.js |
| diff --git a/chrome/test/data/webrtc/peerconnection_rtp.js b/chrome/test/data/webrtc/peerconnection_rtp.js |
| index 49962de83fd3615a8b986c5eedbabacba18f1566..858be6ef9264823b57c020cd2f27cca66d3829d7 100644 |
| --- a/chrome/test/data/webrtc/peerconnection_rtp.js |
| +++ b/chrome/test/data/webrtc/peerconnection_rtp.js |
| @@ -45,15 +45,6 @@ function verifyRtpSenders(expectedNumTracks = null) { |
| throw failTest('One getSenders() call is not equal to the next.'); |
| } |
| - let localTracks = new Set(); |
| - peerConnection_().getLocalStreams().forEach(function(stream) { |
| - stream.getTracks().forEach(function(track) { |
| - localTracks.add(track); |
| - }); |
| - }); |
| - if (peerConnection_().getSenders().length != localTracks.size) |
| - throw failTest('The number of senders and tracks are not the same.'); |
| - |
| let senders = new Set(); |
| let senderTracks = new Set(); |
| peerConnection_().getSenders().forEach(function(sender) { |
| @@ -67,10 +58,6 @@ function verifyRtpSenders(expectedNumTracks = null) { |
| if (senderTracks.size != senders.size) |
| throw failTest('senderTracks.size != senders.size'); |
| - if (!setEquals_(senderTracks, localTracks)) { |
| - throw failTest('The set of sender tracks is not equal to the set of ' + |
| - 'stream tracks.'); |
| - } |
| returnToTest('ok-senders-verified'); |
| } |
| @@ -93,15 +80,6 @@ function verifyRtpReceivers(expectedNumTracks = null) { |
| throw failTest('One getReceivers() call is not equal to the next.'); |
| } |
| - let remoteTracks = new Set(); |
| - peerConnection_().getRemoteStreams().forEach(function(stream) { |
| - stream.getTracks().forEach(function(track) { |
| - remoteTracks.add(track); |
| - }); |
| - }); |
| - if (peerConnection_().getReceivers().length != remoteTracks.size) |
| - throw failTest('The number of receivers and tracks are not the same.'); |
| - |
| let receivers = new Set(); |
| let receiverTracks = new Set(); |
| peerConnection_().getReceivers().forEach(function(receiver) { |
| @@ -117,13 +95,162 @@ function verifyRtpReceivers(expectedNumTracks = null) { |
| if (receiverTracks.size != receivers.size) |
| throw failTest('receiverTracks.size != receivers.size'); |
| - if (!setEquals_(receiverTracks, remoteTracks)) { |
| - throw failTest('The set of receiver tracks is not equal to the set of ' + |
| - 'stream tracks.'); |
| - } |
| returnToTest('ok-receivers-verified'); |
| } |
| +/** |
| + * Creates an audio and video track and adds them to the peer connection using |
| + * |addTrack|. They are added with or without a stream in accordance with |
| + * |streamArgumentType|. The test ensures senders are created and parses the SDP |
| + * to determine the resulting stream and track structure is what we expect. In |
| + * the 'no-stream' case the test allows the peer connection to use null streams |
| + * or to advertise streams that are hidden from us. |
| + * |
| + * Returns |
| + * "ok-<audio stream id> <audio track id> <video stream id> <video track id>" on |
| + * success. If no stream is backing up the track, <stream id> is "null". |
| + * |
| + * @param {string} streamArgumentType Must be one of the following values: |
| + * 'no-stream' - The tracks are added without an associated stream. |
| + * 'shared-stream' - The tracks are added with the same associated stream. |
| + * 'individual-streams' - A stream is created for each track. |
| + */ |
| +function createAndAddAudioAndVideoTrack(streamArgumentType) { |
| + if (streamArgumentType !== 'no-stream' && |
| + streamArgumentType !== 'shared-stream' && |
| + streamArgumentType !== 'individual-streams') |
| + throw failTest('Unsupported streamArgumentType.'); |
| + getUserMedia({ audio: true, video: true }, |
| + function(stream) { |
| + let initialSenderCount = peerConnection_().getSenders().length; |
| + let initialLocalStreams = new Set(peerConnection_().getLocalStreams()); |
| + |
| + let audioStream = undefined; |
| + if (streamArgumentType !== 'no-stream') |
| + audioStream = new MediaStream(); |
| + |
| + let audioTrack = stream.getAudioTracks()[0]; |
| + let audioSender = (!audioStream) |
|
Guido Urdaneta
2017/07/06 09:49:57
why "(!audioStream)" and not just "audioStream" ?
hbos_chromium
2017/07/06 12:31:37
Done.
|
| + ? peerConnection_().addTrack(audioTrack) |
| + : peerConnection_().addTrack(audioTrack, audioStream); |
| + if (audioSender.track !== audioTrack) |
| + throw failTest('audioSender.track !== audioTrack'); |
| + |
| + peerConnection_().onnegotiationneeded = function() { |
| + let videoStream = undefined; |
| + if (streamArgumentType === 'shared-stream') { |
| + videoStream = audioStream; |
| + } else if (streamArgumentType === 'individual-streams') { |
| + videoStream = new MediaStream(); |
| + } |
| + |
| + let videoTrack = stream.getVideoTracks()[0]; |
| + let videoSender = (!videoStream) |
|
Guido Urdaneta
2017/07/06 09:49:57
ditto
hbos_chromium
2017/07/06 12:31:37
Donno.
|
| + ? peerConnection_().addTrack(videoTrack) |
| + : peerConnection_().addTrack(videoTrack, videoStream); |
| + if (videoSender.track !== videoTrack) |
| + throw failTest('videoSender.track !== videoTrack'); |
| + |
| + if (peerConnection_().getSenders().length !== |
| + initialSenderCount + 2 || |
| + !peerConnection_().getSenders().includes(audioSender) || |
| + !peerConnection_().getSenders().includes(videoSender)) |
| + throw failTest('Unexpected getSenders() result.'); |
| + |
| + peerConnection_().onnegotiationneeded = function() { |
| + peerConnection_().createOffer().then(function(sessionDecription) { |
| + // TODO(hbos): When |getLocalStreams| is the set of streams of all |
| + // senders the set will be modified to include |addTrack|-streams. |
| + // https://crbug.com/738918 |
| + if (!setEquals_(initialLocalStreams, |
| + new Set(peerConnection_().getLocalStreams()))) |
| + throw failTest('The local stream set was modified.'); |
| + let streamsAndTracks = getSdpStreamsAndTracks( |
| + sessionDecription.sdp); |
| + if (!streamsAndTracks.trackIds.has(audioTrack.id) || |
| + !streamsAndTracks.trackIds.has(videoTrack.id)) |
| + throw failTest('Track ID are missing from the SDP.'); |
| + if (streamsAndTracks.streamIds.has(stream.id)) { |
| + // We never added this stream. |
| + throw failTest( |
| + 'The stream we created shouldn\'t be listed in the SDP.'); |
| + } |
| + let audioStreamId = null; |
| + let videoStreamId = null; |
| + for (let [streamId, trackIds] of |
| + streamsAndTracks.streamTrackMap) { |
| + if (trackIds.has(audioTrack.id)) { |
| + if (audioStreamId != null) { |
| + throw failTest( |
| + 'The audio track was added to multiple streams.'); |
| + } |
| + audioStreamId = streamId; |
| + } |
| + if (trackIds.has(videoTrack.id)) { |
| + if (videoStreamId != null) { |
| + throw failTest( |
| + 'The video track was added to multiple streams.'); |
| + } |
| + videoStreamId = streamId; |
| + } |
| + } |
| + if (audioStreamId == null) |
| + audioStreamId = 'null'; |
| + if (videoStreamId == null) |
| + videoStreamId = 'null'; |
| + if (audioStream && audioStream.id !== audioStreamId) { |
| + throw failTest('Expected audio stream id ' + audioStream.id + |
| + ', but got ' + audioStreamId); |
| + } |
| + if (videoStream && videoStream.id !== videoStreamId) { |
| + throw failTest('Expected video stream id ' + videoStream.id + |
| + ', but got ' + videoStreamId); |
| + } |
| + returnToTest('ok-' + audioStreamId + ' ' + audioTrack.id |
| + + ' ' + videoStreamId + ' ' + videoTrack.id); |
| + }); |
| + }; |
| + }; |
| + }, |
| + function(error) { |
| + throw failTest('getUserMedia failed: ' + error); |
| + }); |
| +} |
| + |
| +/** |
| + * Calls |removeTrack| with the first sender that has the track with |trackId| |
| + * and verifies the SDP is updated accordingly. |
| + * |
| + * Returns "ok-sender-removed" on success. |
| + */ |
| +function removeTrack(trackId) { |
| + let sender = null; |
| + let otherSenderHasTrack = false; |
| + peerConnection_().getSenders().forEach(function(s) { |
| + if (s.track && s.track.id == trackId) { |
| + if (!sender) |
| + sender = s; |
| + else |
| + otherSenderHasTrack = true; |
| + } |
| + }); |
| + if (!sender) |
| + throw failTest('There is no sender for track ' + trackId); |
| + peerConnection_().removeTrack(sender); |
| + if (sender.track) |
| + throw failTest('sender.track was not nulled by removeTrack.'); |
| + peerConnection_().onnegotiationneeded = function() { |
| + peerConnection_().createOffer().then(function(sessionDecription) { |
| + let streamsAndTracks = getSdpStreamsAndTracks(sessionDecription.sdp); |
| + if (!otherSenderHasTrack && streamsAndTracks.trackIds.has(trackId)) |
| + throw failTest('Removing the track did not remove it from the SDP.'); |
| + if (otherSenderHasTrack && !streamsAndTracks.trackIds.has(trackId)) |
| + throw failTest('Track not expected to be removed from the SDP.'); |
| + returnToTest('ok-sender-removed'); |
| + }); |
| + }; |
| +} |
| + |
| // Internals. |
| /** @private */ |