Merge "Reorder classless static route (RFC3442) records"

This commit is contained in:
Zuul 2019-05-02 00:46:46 +00:00 committed by Gerrit Code Review
commit c8047fb747
2 changed files with 29 additions and 31 deletions

View File

@ -1021,7 +1021,7 @@ class Dnsmasq(DhcpLocalProcess):
if (s.ip_version == 4 and if (s.ip_version == 4 and
s.cidr != subnet.cidr and s.cidr != subnet.cidr and
sub_segment_id == segment_id): sub_segment_id == segment_id):
host_routes.append("%s,0.0.0.0" % s.cidr) host_routes.insert(0, "%s,0.0.0.0" % s.cidr)
if host_routes: if host_routes:
if gateway: if gateway:

View File

@ -1603,11 +1603,11 @@ class TestDnsmasq(TestBase):
def test_output_opts_file_single_dhcp(self): def test_output_opts_file_single_dhcp(self):
expected = ( expected = (
'tag:tag0,option:dns-server,8.8.8.8\n' 'tag:tag0,option:dns-server,8.8.8.8\n'
'tag:tag0,option:classless-static-route,20.0.0.1/24,20.0.0.1,' 'tag:tag0,option:classless-static-route,192.168.1.0/24,0.0.0.0,'
'169.254.169.254/32,192.168.0.1,' '20.0.0.1/24,20.0.0.1,169.254.169.254/32,192.168.0.1,'
'192.168.1.0/24,0.0.0.0,0.0.0.0/0,192.168.0.1\n' '0.0.0.0/0,192.168.0.1\n'
'tag:tag0,249,20.0.0.1/24,20.0.0.1,' 'tag:tag0,249,192.168.1.0/24,0.0.0.0,'
'169.254.169.254/32,192.168.0.1,192.168.1.0/24,0.0.0.0,' '20.0.0.1/24,20.0.0.1,169.254.169.254/32,192.168.0.1,'
'0.0.0.0/0,192.168.0.1\n' '0.0.0.0/0,192.168.0.1\n'
'tag:tag0,option:router,192.168.0.1').lstrip() 'tag:tag0,option:router,192.168.0.1').lstrip()
@ -1628,19 +1628,18 @@ class TestDnsmasq(TestBase):
def test_output_opts_file_dual_dhcp_rfc3442(self): def test_output_opts_file_dual_dhcp_rfc3442(self):
expected = ( expected = (
'tag:tag0,option:dns-server,8.8.8.8\n' 'tag:tag0,option:dns-server,8.8.8.8\n'
'tag:tag0,option:classless-static-route,20.0.0.1/24,20.0.0.1,' 'tag:tag0,option:classless-static-route,192.168.1.0/24,0.0.0.0,'
'169.254.169.254/32,192.168.0.1,' '20.0.0.1/24,20.0.0.1,169.254.169.254/32,192.168.0.1,'
'192.168.1.0/24,0.0.0.0,0.0.0.0/0,192.168.0.1\n' '0.0.0.0/0,192.168.0.1\n'
'tag:tag0,249,20.0.0.1/24,20.0.0.1,' 'tag:tag0,249,192.168.1.0/24,0.0.0.0,'
'169.254.169.254/32,192.168.0.1,192.168.1.0/24,0.0.0.0,' '20.0.0.1/24,20.0.0.1,169.254.169.254/32,192.168.0.1,'
'0.0.0.0/0,192.168.0.1\n' '0.0.0.0/0,192.168.0.1\n'
'tag:tag0,option:router,192.168.0.1\n' 'tag:tag0,option:router,192.168.0.1\n'
'tag:tag1,option:dns-server,8.8.8.8\n' 'tag:tag1,option:dns-server,8.8.8.8\n'
'tag:tag1,option:classless-static-route,' 'tag:tag1,option:classless-static-route,192.168.0.0/24,0.0.0.0,'
'169.254.169.254/32,192.168.1.1,' '169.254.169.254/32,192.168.1.1,0.0.0.0/0,192.168.1.1\n'
'192.168.0.0/24,0.0.0.0,0.0.0.0/0,192.168.1.1\n' 'tag:tag1,249,192.168.0.0/24,0.0.0.0,'
'tag:tag1,249,169.254.169.254/32,192.168.1.1,' '169.254.169.254/32,192.168.1.1,0.0.0.0/0,192.168.1.1\n'
'192.168.0.0/24,0.0.0.0,0.0.0.0/0,192.168.1.1\n'
'tag:tag1,option:router,192.168.1.1').lstrip() 'tag:tag1,option:router,192.168.1.1').lstrip()
self._test_output_opts_file(expected, FakeDualNetworkDualDHCP()) self._test_output_opts_file(expected, FakeDualNetworkDualDHCP())
@ -1666,19 +1665,18 @@ class TestDnsmasq(TestBase):
def test_output_opts_file_dual_dhcp_rfc3442_one_on_link_subnet_route(self): def test_output_opts_file_dual_dhcp_rfc3442_one_on_link_subnet_route(self):
expected = ( expected = (
'tag:tag0,option:dns-server,8.8.8.8\n' 'tag:tag0,option:dns-server,8.8.8.8\n'
'tag:tag0,option:classless-static-route,20.0.0.1/24,20.0.0.1,' 'tag:tag0,option:classless-static-route,192.168.1.0/24,0.0.0.0,'
'169.254.169.254/32,192.168.0.1,' '20.0.0.1/24,20.0.0.1,169.254.169.254/32,192.168.0.1,'
'192.168.1.0/24,0.0.0.0,0.0.0.0/0,192.168.0.1\n' '0.0.0.0/0,192.168.0.1\n'
'tag:tag0,249,20.0.0.1/24,20.0.0.1,' 'tag:tag0,249,192.168.1.0/24,0.0.0.0,'
'169.254.169.254/32,192.168.0.1,192.168.1.0/24,0.0.0.0,' '20.0.0.1/24,20.0.0.1,169.254.169.254/32,192.168.0.1,'
'0.0.0.0/0,192.168.0.1\n' '0.0.0.0/0,192.168.0.1\n'
'tag:tag0,option:router,192.168.0.1\n' 'tag:tag0,option:router,192.168.0.1\n'
'tag:tag1,option:dns-server,8.8.8.8\n' 'tag:tag1,option:dns-server,8.8.8.8\n'
'tag:tag1,option:classless-static-route,' 'tag:tag1,option:classless-static-route,192.168.0.0/24,0.0.0.0,'
'169.254.169.254/32,192.168.1.1,' '169.254.169.254/32,192.168.1.1,0.0.0.0/0,192.168.1.1\n'
'192.168.0.0/24,0.0.0.0,0.0.0.0/0,192.168.1.1\n' 'tag:tag1,249,192.168.0.0/24,0.0.0.0,'
'tag:tag1,249,169.254.169.254/32,192.168.1.1,' '169.254.169.254/32,192.168.1.1,0.0.0.0/0,192.168.1.1\n'
'192.168.0.0/24,0.0.0.0,0.0.0.0/0,192.168.1.1\n'
'tag:tag1,option:router,192.168.1.1\n' 'tag:tag1,option:router,192.168.1.1\n'
'tag:tag2,option:dns-server,8.8.8.8\n' 'tag:tag2,option:dns-server,8.8.8.8\n'
'tag:tag2,option:classless-static-route,' 'tag:tag2,option:classless-static-route,'
@ -1793,11 +1791,11 @@ class TestDnsmasq(TestBase):
def test_output_opts_file_pxe_3port_2net(self): def test_output_opts_file_pxe_3port_2net(self):
expected = ( expected = (
'tag:tag0,option:dns-server,8.8.8.8\n' 'tag:tag0,option:dns-server,8.8.8.8\n'
'tag:tag0,option:classless-static-route,20.0.0.1/24,20.0.0.1,' 'tag:tag0,option:classless-static-route,192.168.1.0/24,0.0.0.0,'
'169.254.169.254/32,192.168.0.1,' '20.0.0.1/24,20.0.0.1,169.254.169.254/32,192.168.0.1,'
'192.168.1.0/24,0.0.0.0,0.0.0.0/0,192.168.0.1\n' '0.0.0.0/0,192.168.0.1\n'
'tag:tag0,249,20.0.0.1/24,20.0.0.1,' 'tag:tag0,249,192.168.1.0/24,0.0.0.0,'
'169.254.169.254/32,192.168.0.1,192.168.1.0/24,0.0.0.0,' '20.0.0.1/24,20.0.0.1,169.254.169.254/32,192.168.0.1,'
'0.0.0.0/0,192.168.0.1\n' '0.0.0.0/0,192.168.0.1\n'
'tag:tag0,option:router,192.168.0.1\n' 'tag:tag0,option:router,192.168.0.1\n'
'tag:eeeeeeee-eeee-eeee-eeee-eeeeeeeeeeee,' 'tag:eeeeeeee-eeee-eeee-eeee-eeeeeeeeeeee,'