|
15 | 15 | import ddt |
16 | 16 | import importlib |
17 | 17 | import os |
| 18 | +import textwrap |
18 | 19 | import unittest |
19 | 20 | import unittest.mock as mock |
20 | 21 |
|
|
48 | 49 | config: |
49 | 50 | - type: router |
50 | 51 | """ |
51 | | -NOCLOUD_NETWORK_CONFIG_TEST_DATA_V1 = """ |
52 | | -network: |
53 | | - version: 1 |
54 | | - config: |
55 | | - - type: physical |
56 | | - name: interface0 |
57 | | - mac_address: "52:54:00:12:34:00" |
58 | | - mtu: 1450 |
59 | | - subnets: |
60 | | - - type: static |
61 | | - address: 192.168.1.10 |
62 | | - netmask: 255.255.255.0 |
63 | | - gateway: 192.168.1.1 |
64 | | - dns_nameservers: |
65 | | - - 192.168.1.11 |
66 | | - - type: bond |
67 | | - name: bond0 |
68 | | - bond_interfaces: |
69 | | - - gbe0 |
70 | | - - gbe1 |
71 | | - mac_address: "52:54:00:12:34:00" |
72 | | - params: |
73 | | - bond-mode: active-backup |
74 | | - bond-lacp-rate: false |
75 | | - mtu: 1450 |
76 | | - subnets: |
77 | | - - type: static |
78 | | - address: 192.168.1.10 |
79 | | - netmask: 255.255.255.0 |
80 | | - dns_nameservers: |
81 | | - - 192.168.1.11 |
82 | | - - type: vlan |
83 | | - name: vlan0 |
84 | | - vlan_link: eth1 |
85 | | - vlan_id: 150 |
86 | | - mac_address: "52:54:00:12:34:00" |
87 | | - mtu: 1450 |
88 | | - subnets: |
89 | | - - type: static |
90 | | - address: 192.168.1.10 |
91 | | - netmask: 255.255.255.0 |
92 | | - dns_nameservers: |
93 | | - - 192.168.1.11 |
94 | | - - type: nameserver |
95 | | - address: |
96 | | - - 192.168.23.2 |
97 | | - - 8.8.8.8 |
98 | | - search: acme.local |
| 52 | +NOCLOUD_NETWORK_CONFIG_TEST_DATA_V1_LEGACY = """ |
| 53 | +version: 1 |
| 54 | +config: |
| 55 | +- type: physical |
| 56 | + name: interface0 |
| 57 | + mac_address: "52:54:00:12:34:00" |
| 58 | + mtu: 1450 |
| 59 | + subnets: |
| 60 | + - type: static |
| 61 | + address: 192.168.1.10 |
| 62 | + netmask: 255.255.255.0 |
| 63 | + gateway: 192.168.1.1 |
| 64 | + dns_nameservers: |
| 65 | + - 192.168.1.11 |
| 66 | +- type: bond |
| 67 | + name: bond0 |
| 68 | + bond_interfaces: |
| 69 | + - gbe0 |
| 70 | + - gbe1 |
| 71 | + mac_address: "52:54:00:12:34:00" |
| 72 | + params: |
| 73 | + bond-mode: active-backup |
| 74 | + bond-lacp-rate: false |
| 75 | + mtu: 1450 |
| 76 | + subnets: |
| 77 | + - type: static |
| 78 | + address: 192.168.1.10 |
| 79 | + netmask: 255.255.255.0 |
| 80 | + dns_nameservers: |
| 81 | + - 192.168.1.11 |
| 82 | +- type: vlan |
| 83 | + name: vlan0 |
| 84 | + vlan_link: eth1 |
| 85 | + vlan_id: 150 |
| 86 | + mac_address: "52:54:00:12:34:00" |
| 87 | + mtu: 1450 |
| 88 | + subnets: |
| 89 | + - type: static |
| 90 | + address: 192.168.1.10 |
| 91 | + netmask: 255.255.255.0 |
| 92 | + dns_nameservers: |
| 93 | + - 192.168.1.11 |
| 94 | +- type: nameserver |
| 95 | + address: |
| 96 | + - 192.168.23.2 |
| 97 | + - 8.8.8.8 |
| 98 | + search: acme.local |
99 | 99 | """ |
| 100 | +NOCLOUD_NETWORK_CONFIG_TEST_DATA_V1 = """ |
| 101 | +network:%s |
| 102 | +""" % (textwrap.indent(NOCLOUD_NETWORK_CONFIG_TEST_DATA_V1_LEGACY, " ")) |
100 | 103 | NOCLOUD_NETWORK_CONFIG_TEST_DATA_V2_EMPTY_CONFIG = """ |
101 | 104 | """ |
102 | 105 | NOCLOUD_NETWORK_CONFIG_TEST_DATA_V2_CONFIG_IS_NOT_DICT = """ |
|
116 | 119 | eth0: |
117 | 120 | - test |
118 | 121 | """ |
119 | | -NOCLOUD_NETWORK_CONFIG_TEST_DATA_V2 = """ |
120 | | -network: |
121 | | - version: 2 |
122 | | - ethernets: |
123 | | - interface0: |
124 | | - match: |
125 | | - macaddress: "52:54:00:12:34:00" |
126 | | - set-name: "eth0" |
| 122 | +NOCLOUD_NETWORK_CONFIG_TEST_DATA_V2_LEGACY = """ |
| 123 | +version: 2 |
| 124 | +ethernets: |
| 125 | + interface0: |
| 126 | + match: |
| 127 | + macaddress: "52:54:00:12:34:00" |
| 128 | + set-name: "eth0" |
| 129 | + addresses: |
| 130 | + - 192.168.1.10/24 |
| 131 | + gateway4: 192.168.1.1 |
| 132 | + nameservers: |
127 | 133 | addresses: |
128 | | - - 192.168.1.10/24 |
129 | | - gateway4: 192.168.1.1 |
130 | | - nameservers: |
131 | | - addresses: |
132 | | - - 192.168.1.11 |
133 | | - - 192.168.1.12 |
134 | | - search: |
135 | | - - acme.local |
136 | | - mtu: 1450 |
137 | | - interface1: |
138 | | - set-name: "interface1" |
| 134 | + - 192.168.1.11 |
| 135 | + - 192.168.1.12 |
| 136 | + search: |
| 137 | + - acme.local |
| 138 | + mtu: 1450 |
| 139 | + interface1: |
| 140 | + set-name: "interface1" |
| 141 | + addresses: |
| 142 | + - 192.168.1.100/24 |
| 143 | + gateway4: 192.168.1.1 |
| 144 | + nameservers: |
139 | 145 | addresses: |
140 | | - - 192.168.1.100/24 |
141 | | - gateway4: 192.168.1.1 |
142 | | - nameservers: |
143 | | - addresses: |
144 | | - - 192.168.1.11 |
145 | | - - 192.168.1.12 |
146 | | - search: |
147 | | - - acme.local |
148 | | - bonds: |
149 | | - bond0: |
150 | | - interfaces: ["gbe0", "gbe1"] |
151 | | - match: |
152 | | - macaddress: "52:54:00:12:34:00" |
153 | | - parameters: |
154 | | - mode: active-backup |
155 | | - lacp-rate: false |
| 146 | + - 192.168.1.11 |
| 147 | + - 192.168.1.12 |
| 148 | + search: |
| 149 | + - acme.local |
| 150 | +bonds: |
| 151 | + bond0: |
| 152 | + interfaces: ["gbe0", "gbe1"] |
| 153 | + match: |
| 154 | + macaddress: "52:54:00:12:34:00" |
| 155 | + parameters: |
| 156 | + mode: active-backup |
| 157 | + lacp-rate: false |
| 158 | + addresses: |
| 159 | + - 192.168.1.10/24 |
| 160 | + nameservers: |
156 | 161 | addresses: |
157 | | - - 192.168.1.10/24 |
158 | | - nameservers: |
159 | | - addresses: |
160 | | - - 192.168.1.11 |
161 | | - mtu: 1450 |
162 | | - vlans: |
163 | | - vlan0: |
164 | | - id: 150 |
165 | | - link: eth1 |
166 | | - dhcp4: yes |
167 | | - match: |
168 | | - macaddress: "52:54:00:12:34:00" |
| 162 | + - 192.168.1.11 |
| 163 | + mtu: 1450 |
| 164 | +vlans: |
| 165 | + vlan0: |
| 166 | + id: 150 |
| 167 | + link: eth1 |
| 168 | + dhcp4: yes |
| 169 | + match: |
| 170 | + macaddress: "52:54:00:12:34:00" |
| 171 | + addresses: |
| 172 | + - 192.168.1.10/24 |
| 173 | + nameservers: |
169 | 174 | addresses: |
170 | | - - 192.168.1.10/24 |
171 | | - nameservers: |
172 | | - addresses: |
173 | | - - 192.168.1.11 |
174 | | - mtu: 1450 |
175 | | - bridges: |
176 | | - br0: |
177 | | - interfaces: ['eth0'] |
178 | | - dhcp4: true |
| 175 | + - 192.168.1.11 |
| 176 | + mtu: 1450 |
| 177 | +bridges: |
| 178 | + br0: |
| 179 | + interfaces: ['eth0'] |
| 180 | + dhcp4: true |
179 | 181 | """ |
| 182 | +NOCLOUD_NETWORK_CONFIG_TEST_DATA_V2 = """ |
| 183 | +network:%s |
| 184 | +""" % (textwrap.indent(NOCLOUD_NETWORK_CONFIG_TEST_DATA_V2_LEGACY, " ")) |
180 | 185 |
|
181 | 186 |
|
182 | 187 | @ddt.ddt |
@@ -207,7 +212,12 @@ def test_parse_empty_result(self, input, expected_result): |
207 | 212 | self.assertEqual(True, expected_result[0] in self.snatcher.output[0]) |
208 | 213 | self.assertEqual(result, expected_result[1]) |
209 | 214 |
|
210 | | - def test_network_details_v2(self): |
| 215 | + @ddt.data( |
| 216 | + (NOCLOUD_NETWORK_CONFIG_TEST_DATA_V1, True), |
| 217 | + (NOCLOUD_NETWORK_CONFIG_TEST_DATA_V1_LEGACY, True) |
| 218 | + ) |
| 219 | + @ddt.unpack |
| 220 | + def test_network_details_v2(self, test_data, expected_result): |
211 | 221 | expected_bond = nm.Bond( |
212 | 222 | members=["gbe0", "gbe1"], |
213 | 223 | type=nm.BOND_TYPE_ACTIVE_BACKUP, |
@@ -275,7 +285,7 @@ def test_network_details_v2(self): |
275 | 285 | search='acme.local') |
276 | 286 |
|
277 | 287 | result = self._parser.parse( |
278 | | - serialization.parse_json_yaml(NOCLOUD_NETWORK_CONFIG_TEST_DATA_V1)) |
| 288 | + serialization.parse_json_yaml(test_data)) |
279 | 289 |
|
280 | 290 | self.assertEqual(result.links[0], expected_link) |
281 | 291 | self.assertEqual(result.networks[0], expected_network) |
@@ -318,7 +328,12 @@ def test_parse_empty_result(self, input, expected_result): |
318 | 328 | self.assertEqual(True, expected_result[0] in self.snatcher.output[0]) |
319 | 329 | self.assertEqual(result, expected_result[1]) |
320 | 330 |
|
321 | | - def test_network_details_v2(self): |
| 331 | + @ddt.data( |
| 332 | + (NOCLOUD_NETWORK_CONFIG_TEST_DATA_V2, True), |
| 333 | + (NOCLOUD_NETWORK_CONFIG_TEST_DATA_V2_LEGACY, True) |
| 334 | + ) |
| 335 | + @ddt.unpack |
| 336 | + def test_network_details_v2(self, test_data, expected_result): |
322 | 337 | expected_bond = nm.Bond( |
323 | 338 | members=["gbe0", "gbe1"], |
324 | 339 | type=nm.BOND_TYPE_ACTIVE_BACKUP, |
@@ -406,7 +421,7 @@ def test_network_details_v2(self): |
406 | 421 | search='acme.local') |
407 | 422 |
|
408 | 423 | result = self._parser.parse( |
409 | | - serialization.parse_json_yaml(NOCLOUD_NETWORK_CONFIG_TEST_DATA_V2)) |
| 424 | + serialization.parse_json_yaml(test_data)) |
410 | 425 |
|
411 | 426 | self.assertEqual(result.links[0], expected_link) |
412 | 427 | self.assertEqual(result.links[1], expected_link_if1) |
|
0 commit comments