| /* |
| * Copyright (C) 2013 Nokia Corporation and/or its subsidiary(-ies). |
| * |
| * Redistribution and use in source and binary forms, with or without |
| * modification, are permitted provided that the following conditions |
| * are met: |
| * 1. Redistributions of source code must retain the above copyright |
| * notice, this list of conditions and the following disclaimer. |
| * 2. Redistributions in binary form must reproduce the above copyright |
| * notice, this list of conditions and the following disclaimer in the |
| * documentation and/or other materials provided with the distribution. |
| * |
| * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS |
| * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT |
| * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR |
| * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT |
| * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, |
| * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT |
| * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, |
| * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY |
| * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT |
| * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE |
| * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
| */ |
| |
| #include "config.h" |
| |
| #if ENABLE(WEB_RTC) |
| |
| #include "RTCPeerConnectionHandlerMock.h" |
| |
| #include "MediaConstraintsMock.h" |
| #include "NotImplemented.h" |
| #include "RTCDTMFSenderHandler.h" |
| #include "RTCDTMFSenderHandlerMock.h" |
| #include "RTCDataChannelHandler.h" |
| #include "RTCDataChannelHandlerMock.h" |
| #include "RTCNotifiersMock.h" |
| #include "RTCSessionDescriptionRequest.h" |
| #include "RTCVoidRequest.h" |
| #include <wtf/text/CString.h> |
| |
| namespace WebCore { |
| |
| std::unique_ptr<RTCPeerConnectionHandler> RTCPeerConnectionHandlerMock::create(RTCPeerConnectionHandlerClient* client) |
| { |
| return std::make_unique<RTCPeerConnectionHandlerMock>(client); |
| } |
| |
| RTCPeerConnectionHandlerMock::RTCPeerConnectionHandlerMock(RTCPeerConnectionHandlerClient* client) |
| : m_client(client) |
| { |
| } |
| |
| bool RTCPeerConnectionHandlerMock::initialize(PassRefPtr<RTCConfigurationPrivate>) |
| { |
| RefPtr<IceConnectionNotifier> notifier = adoptRef(new IceConnectionNotifier(m_client, RTCPeerConnectionHandlerClient::IceConnectionStateCompleted, RTCPeerConnectionHandlerClient::IceGatheringStateComplete)); |
| m_timerEvents.append(adoptRef(new TimerEvent(this, notifier))); |
| return true; |
| } |
| |
| void RTCPeerConnectionHandlerMock::createOffer(PassRefPtr<RTCSessionDescriptionRequest> request, PassRefPtr<RTCOfferOptionsPrivate>) |
| { |
| RefPtr<SessionRequestNotifier> notifier = adoptRef(new SessionRequestNotifier(request, RTCSessionDescriptionDescriptor::create("offer", "local"))); |
| m_timerEvents.append(adoptRef(new TimerEvent(this, notifier))); |
| } |
| |
| void RTCPeerConnectionHandlerMock::createAnswer(PassRefPtr<RTCSessionDescriptionRequest> request, PassRefPtr<RTCOfferAnswerOptionsPrivate>) |
| { |
| RefPtr<SessionRequestNotifier> notifier = adoptRef(new SessionRequestNotifier(request, RTCSessionDescriptionDescriptor::create("answer", "local"))); |
| m_timerEvents.append(adoptRef(new TimerEvent(this, notifier))); |
| } |
| |
| RTCPeerConnectionHandlerClient::SignalingState RTCPeerConnectionHandlerMock::signalingStateFromSDP(RTCSessionDescriptionDescriptor* descriptor) |
| { |
| if (descriptor->type() == "offer" && descriptor->sdp() == "local") |
| return RTCPeerConnectionHandlerClient::SignalingStateHaveLocalOffer; |
| if (descriptor->type() == "offer" && descriptor->sdp() == "remote") |
| return RTCPeerConnectionHandlerClient::SignalingStateHaveRemoteOffer; |
| if (descriptor->type() == "pranswer" && descriptor->sdp() == "local") |
| return RTCPeerConnectionHandlerClient::SignalingStateHaveLocalPrAnswer; |
| if (descriptor->type() == "pranswer" && descriptor->sdp() == "remote") |
| return RTCPeerConnectionHandlerClient::SignalingStateHaveRemotePrAnswer; |
| |
| return RTCPeerConnectionHandlerClient::SignalingStateStable; |
| } |
| |
| void RTCPeerConnectionHandlerMock::setLocalDescription(PassRefPtr<RTCVoidRequest> request, PassRefPtr<RTCSessionDescriptionDescriptor> descriptor) |
| { |
| RefPtr<VoidRequestNotifier> voidNotifier; |
| RefPtr<SignalingStateNotifier> signalingNotifier; |
| if (!descriptor.get() || descriptor->sdp() != "local") |
| voidNotifier = adoptRef(new VoidRequestNotifier(request, false, RTCPeerConnectionHandler::internalErrorName())); |
| else { |
| m_localSessionDescription = descriptor; |
| signalingNotifier = adoptRef(new SignalingStateNotifier(m_client, signalingStateFromSDP(m_localSessionDescription.get()))); |
| voidNotifier = adoptRef(new VoidRequestNotifier(request, true)); |
| m_timerEvents.append(adoptRef(new TimerEvent(this, signalingNotifier))); |
| } |
| |
| m_timerEvents.append(adoptRef(new TimerEvent(this, voidNotifier))); |
| } |
| |
| void RTCPeerConnectionHandlerMock::setRemoteDescription(PassRefPtr<RTCVoidRequest> request, PassRefPtr<RTCSessionDescriptionDescriptor> descriptor) |
| { |
| RefPtr<VoidRequestNotifier> voidNotifier; |
| RefPtr<SignalingStateNotifier> signalingNotifier; |
| if (!descriptor.get() || descriptor->sdp() != "remote") |
| voidNotifier = adoptRef(new VoidRequestNotifier(request, false, RTCPeerConnectionHandler::internalErrorName())); |
| else { |
| m_remoteSessionDescription = descriptor; |
| signalingNotifier = adoptRef(new SignalingStateNotifier(m_client, signalingStateFromSDP(m_remoteSessionDescription.get()))); |
| voidNotifier = adoptRef(new VoidRequestNotifier(request, true)); |
| m_timerEvents.append(adoptRef(new TimerEvent(this, signalingNotifier))); |
| } |
| |
| m_timerEvents.append(adoptRef(new TimerEvent(this, voidNotifier))); |
| } |
| |
| PassRefPtr<RTCSessionDescriptionDescriptor> RTCPeerConnectionHandlerMock::localDescription() |
| { |
| return m_localSessionDescription; |
| } |
| |
| PassRefPtr<RTCSessionDescriptionDescriptor> RTCPeerConnectionHandlerMock::remoteDescription() |
| { |
| return m_remoteSessionDescription; |
| } |
| |
| bool RTCPeerConnectionHandlerMock::updateIce(PassRefPtr<RTCConfigurationPrivate>) |
| { |
| return true; |
| } |
| |
| bool RTCPeerConnectionHandlerMock::addIceCandidate(PassRefPtr<RTCVoidRequest> request, PassRefPtr<RTCIceCandidateDescriptor>) |
| { |
| RefPtr<VoidRequestNotifier> notifier = adoptRef(new VoidRequestNotifier(request, true)); |
| m_timerEvents.append(adoptRef(new TimerEvent(this, notifier))); |
| return true; |
| } |
| |
| bool RTCPeerConnectionHandlerMock::addStream(PassRefPtr<MediaStreamPrivate>) |
| { |
| // Spec states that every time a stream is added, a negotiationneeded event must be fired. |
| m_client->negotiationNeeded(); |
| return true; |
| } |
| |
| void RTCPeerConnectionHandlerMock::removeStream(PassRefPtr<MediaStreamPrivate>) |
| { |
| // Spec states that every time a stream is removed, a negotiationneeded event must be fired. |
| m_client->negotiationNeeded(); |
| } |
| |
| void RTCPeerConnectionHandlerMock::getStats(PassRefPtr<RTCStatsRequest>) |
| { |
| // Current tests does not support getUserMedia and this function requires it. |
| // Once WebKit has test support to getUserMedia, this must be fixed. |
| notImplemented(); |
| } |
| |
| std::unique_ptr<RTCDataChannelHandler> RTCPeerConnectionHandlerMock::createDataChannel(const String& label, const RTCDataChannelInit& init) |
| { |
| RefPtr<RemoteDataChannelNotifier> notifier = adoptRef(new RemoteDataChannelNotifier(m_client)); |
| m_timerEvents.append(adoptRef(new TimerEvent(this, notifier))); |
| return std::make_unique<RTCDataChannelHandlerMock>(label, init); |
| } |
| |
| std::unique_ptr<RTCDTMFSenderHandler> RTCPeerConnectionHandlerMock::createDTMFSender(PassRefPtr<RealtimeMediaSource>) |
| { |
| return std::make_unique<RTCDTMFSenderHandlerMock>(); |
| } |
| |
| void RTCPeerConnectionHandlerMock::stop() |
| { |
| } |
| |
| } // namespace WebCore |
| |
| #endif // ENABLE(WEB_RTC) |