hbos | b24b1ce | 2016-08-16 01:19:43 -0700 | [diff] [blame] | 1 | /* |
| 2 | * Copyright 2016 The WebRTC project authors. All Rights Reserved. |
| 3 | * |
| 4 | * Use of this source code is governed by a BSD-style license |
| 5 | * that can be found in the LICENSE file in the root of the source |
| 6 | * tree. An additional intellectual property rights grant can be found |
| 7 | * in the file PATENTS. All contributing project authors may |
| 8 | * be found in the AUTHORS file in the root of the source tree. |
| 9 | */ |
| 10 | |
| 11 | #ifndef WEBRTC_API_TEST_MOCK_WEBRTCSESSION_H_ |
| 12 | #define WEBRTC_API_TEST_MOCK_WEBRTCSESSION_H_ |
| 13 | |
| 14 | #include <memory> |
| 15 | #include <string> |
| 16 | |
| 17 | #include "webrtc/api/webrtcsession.h" |
kwiberg | 77eab70 | 2016-09-28 17:42:01 -0700 | [diff] [blame] | 18 | #include "webrtc/test/gmock.h" |
hbos | b24b1ce | 2016-08-16 01:19:43 -0700 | [diff] [blame] | 19 | |
| 20 | namespace webrtc { |
| 21 | |
| 22 | class MockWebRtcSession : public webrtc::WebRtcSession { |
| 23 | public: |
| 24 | // TODO(nisse): Valid overrides commented out, because the gmock |
| 25 | // methods don't use any override declarations, and we want to avoid |
| 26 | // warnings from -Winconsistent-missing-override. See |
| 27 | // http://crbug.com/428099. |
| 28 | explicit MockWebRtcSession(MediaControllerInterface* media_controller) |
| 29 | : WebRtcSession( |
| 30 | media_controller, |
| 31 | rtc::Thread::Current(), |
| 32 | rtc::Thread::Current(), |
| 33 | rtc::Thread::Current(), |
| 34 | nullptr, |
| 35 | std::unique_ptr<cricket::TransportController>( |
| 36 | new cricket::TransportController(rtc::Thread::Current(), |
| 37 | rtc::Thread::Current(), |
| 38 | nullptr))) {} |
| 39 | MOCK_METHOD0(voice_channel, cricket::VoiceChannel*()); |
| 40 | MOCK_METHOD0(video_channel, cricket::VideoChannel*()); |
| 41 | // Libjingle uses "local" for a outgoing track, and "remote" for a incoming |
| 42 | // track. |
| 43 | MOCK_METHOD2(GetLocalTrackIdBySsrc, bool(uint32_t, std::string*)); |
| 44 | MOCK_METHOD2(GetRemoteTrackIdBySsrc, bool(uint32_t, std::string*)); |
| 45 | MOCK_METHOD1(GetTransportStats, bool(SessionStats*)); |
| 46 | MOCK_METHOD2(GetLocalCertificate, |
| 47 | bool(const std::string& transport_name, |
| 48 | rtc::scoped_refptr<rtc::RTCCertificate>* certificate)); |
| 49 | |
| 50 | // Workaround for gmock's inability to cope with move-only return values. |
| 51 | std::unique_ptr<rtc::SSLCertificate> GetRemoteSSLCertificate( |
| 52 | const std::string& transport_name) /* override */ { |
| 53 | return std::unique_ptr<rtc::SSLCertificate>( |
| 54 | GetRemoteSSLCertificate_ReturnsRawPointer(transport_name)); |
| 55 | } |
| 56 | MOCK_METHOD1(GetRemoteSSLCertificate_ReturnsRawPointer, |
| 57 | rtc::SSLCertificate*(const std::string& transport_name)); |
| 58 | }; |
| 59 | |
| 60 | } // namespace webrtc |
| 61 | |
| 62 | #endif // WEBRTC_API_TEST_MOCK_WEBRTCSESSION_H_ |