More tests coverage for client.go

This commit is contained in:
Winni Neessen 2022-03-15 21:48:36 +01:00
parent d17decfdc2
commit fe3925c1e6
Signed by: wneessen
GPG key ID: 5F3AF39B820C119D
2 changed files with 37 additions and 25 deletions

View file

@ -133,7 +133,6 @@ func NewClient(h string, o ...Option) (*Client, error) {
// Some settings in a Client cannot be empty/unset
if c.host == "" {
return c, ErrNoHostname
}
return c, nil

View file

@ -13,8 +13,19 @@ const DefaultHost = "localhost"
// TestNewClient tests the NewClient() method with its default options
func TestNewClient(t *testing.T) {
host := "mail.example.com"
c, err := NewClient(host)
if err != nil {
tests := []struct {
name string
host string
shouldfail bool
}{
{"Default", "mail.example.com", false},
{"Empty host should fail", "", true},
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
c, err := NewClient(tt.host)
if err != nil && !tt.shouldfail {
t.Errorf("failed to create new client: %s", err)
return
}
@ -39,6 +50,8 @@ func TestNewClient(t *testing.T) {
t.Errorf("failed to create new client. TLS config min versino expected: %d, got: %d",
DefaultTLSMinVersion, c.tlsconfig.MinVersion)
}
})
}
}
// TestNewClient tests the NewClient() method with its custom options