Fix unit test if there isn't a localhost address (for example FreeBSD jails), second part
parent
a3e2b3e404
commit
8aebc31a17
21
src/test.cpp
21
src/test.cpp
|
@ -1865,9 +1865,24 @@ struct TestConnection: public TestBase
|
|||
Handler hand_server("server");
|
||||
Handler hand_client("client");
|
||||
|
||||
Address address(0, 0, 0, 0, 30001);
|
||||
Address bind_addr(0, 0, 0, 0, 30001);
|
||||
/*
|
||||
* Try to use the bind_address for servers with no localhost address
|
||||
* For example: FreeBSD jails
|
||||
*/
|
||||
std::string bind_str = g_settings->get("bind_address");
|
||||
try {
|
||||
bind_addr.Resolve(bind_str.c_str());
|
||||
|
||||
if (!bind_addr.isIPv6()) {
|
||||
address = bind_addr;
|
||||
}
|
||||
} catch (ResolveError &e) {
|
||||
}
|
||||
|
||||
infostream<<"** Creating server Connection"<<std::endl;
|
||||
con::Connection server(proto_id, 512, 5.0, false, &hand_server);
|
||||
Address address(0,0,0,0, 30001);
|
||||
server.Serve(address);
|
||||
|
||||
infostream<<"** Creating client Connection"<<std::endl;
|
||||
|
@ -1879,6 +1894,10 @@ struct TestConnection: public TestBase
|
|||
sleep_ms(50);
|
||||
|
||||
Address server_address(127, 0, 0, 1, 30001);
|
||||
if (address != Address(0, 0, 0, 0, 30001)) {
|
||||
server_address = bind_addr;
|
||||
}
|
||||
|
||||
infostream<<"** running client.Connect()"<<std::endl;
|
||||
client.Connect(server_address);
|
||||
|
||||
|
|
Loading…
Reference in New Issue