mirror of
https://github.com/FairRootGroup/FairMQ.git
synced 2025-10-12 16:21:13 +00:00
fix(tools): No longer use removed query
API
Deprecated via74fe2b8e14
and removed viae916bdfb1a
in Boost 1.87 or Asio 1.33.
This commit is contained in:
parent
41c6daaabb
commit
9297efb900
|
@ -1,5 +1,5 @@
|
|||
/********************************************************************************
|
||||
* Copyright (C) 2017-2021 GSI Helmholtzzentrum fuer Schwerionenforschung GmbH *
|
||||
* Copyright (C) 2017-2025 GSI Helmholtzzentrum fuer Schwerionenforschung GmbH *
|
||||
* *
|
||||
* This software is distributed under the terms of the *
|
||||
* GNU Lesser General Public Licence (LGPL) version 3, *
|
||||
|
@ -8,12 +8,12 @@
|
|||
|
||||
#include <fairlogger/Logger.h>
|
||||
#include <fairmq/tools/Network.h>
|
||||
#include <fairmq/tools/Strings.h>
|
||||
|
||||
#ifndef _GNU_SOURCE
|
||||
#define _GNU_SOURCE // To get defns of NI_MAXSERV and NI_MAXHOST
|
||||
#endif
|
||||
|
||||
#include <algorithm>
|
||||
#include <array>
|
||||
#include <boost/algorithm/string.hpp> // trim
|
||||
#include <boost/asio.hpp>
|
||||
|
@ -158,33 +158,22 @@ string getDefaultRouteNetworkInterface()
|
|||
}
|
||||
|
||||
string getIpFromHostname(const string& hostname)
|
||||
{
|
||||
try {
|
||||
boost::asio::io_context ioc;
|
||||
boost::asio::ip::tcp::resolver resolver(ioc);
|
||||
|
||||
using namespace boost::asio::ip;
|
||||
|
||||
try {
|
||||
tcp::resolver resolver(ioc);
|
||||
tcp::resolver::query query(hostname, "");
|
||||
tcp::resolver::iterator end;
|
||||
|
||||
auto it = find_if(static_cast<basic_resolver_iterator<tcp>>(resolver.resolve(query)),
|
||||
end,
|
||||
[](const tcp::endpoint& ep) { return ep.address().is_v4(); });
|
||||
|
||||
if (it != end) {
|
||||
stringstream ss;
|
||||
ss << static_cast<tcp::endpoint>(*it).address();
|
||||
return ss.str();
|
||||
}
|
||||
auto const result = resolver.resolve(boost::asio::ip::tcp::v4(), hostname, "");
|
||||
|
||||
if (result.empty()) {
|
||||
LOG(warn) << "could not find ipv4 address for hostname '" << hostname << "'";
|
||||
|
||||
return "";
|
||||
} catch (exception& e) {
|
||||
LOG(error) << "could not resolve hostname '" << hostname << "', reason: " << e.what();
|
||||
return "";
|
||||
}
|
||||
return ToString(result.begin()->endpoint().address());
|
||||
}
|
||||
catch (std::exception const& ex)
|
||||
{
|
||||
LOG(error) << "could not resolve hostname '" << hostname << "', reason: " << ex.what();
|
||||
return "";
|
||||
}
|
||||
|
||||
} // namespace fair::mq::tools
|
||||
|
|
|
@ -253,7 +253,7 @@ add_testsuite(Tools
|
|||
LINKS FairMQ
|
||||
INCLUDES ${CMAKE_CURRENT_SOURCE_DIR}
|
||||
${CMAKE_CURRENT_BINARY_DIR}
|
||||
TIMEOUT 20
|
||||
TIMEOUT 5
|
||||
${environment}
|
||||
)
|
||||
|
||||
|
|
|
@ -1,28 +1,37 @@
|
|||
/********************************************************************************
|
||||
* Copyright (C) 2018 GSI Helmholtzzentrum fuer Schwerionenforschung GmbH *
|
||||
* Copyright (C) 2018-2025 GSI Helmholtzzentrum fuer Schwerionenforschung GmbH *
|
||||
* *
|
||||
* This software is distributed under the terms of the *
|
||||
* GNU Lesser General Public Licence (LGPL) version 3, *
|
||||
* copied verbatim in the file "LICENSE" *
|
||||
********************************************************************************/
|
||||
|
||||
#include <gtest/gtest.h>
|
||||
#include <fairmq/tools/Network.h>
|
||||
|
||||
#include <gtest/gtest.h>
|
||||
#include <string>
|
||||
|
||||
namespace
|
||||
{
|
||||
|
||||
using namespace std;
|
||||
using namespace fair::mq;
|
||||
|
||||
TEST(Tools, Network)
|
||||
TEST(Tools, NetworkDefaultIP)
|
||||
{
|
||||
string interface = fair::mq::tools::getDefaultRouteNetworkInterface();
|
||||
auto const interface = fair::mq::tools::getDefaultRouteNetworkInterface();
|
||||
EXPECT_NE(interface, "");
|
||||
string interfaceIP = fair::mq::tools::getInterfaceIP(interface);
|
||||
auto const interfaceIP = fair::mq::tools::getInterfaceIP(interface);
|
||||
EXPECT_NE(interfaceIP, "");
|
||||
}
|
||||
|
||||
TEST(Tools, NetworkIPv4Localhost)
|
||||
{
|
||||
auto const ip = fair::mq::tools::getIpFromHostname("localhost");
|
||||
EXPECT_FALSE(ip.empty());
|
||||
EXPECT_EQ(ip, "127.0.0.1");
|
||||
}
|
||||
|
||||
TEST(Tools, NetworkInvalidHostname)
|
||||
{
|
||||
auto const ip = fair::mq::tools::getIpFromHostname("non.existent.domain.invalid");
|
||||
EXPECT_TRUE(ip.empty());
|
||||
}
|
||||
|
||||
} /* namespace */
|
||||
|
|
Loading…
Reference in New Issue
Block a user