2023-08-22 13:53:16 +00:00
|
|
|
/*
|
|
|
|
|
* Copyright 2023 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.
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
#include "rtc_base/async_dns_resolver.h"
|
|
|
|
|
|
2025-01-17 13:19:45 +00:00
|
|
|
#include <memory>
|
|
|
|
|
|
|
|
|
|
#include "api/test/rtc_error_matchers.h"
|
|
|
|
|
#include "api/units/time_delta.h"
|
|
|
|
|
#include "rtc_base/logging.h"
|
|
|
|
|
#include "rtc_base/net_helpers.h"
|
|
|
|
|
#include "rtc_base/socket_address.h"
|
|
|
|
|
#include "rtc_base/thread.h"
|
|
|
|
|
#include "test/gmock.h"
|
2023-08-22 13:53:16 +00:00
|
|
|
#include "test/gtest.h"
|
|
|
|
|
#include "test/run_loop.h"
|
2025-01-17 13:19:45 +00:00
|
|
|
#include "test/wait_until.h"
|
2023-08-22 13:53:16 +00:00
|
|
|
|
|
|
|
|
namespace webrtc {
|
|
|
|
|
namespace {
|
2025-01-17 13:19:45 +00:00
|
|
|
|
|
|
|
|
using ::testing::IsTrue;
|
|
|
|
|
|
|
|
|
|
const webrtc::TimeDelta kDefaultTimeout = webrtc::TimeDelta::Millis(1000);
|
2023-08-22 13:53:16 +00:00
|
|
|
const int kPortNumber = 3027;
|
|
|
|
|
|
|
|
|
|
TEST(AsyncDnsResolver, ConstructorWorks) {
|
|
|
|
|
AsyncDnsResolver resolver;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
TEST(AsyncDnsResolver, ResolvingLocalhostWorks) {
|
|
|
|
|
test::RunLoop loop; // Ensure that posting back to main thread works
|
|
|
|
|
AsyncDnsResolver resolver;
|
|
|
|
|
rtc::SocketAddress address("localhost",
|
|
|
|
|
kPortNumber); // Port number does not matter
|
|
|
|
|
rtc::SocketAddress resolved_address;
|
|
|
|
|
bool done = false;
|
|
|
|
|
resolver.Start(address, [&done] { done = true; });
|
2025-01-17 13:19:45 +00:00
|
|
|
ASSERT_THAT(
|
|
|
|
|
WaitUntil([&] { return done; }, IsTrue(), {.timeout = kDefaultTimeout}),
|
|
|
|
|
IsRtcOk());
|
2023-08-22 13:53:16 +00:00
|
|
|
EXPECT_EQ(resolver.result().GetError(), 0);
|
2023-08-24 08:54:28 +00:00
|
|
|
if (resolver.result().GetResolvedAddress(AF_INET, &resolved_address)) {
|
|
|
|
|
EXPECT_EQ(resolved_address, rtc::SocketAddress("127.0.0.1", kPortNumber));
|
|
|
|
|
} else {
|
|
|
|
|
RTC_LOG(LS_INFO) << "Resolution gave no address, skipping test";
|
|
|
|
|
}
|
2023-08-22 13:53:16 +00:00
|
|
|
}
|
|
|
|
|
|
2023-09-02 05:26:55 +00:00
|
|
|
TEST(AsyncDnsResolver, ResolveAfterDeleteDoesNotReturn) {
|
|
|
|
|
test::RunLoop loop;
|
|
|
|
|
std::unique_ptr<AsyncDnsResolver> resolver =
|
|
|
|
|
std::make_unique<AsyncDnsResolver>();
|
|
|
|
|
rtc::SocketAddress address("localhost",
|
|
|
|
|
kPortNumber); // Port number does not matter
|
|
|
|
|
rtc::SocketAddress resolved_address;
|
|
|
|
|
bool done = false;
|
|
|
|
|
resolver->Start(address, [&done] { done = true; });
|
|
|
|
|
resolver.reset(); // Deletes resolver.
|
|
|
|
|
rtc::Thread::Current()->SleepMs(1); // Allows callback to execute
|
|
|
|
|
EXPECT_FALSE(done); // Expect no result.
|
|
|
|
|
}
|
|
|
|
|
|
2023-08-22 13:53:16 +00:00
|
|
|
} // namespace
|
|
|
|
|
} // namespace webrtc
|