0
Fork 0
mirror of https://github.com/caddyserver/caddy.git synced 2025-01-13 22:51:08 -05:00

Beginning some tests for the parser

This commit is contained in:
Matthew Holt 2015-05-21 16:31:01 -06:00
parent 5397eef234
commit b37fed4cc8
2 changed files with 66 additions and 7 deletions

View file

@ -257,7 +257,7 @@ func (p *parser) closeCurlyBrace() error {
// standardAddress turns the accepted host and port patterns // standardAddress turns the accepted host and port patterns
// into a format accepted by net.Dial. // into a format accepted by net.Dial.
func standardAddress(str string) (host, port string, err error) { func standardAddress(str string) (host, port string, err error) {
var schemePort string var schemePort, splitPort string
if strings.HasPrefix(str, "https://") { if strings.HasPrefix(str, "https://") {
schemePort = "https" schemePort = "https"
@ -267,14 +267,19 @@ func standardAddress(str string) (host, port string, err error) {
str = str[7:] str = str[7:]
} }
host, port, err = net.SplitHostPort(str) host, splitPort, err = net.SplitHostPort(str)
if err != nil && schemePort == "" { if err != nil {
host, port, err = net.SplitHostPort(str + ":") // tack on empty port host, splitPort, err = net.SplitHostPort(str + ":") // tack on empty port
} }
if err != nil && schemePort != "" { if err != nil {
// ¯\_(ツ)_/¯
host = str host = str
port = schemePort // assume port from scheme }
err = nil
if splitPort != "" {
port = splitPort
} else {
port = schemePort
} }
return return

View file

@ -0,0 +1,54 @@
package parse
import "testing"
func TestStandardAddress(t *testing.T) {
for i, test := range []struct {
input string
host, port string
shouldErr bool
}{
{`localhost`, "localhost", "", false},
{`localhost:1234`, "localhost", "1234", false},
{`localhost:`, "localhost", "", false},
{`0.0.0.0`, "0.0.0.0", "", false},
{`127.0.0.1:1234`, "127.0.0.1", "1234", false},
{`:1234`, "", "1234", false},
{`[::1]`, "::1", "", false},
{`[::1]:1234`, "::1", "1234", false},
{`:`, "", "", false},
{`localhost:http`, "localhost", "http", false},
{`localhost:https`, "localhost", "https", false},
{`:http`, "", "http", false},
{`:https`, "", "https", false},
{`http://localhost`, "localhost", "http", false},
{`https://localhost`, "localhost", "https", false},
{`http://127.0.0.1`, "127.0.0.1", "http", false},
{`https://127.0.0.1`, "127.0.0.1", "https", false},
{`http://[::1]`, "::1", "http", false},
{`http://localhost:1234`, "localhost", "1234", false},
{`https://127.0.0.1:1234`, "127.0.0.1", "1234", false},
{`http://[::1]:1234`, "::1", "1234", false},
{``, "", "", false},
{`::1`, "::1", "", true},
{`localhost::`, "localhost::", "", true},
{`#$%@`, "#$%@", "", true},
} {
host, port, err := standardAddress(test.input)
if err != nil && !test.shouldErr {
t.Errorf("Test %d: Expected no error, but had error: %v", i, err)
}
if err == nil && test.shouldErr {
t.Errorf("Test %d: Expected error, but had none", i)
}
if host != test.host {
t.Errorf("Test %d: Expected host '%s', got '%s'", i, test.host, host)
}
if port != test.port {
t.Errorf("Test %d: Expected port '%s', got '%s'", i, test.port, port)
}
}
}