pg: support host:port for backwards-compatibility

This commit is contained in:
Alex Suraci 2018-11-20 10:22:39 -05:00
parent b1fd2fa8b1
commit 0b856d1a75
2 changed files with 24 additions and 4 deletions

View file

@ -3,6 +3,7 @@ package sql
import ( import (
"database/sql" "database/sql"
"fmt" "fmt"
"net"
"regexp" "regexp"
"strconv" "strconv"
"strings" "strings"
@ -116,12 +117,24 @@ func (p *Postgres) createDataSourceName() string {
addParam("connect_timeout", strconv.Itoa(p.ConnectionTimeout)) addParam("connect_timeout", strconv.Itoa(p.ConnectionTimeout))
if p.Host != "" { // detect host:port for backwards-compatibility
addParam("host", dataSourceStr(p.Host)) host, port, err := net.SplitHostPort(p.Host)
} if err != nil {
// not host:port, probably unix socket or bare address
host = p.Host
if p.Port != 0 { if p.Port != 0 {
addParam("port", strconv.Itoa(int(p.Port))) port = strconv.Itoa(int(p.Port))
}
}
if host != "" {
addParam("host", dataSourceStr(host))
}
if port != "" {
addParam("port", port)
} }
if p.User != "" { if p.User != "" {

View file

@ -119,6 +119,13 @@ func TestCreateDataSourceName(t *testing.T) {
}, },
expected: "connect_timeout=0 host='coreos.com' sslmode='disable'", expected: "connect_timeout=0 host='coreos.com' sslmode='disable'",
}, },
{
description: "with tcp host:port",
input: &Postgres{
Host: "coreos.com:6543",
},
expected: "connect_timeout=0 host='coreos.com' port=6543 sslmode='verify-full'",
},
{ {
description: "with tcp host and port", description: "with tcp host and port",
input: &Postgres{ input: &Postgres{