Unverified Commit efb15205 authored by Stephan Renatus's avatar Stephan Renatus Committed by GitHub

Merge pull request #1352 from concourse/pr/support-pq-host-port

pg: support host:port for backwards-compatibility
parents d4004380 0b856d1a
......@@ -3,6 +3,7 @@ package sql
import (
"database/sql"
"fmt"
"net"
"regexp"
"strconv"
"strings"
......@@ -116,12 +117,24 @@ func (p *Postgres) createDataSourceName() string {
addParam("connect_timeout", strconv.Itoa(p.ConnectionTimeout))
if p.Host != "" {
addParam("host", dataSourceStr(p.Host))
// detect host:port for backwards-compatibility
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 {
port = strconv.Itoa(int(p.Port))
}
}
if host != "" {
addParam("host", dataSourceStr(host))
}
if p.Port != 0 {
addParam("port", strconv.Itoa(int(p.Port)))
if port != "" {
addParam("port", port)
}
if p.User != "" {
......
......@@ -119,6 +119,13 @@ func TestCreateDataSourceName(t *testing.T) {
},
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",
input: &Postgres{
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment