-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmanager_test.go
63 lines (61 loc) · 1.43 KB
/
manager_test.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
package zerocert
import (
"crypto/tls"
"strings"
"testing"
)
func TestManager_init(t *testing.T) {
type fields struct {
Email string
Reg string
Key []byte
Domain string
CacheFile string
TLSConfig *tls.Config
}
tests := []struct {
name string
fields fields
wantErr string
}{
{
name: "Test with empty fields",
fields: fields{},
wantErr: "loading ACME key",
},
{
name: "Test with valid fields",
fields: fields{
Email: "[email protected]",
Reg: "https://example.com/acme/reg",
Key: []byte(`
-----BEGIN EC PRIVATE KEY-----
MHcCAQEEIBWesomdf9toRdcFXyXtSpbdMmZB83DtXQ+55mhjS6GRoAoGCCqGSM49
AwEHoUQDQgAEZH5K/qgG8c5nvZK0bJnzY9NZa/NdSAYy+YU7TOKbgHtYRlWofgI5
tswDaYyjs/HfTQW9kgnaZ7Hg+kD05ElrIe==
-----END EC PRIVATE KEY-----`),
Domain: "example.com",
CacheFile: "cache.json",
TLSConfig: &tls.Config{
NextProtos: []string{"http/1.1"},
},
},
wantErr: "",
},
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
m := &Manager{
Email: tt.fields.Email,
Reg: tt.fields.Reg,
Key: tt.fields.Key,
Domain: tt.fields.Domain,
CacheFile: tt.fields.CacheFile,
TLSConfig: tt.fields.TLSConfig,
}
if err := m.init(); (err != nil && tt.wantErr == "") || (tt.wantErr != "" && !strings.Contains(err.Error(), tt.wantErr)) {
t.Errorf("Manager.init() error = %v, wantErr %v", err, tt.wantErr)
}
})
}
}