From 2b012c2e16d85848664c7046b5cf47dea4baf8de Mon Sep 17 00:00:00 2001 From: Joseph Woodward Date: Wed, 17 Jul 2024 14:47:48 +0100 Subject: [PATCH] [IMPROVED] Trim trailing slash if set on server address which causes errors during look up (#1654) --- nats.go | 2 +- nats_test.go | 4 ++++ 2 files changed, 5 insertions(+), 1 deletion(-) diff --git a/nats.go b/nats.go index d019cee49..e4faa7495 100644 --- a/nats.go +++ b/nats.go @@ -1513,7 +1513,7 @@ func processUrlString(url string) []string { urls := strings.Split(url, ",") var j int for _, s := range urls { - u := strings.TrimSpace(s) + u := strings.TrimSuffix(strings.TrimSpace(s), "/") if len(u) > 0 { urls[j] = u j++ diff --git a/nats_test.go b/nats_test.go index 7dcdce2cf..e64c80133 100644 --- a/nats_test.go +++ b/nats_test.go @@ -229,6 +229,7 @@ func TestSimplifiedURLs(t *testing.T) { { "nats", []string{ + "nats://host1:1234/", "nats://host1:1234", "nats://host2:", "nats://host3", @@ -242,6 +243,7 @@ func TestSimplifiedURLs(t *testing.T) { "[17:18:19:20]:1234", }, []string{ + "nats://host1:1234/", "nats://host1:1234", "nats://host2:4222", "nats://host3:4222", @@ -434,6 +436,7 @@ func TestUrlArgument(t *testing.T) { check("nats://localhost:1222 ", oneExpected) check(" nats://localhost:1222", oneExpected) check(" nats://localhost:1222 ", oneExpected) + check("nats://localhost:1222/", oneExpected) var multiExpected = []string{ "nats://localhost:1222", @@ -445,6 +448,7 @@ func TestUrlArgument(t *testing.T) { check("nats://localhost:1222, nats://localhost:1223, nats://localhost:1224", multiExpected) check(" nats://localhost:1222, nats://localhost:1223, nats://localhost:1224 ", multiExpected) check("nats://localhost:1222, nats://localhost:1223 ,nats://localhost:1224", multiExpected) + check("nats://localhost:1222/,nats://localhost:1223/,nats://localhost:1224/", multiExpected) } func TestParserPing(t *testing.T) {