summaryrefslogtreecommitdiffstats
path: root/src/lib
diff options
context:
space:
mode:
authorMarcin Siodelski <marcin@isc.org>2018-05-14 16:59:16 +0200
committerMarcin Siodelski <marcin@isc.org>2018-05-14 16:59:16 +0200
commitd55053a832db1637af11438328bcfc1506f33ea4 (patch)
tree724ddce515e26e49cc88baf5466f92576a2cde16 /src/lib
parent[5620] Added Url method for retrieving stripped hostname (diff)
downloadkea-d55053a832db1637af11438328bcfc1506f33ea4.tar.xz
kea-d55053a832db1637af11438328bcfc1506f33ea4.zip
[5620] Http client uses stripped IPv6 address.
Diffstat (limited to 'src/lib')
-rw-r--r--src/lib/http/client.cc3
-rw-r--r--src/lib/http/tests/server_client_unittests.cc15
2 files changed, 11 insertions, 7 deletions
diff --git a/src/lib/http/client.cc b/src/lib/http/client.cc
index d433136aa3..5b0da858e2 100644
--- a/src/lib/http/client.cc
+++ b/src/lib/http/client.cc
@@ -445,7 +445,8 @@ Connection::doTransaction(const HttpRequestPtr& request,
/// @todo We're getting a hostname but in fact it is expected to be an IP address.
/// We should extend the TCPEndpoint to also accept names. Currently, it will fall
/// over for names.
- TCPEndpoint endpoint(url_.getHostname(), static_cast<unsigned short>(url_.getPort()));
+ TCPEndpoint endpoint(url_.getStrippedHostname(),
+ static_cast<unsigned short>(url_.getPort()));
SocketCallback socket_cb(boost::bind(&Connection::connectCallback, shared_from_this(),
request_timeout, _1));
diff --git a/src/lib/http/tests/server_client_unittests.cc b/src/lib/http/tests/server_client_unittests.cc
index 8415724ec5..ebb5e03f50 100644
--- a/src/lib/http/tests/server_client_unittests.cc
+++ b/src/lib/http/tests/server_client_unittests.cc
@@ -38,6 +38,9 @@ namespace {
/// @brief IP address to which HTTP service is bound.
const std::string SERVER_ADDRESS = "127.0.0.1";
+/// @brief IPv6 address to whch HTTP service is bound.
+const std::string IPV6_SERVER_ADDRESS = "::1";
+
/// @brief Port number to which HTTP service is bound.
const unsigned short SERVER_PORT = 18123;
@@ -507,6 +510,7 @@ TEST_F(HttpListenerTest, listen) {
io_service_.poll();
}
+
// This test verifies that persistent HTTP connection can be established when
// "Conection: Keep-Alive" header value is specified.
TEST_F(HttpListenerTest, keepAlive) {
@@ -899,7 +903,7 @@ public:
listener_(io_service_, IOAddress(SERVER_ADDRESS), SERVER_PORT,
factory_, HttpListener::RequestTimeout(REQUEST_TIMEOUT),
HttpListener::IdleTimeout(IDLE_TIMEOUT)),
- listener2_(io_service_, IOAddress(SERVER_ADDRESS), SERVER_PORT + 1,
+ listener2_(io_service_, IOAddress(IPV6_SERVER_ADDRESS), SERVER_PORT + 1,
factory_, HttpListener::RequestTimeout(REQUEST_TIMEOUT),
HttpListener::IdleTimeout(IDLE_TIMEOUT)),
listener3_(io_service_, IOAddress(SERVER_ADDRESS), SERVER_PORT + 2,
@@ -1036,7 +1040,7 @@ TEST_F(HttpClientTest, multipleDestinations) {
// Specify the URLs on which the servers are available.
Url url1("http://127.0.0.1:18123");
- Url url2("http://127.0.0.1:18124");
+ Url url2("http://[::1]:18124");
// Create a request to the first server.
PostHttpRequestJsonPtr request1 = createRequest("sequence", 1);
@@ -1179,11 +1183,10 @@ TEST_F(HttpClientTest, malformedResponse) {
// content type.
PostHttpRequestJsonPtr request = createRequest("requested-content-type", "text/html");
HttpResponseJsonPtr response(new HttpResponseJson());
- unsigned resp_num = 0;
ASSERT_NO_THROW(client.asyncSendRequest(url, request, response,
- [this, &resp_num](const boost::system::error_code& ec,
- const HttpResponsePtr& response,
- const std::string& parsing_error) {
+ [this](const boost::system::error_code& ec,
+ const HttpResponsePtr& response,
+ const std::string& parsing_error) {
io_service_.stop();
// There should be no IO error (answer from the server is received).
EXPECT_FALSE(ec);