mirror of
https://github.com/minio/minio.git
synced 2025-01-11 15:03:22 -05:00
config: Accept more address format + unit test (#3915)
checkURL() is a generic function to check if a passed address is valid. This commit adds support for addresses like `m1` and `172.16.3.1` which is needed in MySQL and NATS. This commit also adds tests.
This commit is contained in:
parent
f3334159a4
commit
8426cf9aec
@ -44,7 +44,7 @@ func (a *amqpNotify) Validate() error {
|
||||
if !a.Enable {
|
||||
return nil
|
||||
}
|
||||
if _, err := checkNetURL(a.URL); err != nil {
|
||||
if _, err := checkURL(a.URL); err != nil {
|
||||
return err
|
||||
}
|
||||
return nil
|
||||
|
@ -37,7 +37,7 @@ func (e *elasticSearchNotify) Validate() error {
|
||||
if !e.Enable {
|
||||
return nil
|
||||
}
|
||||
if _, err := checkNetURL(e.URL); err != nil {
|
||||
if _, err := checkURL(e.URL); err != nil {
|
||||
return err
|
||||
}
|
||||
return nil
|
||||
|
@ -52,7 +52,7 @@ func (n *natsNotify) Validate() error {
|
||||
if !n.Enable {
|
||||
return nil
|
||||
}
|
||||
if _, err := checkNetURL(n.Address); err != nil {
|
||||
if _, err := checkURL(n.Address); err != nil {
|
||||
return err
|
||||
}
|
||||
return nil
|
||||
|
@ -88,7 +88,7 @@ func (p *postgreSQLNotify) Validate() error {
|
||||
if !p.Enable {
|
||||
return nil
|
||||
}
|
||||
if _, err := checkNetURL(p.Host); err != nil {
|
||||
if _, err := checkURL(p.Host); err != nil {
|
||||
return err
|
||||
}
|
||||
return nil
|
||||
|
@ -36,7 +36,7 @@ func (r *redisNotify) Validate() error {
|
||||
if !r.Enable {
|
||||
return nil
|
||||
}
|
||||
if _, err := checkNetURL(r.Addr); err != nil {
|
||||
if _, err := checkURL(r.Addr); err != nil {
|
||||
return err
|
||||
}
|
||||
return nil
|
||||
|
@ -36,7 +36,7 @@ func (w *webhookNotify) Validate() error {
|
||||
if !w.Enable {
|
||||
return nil
|
||||
}
|
||||
if _, err := checkNetURL(w.Endpoint); err != nil {
|
||||
if _, err := checkURL(w.Endpoint); err != nil {
|
||||
return err
|
||||
}
|
||||
return nil
|
||||
|
12
cmd/utils.go
12
cmd/utils.go
@ -19,6 +19,7 @@ package cmd
|
||||
import (
|
||||
"encoding/base64"
|
||||
"encoding/xml"
|
||||
"errors"
|
||||
"fmt"
|
||||
"io"
|
||||
"net/http"
|
||||
@ -263,15 +264,14 @@ func isFile(path string) bool {
|
||||
return false
|
||||
}
|
||||
|
||||
// checkNetURL - checks if passed address correspond
|
||||
// to a network address (and not file system path)
|
||||
func checkNetURL(address string) (*url.URL, error) {
|
||||
// checkURL - checks if passed address correspond
|
||||
func checkURL(address string) (*url.URL, error) {
|
||||
if address == "" {
|
||||
return nil, errors.New("Address cannot be empty")
|
||||
}
|
||||
u, err := url.Parse(address)
|
||||
if err != nil {
|
||||
return nil, fmt.Errorf("`%s` invalid: %s", address, err.Error())
|
||||
}
|
||||
if u.Host == "" {
|
||||
return nil, fmt.Errorf("`%s` invalid network URL", address)
|
||||
}
|
||||
return u, nil
|
||||
}
|
||||
|
@ -388,3 +388,30 @@ func TestLocalAddress(t *testing.T) {
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
// TestCheckURL tests valid address
|
||||
func TestCheckURL(t *testing.T) {
|
||||
testCases := []struct {
|
||||
addr string
|
||||
shouldPass bool
|
||||
}{
|
||||
{"", false},
|
||||
{":", false},
|
||||
{"localhost", true},
|
||||
{"127.0.0.1", true},
|
||||
{"http://localhost/", true},
|
||||
{"http://127.0.0.1/", true},
|
||||
{"proto://myhostname/path", true},
|
||||
}
|
||||
|
||||
// Validates fetching local address.
|
||||
for i, testCase := range testCases {
|
||||
_, err := checkURL(testCase.addr)
|
||||
if testCase.shouldPass && err != nil {
|
||||
t.Errorf("Test %d: expected to pass but got an error: %v\n", i+1, err)
|
||||
}
|
||||
if !testCase.shouldPass && err == nil {
|
||||
t.Errorf("Test %d: expected to fail but passed.", i+1)
|
||||
}
|
||||
}
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user