mirror of
https://github.com/minio/minio.git
synced 2025-01-11 23:13:23 -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 {
|
if !a.Enable {
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
if _, err := checkNetURL(a.URL); err != nil {
|
if _, err := checkURL(a.URL); err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
return nil
|
return nil
|
||||||
|
@ -37,7 +37,7 @@ func (e *elasticSearchNotify) Validate() error {
|
|||||||
if !e.Enable {
|
if !e.Enable {
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
if _, err := checkNetURL(e.URL); err != nil {
|
if _, err := checkURL(e.URL); err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
return nil
|
return nil
|
||||||
|
@ -52,7 +52,7 @@ func (n *natsNotify) Validate() error {
|
|||||||
if !n.Enable {
|
if !n.Enable {
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
if _, err := checkNetURL(n.Address); err != nil {
|
if _, err := checkURL(n.Address); err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
return nil
|
return nil
|
||||||
|
@ -88,7 +88,7 @@ func (p *postgreSQLNotify) Validate() error {
|
|||||||
if !p.Enable {
|
if !p.Enable {
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
if _, err := checkNetURL(p.Host); err != nil {
|
if _, err := checkURL(p.Host); err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
return nil
|
return nil
|
||||||
|
@ -36,7 +36,7 @@ func (r *redisNotify) Validate() error {
|
|||||||
if !r.Enable {
|
if !r.Enable {
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
if _, err := checkNetURL(r.Addr); err != nil {
|
if _, err := checkURL(r.Addr); err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
return nil
|
return nil
|
||||||
|
@ -36,7 +36,7 @@ func (w *webhookNotify) Validate() error {
|
|||||||
if !w.Enable {
|
if !w.Enable {
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
if _, err := checkNetURL(w.Endpoint); err != nil {
|
if _, err := checkURL(w.Endpoint); err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
return nil
|
return nil
|
||||||
|
12
cmd/utils.go
12
cmd/utils.go
@ -19,6 +19,7 @@ package cmd
|
|||||||
import (
|
import (
|
||||||
"encoding/base64"
|
"encoding/base64"
|
||||||
"encoding/xml"
|
"encoding/xml"
|
||||||
|
"errors"
|
||||||
"fmt"
|
"fmt"
|
||||||
"io"
|
"io"
|
||||||
"net/http"
|
"net/http"
|
||||||
@ -263,15 +264,14 @@ func isFile(path string) bool {
|
|||||||
return false
|
return false
|
||||||
}
|
}
|
||||||
|
|
||||||
// checkNetURL - checks if passed address correspond
|
// checkURL - checks if passed address correspond
|
||||||
// to a network address (and not file system path)
|
func checkURL(address string) (*url.URL, error) {
|
||||||
func checkNetURL(address string) (*url.URL, error) {
|
if address == "" {
|
||||||
|
return nil, errors.New("Address cannot be empty")
|
||||||
|
}
|
||||||
u, err := url.Parse(address)
|
u, err := url.Parse(address)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, fmt.Errorf("`%s` invalid: %s", address, err.Error())
|
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
|
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