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
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
|
// Copyright 2016 Canonical Ltd.
// Licensed under the AGPLv3, see LICENCE file for details.
package migration_test
import (
"github.com/juju/errors"
jc "github.com/juju/testing/checkers"
"github.com/juju/utils"
gc "gopkg.in/check.v1"
"gopkg.in/juju/names.v2"
"gopkg.in/macaroon.v1"
"github.com/juju/juju/core/migration"
coretesting "github.com/juju/juju/testing"
)
type TargetInfoSuite struct {
coretesting.BaseSuite
}
var _ = gc.Suite(new(TargetInfoSuite))
func (s *TargetInfoSuite) TestValidation(c *gc.C) {
tests := []struct {
label string
tweakInfo func(*migration.TargetInfo)
errorPattern string
}{{
"empty ControllerTag",
func(info *migration.TargetInfo) {
info.ControllerTag = names.NewControllerTag("fooo")
},
"ControllerTag not valid",
}, {
"invalid ControllerTag",
func(info *migration.TargetInfo) {
info.ControllerTag = names.NewControllerTag("")
},
"ControllerTag not valid",
}, {
"empty Addrs",
func(info *migration.TargetInfo) {
info.Addrs = []string{}
},
"empty Addrs not valid",
}, {
"invalid Addrs",
func(info *migration.TargetInfo) {
info.Addrs = []string{"1.2.3.4:555", "abc"}
},
`"abc" in Addrs not valid`,
}, {
"CACert",
func(info *migration.TargetInfo) {
info.CACert = ""
},
"empty CACert not valid",
}, {
"AuthTag",
func(info *migration.TargetInfo) {
info.AuthTag = names.UserTag{}
},
"empty AuthTag not valid",
}, {
"Password & Macaroons",
func(info *migration.TargetInfo) {
info.Password = ""
info.Macaroons = nil
},
"missing Password & Macaroons not valid",
}, {
"Success - empty Password",
func(info *migration.TargetInfo) {
info.Password = ""
},
"",
}, {
"Success - empty Macaroons",
func(info *migration.TargetInfo) {
info.Macaroons = nil
},
"",
}, {
"Success - all set",
func(*migration.TargetInfo) {},
"",
}}
for _, test := range tests {
c.Logf("---- %s -----------", test.label)
info := makeValidTargetInfo(c)
test.tweakInfo(&info)
err := info.Validate()
if test.errorPattern == "" {
c.Check(err, jc.ErrorIsNil)
} else {
c.Check(errors.IsNotValid(err), jc.IsTrue)
c.Check(err, gc.ErrorMatches, test.errorPattern)
}
}
}
func makeValidTargetInfo(c *gc.C) migration.TargetInfo {
mac, err := macaroon.New([]byte("secret"), "id", "location")
c.Assert(err, jc.ErrorIsNil)
return migration.TargetInfo{
ControllerTag: names.NewControllerTag(utils.MustNewUUID().String()),
Addrs: []string{"1.2.3.4:5555"},
CACert: "cert",
AuthTag: names.NewUserTag("user"),
Password: "password",
Macaroons: []macaroon.Slice{{mac}},
}
}
|