Commit f91d5dcf authored by Kenton Varda's avatar Kenton Varda

Fix bug in async-io-test.c++ where several tests were always skipped.

parent 8777008e
...@@ -77,12 +77,13 @@ String tryParse(WaitScope& waitScope, Network& network, StringPtr text, uint por ...@@ -77,12 +77,13 @@ String tryParse(WaitScope& waitScope, Network& network, StringPtr text, uint por
return network.parseAddress(text, portHint).wait(waitScope)->toString(); return network.parseAddress(text, portHint).wait(waitScope)->toString();
} }
bool systemSupportsAddress(StringPtr addr) { bool systemSupportsAddress(StringPtr addr, StringPtr service = nullptr) {
// Can getaddrinfo() parse this addresses? This is only true if the address family (e.g., ipv6) // Can getaddrinfo() parse this addresses? This is only true if the address family (e.g., ipv6)
// is configured on at least one interface. (The loopback interface usually has both ipv4 and // is configured on at least one interface. (The loopback interface usually has both ipv4 and
// ipv6 configured, but not always.) // ipv6 configured, but not always.)
struct addrinfo* list; struct addrinfo* list;
int status = getaddrinfo(addr.cStr(), nullptr, nullptr, &list); int status = getaddrinfo(
addr.cStr(), service == nullptr ? nullptr : service.cStr(), nullptr, &list);
if (status == 0) { if (status == 0) {
freeaddrinfo(list); freeaddrinfo(list);
return true; return true;
...@@ -91,7 +92,6 @@ bool systemSupportsAddress(StringPtr addr) { ...@@ -91,7 +92,6 @@ bool systemSupportsAddress(StringPtr addr) {
} }
} }
TEST(AsyncIo, AddressParsing) { TEST(AsyncIo, AddressParsing) {
auto ioContext = setupAsyncIo(); auto ioContext = setupAsyncIo();
auto& w = ioContext.waitScope; auto& w = ioContext.waitScope;
...@@ -110,7 +110,7 @@ TEST(AsyncIo, AddressParsing) { ...@@ -110,7 +110,7 @@ TEST(AsyncIo, AddressParsing) {
// We can parse services by name... // We can parse services by name...
// //
// For some reason, Android and some various Linux distros do not support service names. // For some reason, Android and some various Linux distros do not support service names.
if (systemSupportsAddress("1.2.3.4:http")) { if (systemSupportsAddress("1.2.3.4", "http")) {
EXPECT_EQ("1.2.3.4:80", tryParse(w, network, "1.2.3.4:http", 5678)); EXPECT_EQ("1.2.3.4:80", tryParse(w, network, "1.2.3.4:http", 5678));
EXPECT_EQ("*:80", tryParse(w, network, "*:http", 5678)); EXPECT_EQ("*:80", tryParse(w, network, "*:http", 5678));
} else { } else {
...@@ -122,7 +122,7 @@ TEST(AsyncIo, AddressParsing) { ...@@ -122,7 +122,7 @@ TEST(AsyncIo, AddressParsing) {
if (systemSupportsAddress("::")) { if (systemSupportsAddress("::")) {
EXPECT_EQ("[::]:123", tryParse(w, network, "0::0", 123)); EXPECT_EQ("[::]:123", tryParse(w, network, "0::0", 123));
EXPECT_EQ("[12ab:cd::34]:321", tryParse(w, network, "[12ab:cd:0::0:34]:321", 432)); EXPECT_EQ("[12ab:cd::34]:321", tryParse(w, network, "[12ab:cd:0::0:34]:321", 432));
if (systemSupportsAddress("[12ab:cd::34]:http")) { if (systemSupportsAddress("12ab:cd::34", "http")) {
EXPECT_EQ("[::]:80", tryParse(w, network, "[::]:http", 5678)); EXPECT_EQ("[::]:80", tryParse(w, network, "[::]:http", 5678));
EXPECT_EQ("[12ab:cd::34]:80", tryParse(w, network, "[12ab:cd::34]:http", 5678)); EXPECT_EQ("[12ab:cd::34]:80", tryParse(w, network, "[12ab:cd::34]:http", 5678));
} else { } else {
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment