From d46a525aef691f3a11f3f67e53ca5cfb5b487e84 Mon Sep 17 00:00:00 2001 From: Fredrik Ekre Date: Sun, 19 Jun 2022 12:54:52 +0200 Subject: [PATCH] Fix HTTP.listen with provided TCP server Sockets.getsockname returns host as an IPAddr and port as Int, but HTTP.Listener expects host and port as Strings. --- Project.toml | 2 +- src/Servers.jl | 2 +- test/server.jl | 12 ++++++++++++ 3 files changed, 14 insertions(+), 2 deletions(-) diff --git a/Project.toml b/Project.toml index f80399408..e0503dae1 100644 --- a/Project.toml +++ b/Project.toml @@ -1,7 +1,7 @@ name = "HTTP" uuid = "cd3eb016-35fb-5094-929b-558a96fad6f3" authors = ["Jacob Quinn", "contributors: https://github.com/JuliaWeb/HTTP.jl/graphs/contributors"] -version = "1.0.0" +version = "1.0.1" [deps] Base64 = "2a0f44e3-6c83-55bd-87e4-b1978d98bd5f" diff --git a/src/Servers.jl b/src/Servers.jl index e752a7180..3baa0a2bc 100644 --- a/src/Servers.jl +++ b/src/Servers.jl @@ -32,7 +32,7 @@ end function Listener(server::Base.IOServer; sslconfig::Union{MbedTLS.SSLConfig, Nothing}=nothing, kw...) host, port = getsockname(server) addr = getinet(host, port) - return Listener(addr, host, port, sslconfig, server) + return Listener(addr, string(host), string(port), sslconfig, server) end supportsreuseaddr() = ccall(:jl_has_so_reuseport, Int32, ()) == 1 diff --git a/test/server.jl b/test/server.jl index 082d43366..324cd1af3 100644 --- a/test/server.jl +++ b/test/server.jl @@ -162,6 +162,18 @@ const echostreamhandler = HTTP.streamhandler(echohandler) r = HTTP.request("GET", "https://127.0.0.1:8092"; require_ssl_verification = false) @test_throws HTTP.RequestError HTTP.request("GET", "http://127.0.0.1:8092"; require_ssl_verification = false) close(server) + + # HTTP.listen with server kwarg + let host = Sockets.localhost; port = 8093 + server = Sockets.listen(host, port) + HTTP.listen!(Sockets.localhost, 8093; server=server) do http + HTTP.setstatus(http, 200) + HTTP.startwrite(http) + end + r = HTTP.get("http://$(host):$(port)/"; readtimeout=30) + @test r.status == 200 + close(server) + end end # @testset @testset "on_shutdown" begin