interfaces_file: Add test for changing ipv4 or ipv6 address through address_family
This commit is contained in:
parent
7ec49d7472
commit
bd7001cdb6
19 changed files with 498 additions and 0 deletions
|
@ -0,0 +1,10 @@
|
|||
# The loopback network interface
|
||||
auto lo eth0
|
||||
iface lo inet loopback
|
||||
|
||||
# The primary network interface
|
||||
iface eth0 inet static
|
||||
address 192.168.0.42
|
||||
|
||||
iface eth0 inet6 static
|
||||
address fc00::1
|
|
@ -0,0 +1,19 @@
|
|||
{
|
||||
"eth0": {
|
||||
"address": "fc00::1",
|
||||
"address_family": "inet6",
|
||||
"down": [],
|
||||
"method": "static",
|
||||
"post-up": [],
|
||||
"pre-up": [],
|
||||
"up": []
|
||||
},
|
||||
"lo": {
|
||||
"address_family": "inet",
|
||||
"down": [],
|
||||
"method": "loopback",
|
||||
"post-up": [],
|
||||
"pre-up": [],
|
||||
"up": []
|
||||
}
|
||||
}
|
|
@ -0,0 +1,10 @@
|
|||
# The loopback network interface
|
||||
auto lo eth0
|
||||
iface lo inet loopback
|
||||
|
||||
# The primary network interface
|
||||
iface eth0 inet static
|
||||
address 192.168.0.1
|
||||
|
||||
iface eth0 inet6 static
|
||||
address fc00::42
|
|
@ -0,0 +1,19 @@
|
|||
{
|
||||
"eth0": {
|
||||
"address": "fc00::1",
|
||||
"address_family": "inet6",
|
||||
"down": [],
|
||||
"method": "static",
|
||||
"post-up": [],
|
||||
"pre-up": [],
|
||||
"up": []
|
||||
},
|
||||
"lo": {
|
||||
"address_family": "inet",
|
||||
"down": [],
|
||||
"method": "loopback",
|
||||
"post-up": [],
|
||||
"pre-up": [],
|
||||
"up": []
|
||||
}
|
||||
}
|
|
@ -0,0 +1,7 @@
|
|||
# The loopback network interface
|
||||
auto lo eth0
|
||||
iface lo inet loopback
|
||||
|
||||
# The primary network interface
|
||||
iface eth0 inet dhcp
|
||||
address 192.168.0.42
|
|
@ -0,0 +1,18 @@
|
|||
{
|
||||
"eth0": {
|
||||
"address_family": "inet",
|
||||
"down": [],
|
||||
"method": "dhcp",
|
||||
"post-up": [],
|
||||
"pre-up": [],
|
||||
"up": []
|
||||
},
|
||||
"lo": {
|
||||
"address_family": "inet",
|
||||
"down": [],
|
||||
"method": "loopback",
|
||||
"post-up": [],
|
||||
"pre-up": [],
|
||||
"up": []
|
||||
}
|
||||
}
|
|
@ -0,0 +1,6 @@
|
|||
# The loopback network interface
|
||||
auto lo eth0
|
||||
iface lo inet loopback
|
||||
|
||||
# The primary network interface
|
||||
iface eth0 inet dhcp
|
|
@ -0,0 +1,9 @@
|
|||
fail_json message: Error: interface eth0 not found
|
||||
options:
|
||||
{
|
||||
"address_family": "inet6",
|
||||
"iface": "eth0",
|
||||
"option": "address",
|
||||
"state": "present",
|
||||
"value": "fc00::42"
|
||||
}
|
|
@ -0,0 +1,18 @@
|
|||
{
|
||||
"eth0": {
|
||||
"address_family": "inet",
|
||||
"down": [],
|
||||
"method": "dhcp",
|
||||
"post-up": [],
|
||||
"pre-up": [],
|
||||
"up": []
|
||||
},
|
||||
"lo": {
|
||||
"address_family": "inet",
|
||||
"down": [],
|
||||
"method": "loopback",
|
||||
"post-up": [],
|
||||
"pre-up": [],
|
||||
"up": []
|
||||
}
|
||||
}
|
|
@ -0,0 +1,58 @@
|
|||
auto aggi
|
||||
iface aggi inet static
|
||||
hwaddress ether 22:44:77:88:D5:96
|
||||
address 10.44.15.196
|
||||
netmask 255.255.255.248
|
||||
mtu 1500
|
||||
slaves int1 int2
|
||||
bond_mode 4
|
||||
bond_miimon 100
|
||||
bond_downdelay 200
|
||||
bond_updelay 200
|
||||
bond_lacp_rate slow
|
||||
bond_xmit_hash_policy layer3+4
|
||||
post-up /sbin/ethtool -K aggi tx off tso off
|
||||
|
||||
auto agge
|
||||
iface agge inet manual
|
||||
|
||||
auto br0
|
||||
iface br0 inet static
|
||||
bridge_ports agge
|
||||
hwaddress ether 22:44:77:88:D5:98
|
||||
address 188.44.133.76
|
||||
netmask 255.255.255.248
|
||||
gateway 188.44.133.75
|
||||
slaves ext1 ext2
|
||||
bond_mode 4
|
||||
bond_miimon 100
|
||||
bond_downdelay 200
|
||||
bond_updelay 200
|
||||
bond_lacp_rate slow
|
||||
bond_xmit_hash_policy layer3+4
|
||||
post-up /sbin/ethtool -K agge tx off tso off
|
||||
|
||||
up route add -net 10.0.0.0/8 gw 10.44.15.117 dev aggi
|
||||
up route add -net 192.168.0.0/16 gw 10.44.15.117 dev aggi
|
||||
up route add -net 188.44.208.0/21 gw 10.44.15.117 dev aggi
|
||||
|
||||
auto int1
|
||||
iface int1 inet manual
|
||||
bond-master aggi
|
||||
|
||||
auto int2
|
||||
iface int2 inet manual
|
||||
bond-master aggi
|
||||
|
||||
auto ext1
|
||||
iface ext1 inet manual
|
||||
bond-master agge
|
||||
|
||||
auto ext2
|
||||
iface ext2 inet manual
|
||||
bond-master agge
|
||||
|
||||
auto lo
|
||||
iface lo inet loopback
|
||||
|
||||
source /etc/network/interfaces.d/*.cfg
|
|
@ -0,0 +1,9 @@
|
|||
fail_json message: Error: interface eth0 not found
|
||||
options:
|
||||
{
|
||||
"address_family": "inet",
|
||||
"iface": "eth0",
|
||||
"option": "address",
|
||||
"state": "present",
|
||||
"value": "192.168.0.42"
|
||||
}
|
|
@ -0,0 +1,101 @@
|
|||
{
|
||||
"agge": {
|
||||
"address_family": "inet",
|
||||
"down": [],
|
||||
"method": "manual",
|
||||
"post-up": [],
|
||||
"pre-up": [],
|
||||
"up": []
|
||||
},
|
||||
"aggi": {
|
||||
"address": "10.44.15.196",
|
||||
"address_family": "inet",
|
||||
"bond_downdelay": "200",
|
||||
"bond_lacp_rate": "slow",
|
||||
"bond_miimon": "100",
|
||||
"bond_mode": "4",
|
||||
"bond_updelay": "200",
|
||||
"bond_xmit_hash_policy": "layer3+4",
|
||||
"down": [],
|
||||
"hwaddress": "ether 22:44:77:88:D5:96",
|
||||
"method": "static",
|
||||
"mtu": "1500",
|
||||
"netmask": "255.255.255.248",
|
||||
"post-up": [
|
||||
"/sbin/ethtool -K aggi tx off tso off"
|
||||
],
|
||||
"pre-up": [],
|
||||
"slaves": "int1 int2",
|
||||
"up": []
|
||||
},
|
||||
"br0": {
|
||||
"address": "188.44.133.76",
|
||||
"address_family": "inet",
|
||||
"bond_downdelay": "200",
|
||||
"bond_lacp_rate": "slow",
|
||||
"bond_miimon": "100",
|
||||
"bond_mode": "4",
|
||||
"bond_updelay": "200",
|
||||
"bond_xmit_hash_policy": "layer3+4",
|
||||
"bridge_ports": "agge",
|
||||
"down": [],
|
||||
"gateway": "188.44.133.75",
|
||||
"hwaddress": "ether 22:44:77:88:D5:98",
|
||||
"method": "static",
|
||||
"netmask": "255.255.255.248",
|
||||
"post-up": [
|
||||
"/sbin/ethtool -K agge tx off tso off"
|
||||
],
|
||||
"pre-up": [],
|
||||
"slaves": "ext1 ext2",
|
||||
"up": [
|
||||
"route add -net 10.0.0.0/8 gw 10.44.15.117 dev aggi",
|
||||
"route add -net 192.168.0.0/16 gw 10.44.15.117 dev aggi",
|
||||
"route add -net 188.44.208.0/21 gw 10.44.15.117 dev aggi"
|
||||
]
|
||||
},
|
||||
"ext1": {
|
||||
"address_family": "inet",
|
||||
"bond-master": "agge",
|
||||
"down": [],
|
||||
"method": "manual",
|
||||
"post-up": [],
|
||||
"pre-up": [],
|
||||
"up": []
|
||||
},
|
||||
"ext2": {
|
||||
"address_family": "inet",
|
||||
"bond-master": "agge",
|
||||
"down": [],
|
||||
"method": "manual",
|
||||
"post-up": [],
|
||||
"pre-up": [],
|
||||
"up": []
|
||||
},
|
||||
"int1": {
|
||||
"address_family": "inet",
|
||||
"bond-master": "aggi",
|
||||
"down": [],
|
||||
"method": "manual",
|
||||
"post-up": [],
|
||||
"pre-up": [],
|
||||
"up": []
|
||||
},
|
||||
"int2": {
|
||||
"address_family": "inet",
|
||||
"bond-master": "aggi",
|
||||
"down": [],
|
||||
"method": "manual",
|
||||
"post-up": [],
|
||||
"pre-up": [],
|
||||
"up": []
|
||||
},
|
||||
"lo": {
|
||||
"address_family": "inet",
|
||||
"down": [],
|
||||
"method": "loopback",
|
||||
"post-up": [],
|
||||
"pre-up": [],
|
||||
"up": []
|
||||
}
|
||||
}
|
|
@ -0,0 +1,58 @@
|
|||
auto aggi
|
||||
iface aggi inet static
|
||||
hwaddress ether 22:44:77:88:D5:96
|
||||
address 10.44.15.196
|
||||
netmask 255.255.255.248
|
||||
mtu 1500
|
||||
slaves int1 int2
|
||||
bond_mode 4
|
||||
bond_miimon 100
|
||||
bond_downdelay 200
|
||||
bond_updelay 200
|
||||
bond_lacp_rate slow
|
||||
bond_xmit_hash_policy layer3+4
|
||||
post-up /sbin/ethtool -K aggi tx off tso off
|
||||
|
||||
auto agge
|
||||
iface agge inet manual
|
||||
|
||||
auto br0
|
||||
iface br0 inet static
|
||||
bridge_ports agge
|
||||
hwaddress ether 22:44:77:88:D5:98
|
||||
address 188.44.133.76
|
||||
netmask 255.255.255.248
|
||||
gateway 188.44.133.75
|
||||
slaves ext1 ext2
|
||||
bond_mode 4
|
||||
bond_miimon 100
|
||||
bond_downdelay 200
|
||||
bond_updelay 200
|
||||
bond_lacp_rate slow
|
||||
bond_xmit_hash_policy layer3+4
|
||||
post-up /sbin/ethtool -K agge tx off tso off
|
||||
|
||||
up route add -net 10.0.0.0/8 gw 10.44.15.117 dev aggi
|
||||
up route add -net 192.168.0.0/16 gw 10.44.15.117 dev aggi
|
||||
up route add -net 188.44.208.0/21 gw 10.44.15.117 dev aggi
|
||||
|
||||
auto int1
|
||||
iface int1 inet manual
|
||||
bond-master aggi
|
||||
|
||||
auto int2
|
||||
iface int2 inet manual
|
||||
bond-master aggi
|
||||
|
||||
auto ext1
|
||||
iface ext1 inet manual
|
||||
bond-master agge
|
||||
|
||||
auto ext2
|
||||
iface ext2 inet manual
|
||||
bond-master agge
|
||||
|
||||
auto lo
|
||||
iface lo inet loopback
|
||||
|
||||
source /etc/network/interfaces.d/*.cfg
|
|
@ -0,0 +1,9 @@
|
|||
fail_json message: Error: interface eth0 not found
|
||||
options:
|
||||
{
|
||||
"address_family": "inet6",
|
||||
"iface": "eth0",
|
||||
"option": "address",
|
||||
"state": "present",
|
||||
"value": "fc00::42"
|
||||
}
|
|
@ -0,0 +1,101 @@
|
|||
{
|
||||
"agge": {
|
||||
"address_family": "inet",
|
||||
"down": [],
|
||||
"method": "manual",
|
||||
"post-up": [],
|
||||
"pre-up": [],
|
||||
"up": []
|
||||
},
|
||||
"aggi": {
|
||||
"address": "10.44.15.196",
|
||||
"address_family": "inet",
|
||||
"bond_downdelay": "200",
|
||||
"bond_lacp_rate": "slow",
|
||||
"bond_miimon": "100",
|
||||
"bond_mode": "4",
|
||||
"bond_updelay": "200",
|
||||
"bond_xmit_hash_policy": "layer3+4",
|
||||
"down": [],
|
||||
"hwaddress": "ether 22:44:77:88:D5:96",
|
||||
"method": "static",
|
||||
"mtu": "1500",
|
||||
"netmask": "255.255.255.248",
|
||||
"post-up": [
|
||||
"/sbin/ethtool -K aggi tx off tso off"
|
||||
],
|
||||
"pre-up": [],
|
||||
"slaves": "int1 int2",
|
||||
"up": []
|
||||
},
|
||||
"br0": {
|
||||
"address": "188.44.133.76",
|
||||
"address_family": "inet",
|
||||
"bond_downdelay": "200",
|
||||
"bond_lacp_rate": "slow",
|
||||
"bond_miimon": "100",
|
||||
"bond_mode": "4",
|
||||
"bond_updelay": "200",
|
||||
"bond_xmit_hash_policy": "layer3+4",
|
||||
"bridge_ports": "agge",
|
||||
"down": [],
|
||||
"gateway": "188.44.133.75",
|
||||
"hwaddress": "ether 22:44:77:88:D5:98",
|
||||
"method": "static",
|
||||
"netmask": "255.255.255.248",
|
||||
"post-up": [
|
||||
"/sbin/ethtool -K agge tx off tso off"
|
||||
],
|
||||
"pre-up": [],
|
||||
"slaves": "ext1 ext2",
|
||||
"up": [
|
||||
"route add -net 10.0.0.0/8 gw 10.44.15.117 dev aggi",
|
||||
"route add -net 192.168.0.0/16 gw 10.44.15.117 dev aggi",
|
||||
"route add -net 188.44.208.0/21 gw 10.44.15.117 dev aggi"
|
||||
]
|
||||
},
|
||||
"ext1": {
|
||||
"address_family": "inet",
|
||||
"bond-master": "agge",
|
||||
"down": [],
|
||||
"method": "manual",
|
||||
"post-up": [],
|
||||
"pre-up": [],
|
||||
"up": []
|
||||
},
|
||||
"ext2": {
|
||||
"address_family": "inet",
|
||||
"bond-master": "agge",
|
||||
"down": [],
|
||||
"method": "manual",
|
||||
"post-up": [],
|
||||
"pre-up": [],
|
||||
"up": []
|
||||
},
|
||||
"int1": {
|
||||
"address_family": "inet",
|
||||
"bond-master": "aggi",
|
||||
"down": [],
|
||||
"method": "manual",
|
||||
"post-up": [],
|
||||
"pre-up": [],
|
||||
"up": []
|
||||
},
|
||||
"int2": {
|
||||
"address_family": "inet",
|
||||
"bond-master": "aggi",
|
||||
"down": [],
|
||||
"method": "manual",
|
||||
"post-up": [],
|
||||
"pre-up": [],
|
||||
"up": []
|
||||
},
|
||||
"lo": {
|
||||
"address_family": "inet",
|
||||
"down": [],
|
||||
"method": "loopback",
|
||||
"post-up": [],
|
||||
"pre-up": [],
|
||||
"up": []
|
||||
}
|
||||
}
|
|
@ -229,3 +229,49 @@ class TestInterfacesFileModule(unittest.TestCase):
|
|||
self.compareInterfacesToFile(ifaces, testfile, "%s_%s.json" % (testfile, testname))
|
||||
# Restore backup
|
||||
move(backupp, path)
|
||||
|
||||
def test_change_address(self):
|
||||
testcases = {
|
||||
"change_ipv4": [
|
||||
{
|
||||
'iface': 'eth0',
|
||||
'address_family': 'inet',
|
||||
'option': 'address',
|
||||
'value': '192.168.0.42',
|
||||
'state': 'present',
|
||||
}
|
||||
],
|
||||
"change_ipv6": [
|
||||
{
|
||||
'iface': 'eth0',
|
||||
'address_family': 'inet6',
|
||||
'option': 'address',
|
||||
'value': 'fc00::42',
|
||||
'state': 'present',
|
||||
}
|
||||
],
|
||||
}
|
||||
for testname, options_list in testcases.items():
|
||||
for testfile in self.getTestFiles():
|
||||
with tempfile.NamedTemporaryFile() as temp_file:
|
||||
src_path = os.path.join(fixture_path, testfile)
|
||||
path = temp_file.name
|
||||
shutil.copy(src_path, path)
|
||||
lines, ifaces = interfaces_file.read_interfaces_file(module, path)
|
||||
backupp = module.backup_local(path)
|
||||
options = options_list[0]
|
||||
fail_json_iterations = []
|
||||
try:
|
||||
_, lines = interfaces_file.setInterfaceOption(module, lines, options['iface'], options['option'],
|
||||
options['value'], options['state'], options['address_family'])
|
||||
except AnsibleFailJson as e:
|
||||
fail_json_iterations.append("fail_json message: %s\noptions:\n%s" %
|
||||
(str(e), json.dumps(options, sort_keys=True, indent=4, separators=(',', ': '))))
|
||||
interfaces_file.write_changes(module, [d['line'] for d in lines if 'line' in d], path)
|
||||
|
||||
self.compareStringWithFile("\n=====\n".join(fail_json_iterations), "%s_%s.exceptions.txt" % (testfile, testname))
|
||||
|
||||
self.compareInterfacesLinesToFile(lines, testfile, "%s_%s" % (testfile, testname))
|
||||
self.compareInterfacesToFile(ifaces, testfile, "%s_%s.json" % (testfile, testname))
|
||||
# Restore backup
|
||||
move(backupp, path)
|
||||
|
|
Loading…
Reference in a new issue