Fix test_ipv6 and simplify to_global()
The tests test_to_global_with_bad_prefix and test_to_global_with_bad_project are broken, they assert the TypeError because they call to_global with an IPv6 address as MAC parameter and do not check the functionality that they claim to check. test_to_global_with_bad_project gets removed, because there is no checking on the project_id, we simply hash whatever is there. We also make sure that the correct error message is generated and add a check to prevent regressing again. While at it, simplify the code for to_global() in nova/ipv6/rfc2462.py. Change-Id: I2a6f75beca1c37d135dcbb3a6eb0d739f2dd41e2
This commit is contained in:
parent
0871f4953d
commit
4647f418af
@ -38,15 +38,14 @@ def to_global(prefix, mac, project_id):
|
|||||||
try:
|
try:
|
||||||
mac_suffix = netaddr.EUI(mac).value & 0xffffff
|
mac_suffix = netaddr.EUI(mac).value & 0xffffff
|
||||||
mac_addr = netaddr.IPAddress(mac_suffix)
|
mac_addr = netaddr.IPAddress(mac_suffix)
|
||||||
|
except netaddr.AddrFormatError:
|
||||||
|
raise TypeError(_('Bad mac for to_global_ipv6: %s') % mac)
|
||||||
|
|
||||||
|
try:
|
||||||
maskIP = netaddr.IPNetwork(prefix).ip
|
maskIP = netaddr.IPNetwork(prefix).ip
|
||||||
return (project_hash ^ static_num ^ mac_addr | maskIP).format()
|
return (project_hash ^ static_num ^ mac_addr | maskIP).format()
|
||||||
except netaddr.AddrFormatError:
|
except netaddr.AddrFormatError:
|
||||||
raise TypeError(_('Bad mac for to_global_ipv6: %s') % mac)
|
|
||||||
except TypeError:
|
|
||||||
raise TypeError(_('Bad prefix for to_global_ipv6: %s') % prefix)
|
raise TypeError(_('Bad prefix for to_global_ipv6: %s') % prefix)
|
||||||
except NameError:
|
|
||||||
raise TypeError(_('Bad project_id for to_global_ipv6: %s') %
|
|
||||||
project_id)
|
|
||||||
|
|
||||||
|
|
||||||
def to_mac(ipv6_address):
|
def to_mac(ipv6_address):
|
||||||
|
@ -24,15 +24,15 @@ from nova.i18n import _
|
|||||||
|
|
||||||
def to_global(prefix, mac, project_id):
|
def to_global(prefix, mac, project_id):
|
||||||
try:
|
try:
|
||||||
mac64 = netaddr.EUI(mac).eui64().words
|
mac64 = netaddr.EUI(mac).modified_eui64().value
|
||||||
int_addr = int(''.join(['%02x' % i for i in mac64]), 16)
|
mac64_addr = netaddr.IPAddress(mac64)
|
||||||
mac64_addr = netaddr.IPAddress(int_addr)
|
|
||||||
maskIP = netaddr.IPNetwork(prefix).ip
|
|
||||||
return (mac64_addr ^ netaddr.IPAddress('::0200:0:0:0') |
|
|
||||||
maskIP).format()
|
|
||||||
except netaddr.AddrFormatError:
|
except netaddr.AddrFormatError:
|
||||||
raise TypeError(_('Bad mac for to_global_ipv6: %s') % mac)
|
raise TypeError(_('Bad mac for to_global_ipv6: %s') % mac)
|
||||||
except TypeError:
|
|
||||||
|
try:
|
||||||
|
maskIP = netaddr.IPNetwork(prefix).ip
|
||||||
|
return (mac64_addr | maskIP).format()
|
||||||
|
except netaddr.AddrFormatError:
|
||||||
raise TypeError(_('Bad prefix for to_global_ipv6: %s') % prefix)
|
raise TypeError(_('Bad prefix for to_global_ipv6: %s') % prefix)
|
||||||
|
|
||||||
|
|
||||||
|
@ -35,22 +35,19 @@ class IPv6RFC2462TestCase(test.NoDBTestCase):
|
|||||||
|
|
||||||
def test_to_global_with_bad_mac(self):
|
def test_to_global_with_bad_mac(self):
|
||||||
bad_mac = '02:16:3e:33:44:5Z'
|
bad_mac = '02:16:3e:33:44:5Z'
|
||||||
self.assertRaises(TypeError, ipv6.to_global,
|
expected_msg = 'Bad mac for to_global_ipv6: %s' % bad_mac
|
||||||
|
err = self.assertRaises(TypeError, ipv6.to_global,
|
||||||
'2001:db8::', bad_mac, 'test')
|
'2001:db8::', bad_mac, 'test')
|
||||||
|
self.assertEqual(expected_msg, str(err))
|
||||||
|
|
||||||
def test_to_global_with_bad_prefix(self):
|
def test_to_global_with_bad_prefix(self):
|
||||||
bad_prefix = '82'
|
bad_prefix = '2001::1::2'
|
||||||
self.assertRaises(TypeError, ipv6.to_global,
|
expected_msg = 'Bad prefix for to_global_ipv6: %s' % bad_prefix
|
||||||
|
err = self.assertRaises(TypeError, ipv6.to_global,
|
||||||
bad_prefix,
|
bad_prefix,
|
||||||
'2001:db8::216:3eff:fe33:4455',
|
'02:16:3e:33:44:55',
|
||||||
'test')
|
'test')
|
||||||
|
self.assertEqual(expected_msg, str(err))
|
||||||
def test_to_global_with_bad_project(self):
|
|
||||||
bad_project = 'non-existent-project-name'
|
|
||||||
self.assertRaises(TypeError, ipv6.to_global,
|
|
||||||
'2001:db8::',
|
|
||||||
'2001:db8::a94a:8fe5:ff33:4455',
|
|
||||||
bad_project)
|
|
||||||
|
|
||||||
|
|
||||||
class IPv6AccountIdentiferTestCase(test.NoDBTestCase):
|
class IPv6AccountIdentiferTestCase(test.NoDBTestCase):
|
||||||
@ -69,20 +66,17 @@ class IPv6AccountIdentiferTestCase(test.NoDBTestCase):
|
|||||||
self.assertEqual(mac, '02:16:3e:33:44:55')
|
self.assertEqual(mac, '02:16:3e:33:44:55')
|
||||||
|
|
||||||
def test_to_global_with_bad_mac(self):
|
def test_to_global_with_bad_mac(self):
|
||||||
bad_mac = '02:16:3e:33:44:5X'
|
bad_mac = '02:16:3e:33:44:5Z'
|
||||||
self.assertRaises(TypeError, ipv6.to_global,
|
expected_msg = 'Bad mac for to_global_ipv6: %s' % bad_mac
|
||||||
|
err = self.assertRaises(TypeError, ipv6.to_global,
|
||||||
'2001:db8::', bad_mac, 'test')
|
'2001:db8::', bad_mac, 'test')
|
||||||
|
self.assertEqual(expected_msg, str(err))
|
||||||
|
|
||||||
def test_to_global_with_bad_prefix(self):
|
def test_to_global_with_bad_prefix(self):
|
||||||
bad_prefix = '78'
|
bad_prefix = '2001::1::2'
|
||||||
self.assertRaises(TypeError, ipv6.to_global,
|
expected_msg = 'Bad prefix for to_global_ipv6: %s' % bad_prefix
|
||||||
|
err = self.assertRaises(TypeError, ipv6.to_global,
|
||||||
bad_prefix,
|
bad_prefix,
|
||||||
'2001:db8::a94a:8fe5:ff33:4455',
|
'02:16:3e:33:44:55',
|
||||||
'test')
|
'test')
|
||||||
|
self.assertEqual(expected_msg, str(err))
|
||||||
def test_to_global_with_bad_project(self):
|
|
||||||
bad_project = 'non-existent-project-name'
|
|
||||||
self.assertRaises(TypeError, ipv6.to_global,
|
|
||||||
'2001:db8::',
|
|
||||||
'2001:db8::a94a:8fe5:ff33:4455',
|
|
||||||
bad_project)
|
|
||||||
|
Loading…
Reference in New Issue
Block a user