mirror of
https://github.com/mollyim/webrtc.git
synced 2025-05-19 00:27:51 +01:00

The input SocketAddress for STUN host lookup is constructed with just the hostname, so the family is AF_UNSPEC. So added an overload with a target family to distinguish this from the family of the input addr. Bug: webrtc:14319, webrtc:14131 Change-Id: Ia5ac5aa2e894e0c4dfb4417e3e8a76a6cec3ea71 Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/270624 Reviewed-by: Tomas Gunnarsson <tommi@webrtc.org> Commit-Queue: Sameer Vijaykar <samvi@google.com> Reviewed-by: Jonas Oreland <jonaso@webrtc.org> Reviewed-by: Jonas Oreland <jonaso@google.com> Cr-Commit-Position: refs/heads/main@{#37750}
57 lines
1.7 KiB
C++
57 lines
1.7 KiB
C++
/*
|
|
* Copyright 2018 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 P2P_BASE_MOCK_ASYNC_RESOLVER_H_
|
|
#define P2P_BASE_MOCK_ASYNC_RESOLVER_H_
|
|
|
|
#include "api/async_resolver_factory.h"
|
|
#include "rtc_base/async_resolver_interface.h"
|
|
#include "test/gmock.h"
|
|
|
|
namespace rtc {
|
|
|
|
using ::testing::_;
|
|
using ::testing::InvokeWithoutArgs;
|
|
|
|
class MockAsyncResolver : public AsyncResolverInterface {
|
|
public:
|
|
MockAsyncResolver() {
|
|
ON_CALL(*this, Start(_)).WillByDefault(InvokeWithoutArgs([this] {
|
|
SignalDone(this);
|
|
}));
|
|
}
|
|
~MockAsyncResolver() = default;
|
|
|
|
MOCK_METHOD(void, Start, (const rtc::SocketAddress&), (override));
|
|
MOCK_METHOD(void, Start, (const rtc::SocketAddress&, int family), (override));
|
|
MOCK_METHOD(bool,
|
|
GetResolvedAddress,
|
|
(int family, SocketAddress* addr),
|
|
(const, override));
|
|
MOCK_METHOD(int, GetError, (), (const, override));
|
|
|
|
// Note that this won't delete the object like AsyncResolverInterface says in
|
|
// order to avoid sanitizer failures caused by this being a synchronous
|
|
// implementation. The test code should delete the object instead.
|
|
MOCK_METHOD(void, Destroy, (bool), (override));
|
|
};
|
|
|
|
} // namespace rtc
|
|
|
|
namespace webrtc {
|
|
|
|
class MockAsyncResolverFactory : public AsyncResolverFactory {
|
|
public:
|
|
MOCK_METHOD(rtc::AsyncResolverInterface*, Create, (), (override));
|
|
};
|
|
|
|
} // namespace webrtc
|
|
|
|
#endif // P2P_BASE_MOCK_ASYNC_RESOLVER_H_
|