diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-07 19:33:14 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-07 19:33:14 +0000 |
commit | 36d22d82aa202bb199967e9512281e9a53db42c9 (patch) | |
tree | 105e8c98ddea1c1e4784a60a5a6410fa416be2de /third_party/libwebrtc/rtc_base/test_utils.h | |
parent | Initial commit. (diff) | |
download | firefox-esr-36d22d82aa202bb199967e9512281e9a53db42c9.tar.xz firefox-esr-36d22d82aa202bb199967e9512281e9a53db42c9.zip |
Adding upstream version 115.7.0esr.upstream/115.7.0esr
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'third_party/libwebrtc/rtc_base/test_utils.h')
-rw-r--r-- | third_party/libwebrtc/rtc_base/test_utils.h | 99 |
1 files changed, 99 insertions, 0 deletions
diff --git a/third_party/libwebrtc/rtc_base/test_utils.h b/third_party/libwebrtc/rtc_base/test_utils.h new file mode 100644 index 0000000000..3f877fc9af --- /dev/null +++ b/third_party/libwebrtc/rtc_base/test_utils.h @@ -0,0 +1,99 @@ +/* + * Copyright 2004 The WebRTC Project Authors. All rights reserved. + * + * Use of this source code is governed by a BSD-style license + * that can be found in the LICENSE file in the root of the source + * tree. An additional intellectual property rights grant can be found + * in the file PATENTS. All contributing project authors may + * be found in the AUTHORS file in the root of the source tree. + */ + +#ifndef RTC_BASE_TEST_UTILS_H_ +#define RTC_BASE_TEST_UTILS_H_ + +// Utilities for testing rtc infrastructure in unittests + +#include <map> +#include <utility> + +#include "rtc_base/socket.h" +#include "rtc_base/third_party/sigslot/sigslot.h" + +namespace webrtc { +namespace testing { + +/////////////////////////////////////////////////////////////////////////////// +// StreamSink - Monitor asynchronously signalled events from Socket. +/////////////////////////////////////////////////////////////////////////////// + +// Note: Any event that is an error is treated as SSE_ERROR instead of that +// event. + +enum StreamSinkEvent { + SSE_OPEN = 1, + SSE_READ = 2, + SSE_WRITE = 4, + SSE_CLOSE = 8, + SSE_ERROR = 16 +}; + +class StreamSink : public sigslot::has_slots<> { + public: + StreamSink(); + ~StreamSink() override; + + void Monitor(rtc::Socket* socket) { + socket->SignalConnectEvent.connect(this, &StreamSink::OnConnectEvent); + socket->SignalReadEvent.connect(this, &StreamSink::OnReadEvent); + socket->SignalWriteEvent.connect(this, &StreamSink::OnWriteEvent); + socket->SignalCloseEvent.connect(this, &StreamSink::OnCloseEvent); + // In case you forgot to unmonitor a previous object with this address + events_.erase(socket); + } + void Unmonitor(rtc::Socket* socket) { + socket->SignalConnectEvent.disconnect(this); + socket->SignalReadEvent.disconnect(this); + socket->SignalWriteEvent.disconnect(this); + socket->SignalCloseEvent.disconnect(this); + events_.erase(socket); + } + bool Check(rtc::Socket* socket, StreamSinkEvent event, bool reset = true) { + return DoCheck(socket, event, reset); + } + + private: + typedef std::map<rtc::Socket*, int> EventMap; + + void OnConnectEvent(rtc::Socket* socket) { AddEvents(socket, SSE_OPEN); } + void OnReadEvent(rtc::Socket* socket) { AddEvents(socket, SSE_READ); } + void OnWriteEvent(rtc::Socket* socket) { AddEvents(socket, SSE_WRITE); } + void OnCloseEvent(rtc::Socket* socket, int error) { + AddEvents(socket, (0 == error) ? SSE_CLOSE : SSE_ERROR); + } + + void AddEvents(rtc::Socket* obj, int events) { + EventMap::iterator it = events_.find(obj); + if (events_.end() == it) { + events_.insert(EventMap::value_type(obj, events)); + } else { + it->second |= events; + } + } + bool DoCheck(rtc::Socket* obj, StreamSinkEvent event, bool reset) { + EventMap::iterator it = events_.find(obj); + if ((events_.end() == it) || (0 == (it->second & event))) { + return false; + } + if (reset) { + it->second &= ~event; + } + return true; + } + + EventMap events_; +}; + +} // namespace testing +} // namespace webrtc + +#endif // RTC_BASE_TEST_UTILS_H_ |