-
Notifications
You must be signed in to change notification settings - Fork 6
/
Copy pathport_set_test.go
182 lines (145 loc) · 6.98 KB
/
port_set_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
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
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
package main
import (
"strings"
"testing"
"github.com/corbym/gocrest/is"
"github.com/corbym/gocrest/then"
)
func TestFindHashInPortHtml(t *testing.T) {
hash, err := findHashInHtml(GS308EPP, strings.NewReader(loadTestFile("GS308EPP", "dashboard.cgi.html")))
then.AssertThat(t, err, is.Nil())
then.AssertThat(t, hash, is.EqualTo("4f11f5d64ef3fd75a92a9f2ad1de3060"))
}
func TestComparePortSettingsUnknown(t *testing.T) {
for _, setting := range []PortSettingKey{Speed, IngressRateLimit, EgressRateLimit, FlowControl} {
finalSetting, _ := comparePortSettings(setting, "defaultValue", "newValue")
then.AssertThat(t, finalSetting, is.EqualTo(unknown).Reason("when providing a value that does not exist, return unknown to the caller"))
finalSetting, err := comparePortSettings(setting, "defaultValue", "")
then.AssertThat(t, err, is.Nil())
then.AssertThat(t, finalSetting, is.EqualTo("defaultValue").Reason("return defaultValue to the caller when newValue is not preent"))
}
setting, err := comparePortSettings("None", "defaultValue", "newValue")
then.AssertThat(t, err, is.Not(is.Nil()))
then.AssertThat(t, setting, is.EqualTo("defaultValue").Reason("return defaultValue to the caller when comparison is unknown"))
}
func TestCompareSettingsSameName(t *testing.T) {
name, err := comparePortSettings(Name, "Port Name", "Port Name")
then.AssertThat(t, err, is.Nil())
then.AssertThat(t, name, is.EqualTo("Port Name"))
}
func TestCompareSettingsNameLengthLimit(t *testing.T) {
name, err := comparePortSettings(Name, "Port Name", "OK Port Name")
then.AssertThat(t, err, is.Nil())
then.AssertThat(t, name, is.EqualTo("OK Port Name").Reason("port names are allowed within a 16 character limit"))
name, err = comparePortSettings(Name, "Large Port Name", "Larger Port Name")
then.AssertThat(t, err, is.Nil())
then.AssertThat(t, name, is.EqualTo("Larger Port Name").Reason("port names are allowed to be exactly 16 characters"))
// Disallow new port names beyond 16 characters
name, err = comparePortSettings(Name, "Port Name", "Embiggened Port Name")
then.AssertThat(t, err, is.Not(is.Nil()))
// Allow port names that are smaller and different than the current one
name, err = comparePortSettings(Name, "Larger Port Name", "New Port Name")
then.AssertThat(t, err, is.Nil())
then.AssertThat(t, name, is.EqualTo("New Port Name").Reason("port names are allowed to be changed"))
// Name is allowed to be blank (unsetting the name for a port)
name, err = comparePortSettings(Name, "Port Name", "")
then.AssertThat(t, err, is.Nil())
then.AssertThat(t, name, is.EqualTo("").Reason("port names are allowed to be blank/unset"))
}
func TestCompareSettingsSpeed(t *testing.T) {
for key, value := range portSpeedMap {
result, err := comparePortSettings(Speed, value, value)
then.AssertThat(t, err, is.Nil())
then.AssertThat(t, result, is.EqualTo(key).Reason("Key: "+key+" in portSpeedMap is expected to be value: "+value+" after comparePortSettings()"))
}
// Allow speed changes
speed, err := comparePortSettings(Speed, "1", "Disable")
then.AssertThat(t, err, is.Nil())
then.AssertThat(t, speed, is.EqualTo("2").Reason("port speed index should be 2 if a change to Disable is requested"))
// Check for an invalid speed and 'unknown'
speed, err = comparePortSettings(Speed, "invalid speed", "invalid speed")
then.AssertThat(t, err, is.Not(is.Nil()))
then.AssertThat(t, speed, is.EqualTo(unknown).Reason("invalid speeds should return an error message and be rejected"))
}
func TestCompareSettingsIngressEgress(t *testing.T) {
for _, setting := range []PortSettingKey{IngressRateLimit, EgressRateLimit} {
for key, value := range portRateLimitMap {
result, err := comparePortSettings(setting, value, value)
then.AssertThat(t, err, is.Nil())
then.AssertThat(t, result, is.EqualTo(key).Reason("Key: "+key+" in portRateLimitMap is expected to be value: "+value+" after comparePortSettings()"))
}
// Allow limit changes
rateLimit, err := comparePortSettings(setting, "1", "512 Mbit/s")
then.AssertThat(t, err, is.Nil())
then.AssertThat(t, rateLimit, is.EqualTo("12").Reason("'512 Mbit/s' should be an accepted value for ingress or egress"))
// Check for an invalid limit
rateLimit, err = comparePortSettings(setting, "invalid", "invalid")
then.AssertThat(t, err, is.Not(is.Nil()))
then.AssertThat(t, rateLimit, is.EqualTo(unknown).Reason("an invalid ingress or egress limit cannot be set"))
}
}
func TestCompareSettingsFlowControl(t *testing.T) {
for key, value := range portFlowControlMap {
result, err := comparePortSettings(FlowControl, value, value)
then.AssertThat(t, err, is.Nil())
then.AssertThat(t, result, is.EqualTo(key).Reason("Key: "+key+" in portFlowControlMap is expected to be value: "+value+" after comparePortSettings()"))
}
// Allow changes in port flow control
portFlowControl, err := comparePortSettings(FlowControl, "1", "Off")
then.AssertThat(t, err, is.Nil())
then.AssertThat(t, portFlowControl, is.EqualTo("2").Reason("flow control is allowed to be turned off"))
// Check for invalid entry
portFlowControl, err = comparePortSettings(FlowControl, "invalid", "invalid")
then.AssertThat(t, err, is.Not(is.Nil()))
then.AssertThat(t, portFlowControl, is.EqualTo(unknown).Reason("an invalid flow control setting cannot be set"))
}
func TestCollectChangedPortConfiguration(t *testing.T) {
var ports = []int{1, 2}
var settings = []PortSetting{
{
Index: 1,
Name: "port 1",
Speed: "1",
IngressRateLimit: "2",
EgressRateLimit: "2",
FlowControl: "2",
},
{
Index: 2,
Name: "port 2",
Speed: "3",
IngressRateLimit: "1",
EgressRateLimit: "2",
FlowControl: "1",
},
}
changed := collectChangedPortConfiguration(ports, settings)
then.AssertThat(t, len(changed), is.EqualTo(2))
then.AssertThat(t, int(changed[1].Index), is.EqualTo(2))
}
func TestCreatePortSettingUpdatePayloadGs316ep(t *testing.T) {
token := "xyz123"
newName := "newName"
portSet := PortSetCommand{
Name: &newName,
Ports: []int{16},
Speed: "10M half",
IngressRateLimit: "1 Mbit/s",
EgressRateLimit: "16 Mbit/s",
FlowControl: "On",
}
currentSetting := PortSetting{
Name: "oldName",
}
value, err := createPortSettingUpdatePayloadGs316ep(&portSet, currentSetting, token, "16")
then.AssertThat(t, err, is.Nil())
then.AssertThat(t, value.Encode(), is.StringContaining("Gambit=xyz123"))
then.AssertThat(t, value.Encode(), is.StringContaining("PORT_NO=16"))
then.AssertThat(t, value.Encode(), is.StringContaining("PORT_NAME=newName"))
then.AssertThat(t, value.Encode(), is.StringContaining("PORT_CTRL_MODE=2"))
then.AssertThat(t, value.Encode(), is.StringContaining("PORT_CTRL_SPEED=1"))
then.AssertThat(t, value.Encode(), is.StringContaining("PORT_CTRL_DUPLEX=2"))
then.AssertThat(t, value.Encode(), is.StringContaining("INGRESS=3"))
then.AssertThat(t, value.Encode(), is.StringContaining("EGRESS=7"))
then.AssertThat(t, value.Encode(), is.StringContaining("FLOW_CONTROL=4"))
}