Test Harness: use ares_timeout() to calculate the value to pass to select() these days. (#555)

The test framework was using 100ms timeout passed to select(), and not using ares_timeout() to calculate the actual recommended value based on the queries in queue. Using ares_timeout() tests the functionality of ares_timeout() itself and will provide more responsive results.

Fix By: Brad House (@bradh352)
pull/557/head
Brad House 1 year ago committed by GitHub
parent fab4039b9b
commit 4d4fb34075
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
  1. 8
      test/ares-test.cc

@ -101,9 +101,11 @@ void ProcessWork(ares_channel channel,
} }
} }
// Wait for activity or timeout. /* If ares_timeout returns NULL, it means there are no requests in queue,
tv.tv_sec = 0; * so we can break out */
tv.tv_usec = 100000; // 100ms if (ares_timeout(channel, NULL, &tv) == NULL)
return;
count = select(nfds, &readers, &writers, nullptr, &tv); count = select(nfds, &readers, &writers, nullptr, &tv);
if (count < 0) { if (count < 0) {
fprintf(stderr, "select() failed, errno %d\n", errno); fprintf(stderr, "select() failed, errno %d\n", errno);

Loading…
Cancel
Save