Fix floating ips with external gateway
If dnsmasq is configured to use an external gateway, then floating ips on other interfaces do not work properly. This is because outgoing traffic is no longer snatted to the floating ip. This patch fixes it by adding an ebtables rule to force traffic from ips that have a floating ip associated to route instead of bridge. Fixes bug 1096985 Change-Id: I8e4904660d42fe51c44b66686bed9f5d622693bd
This commit is contained in:
		| @@ -253,11 +253,11 @@ class DbApiTestCase(test.TestCase): | |||||||
|         values = {'address': 'fixed'} |         values = {'address': 'fixed'} | ||||||
|         fixed = db.fixed_ip_create(ctxt, values) |         fixed = db.fixed_ip_create(ctxt, values) | ||||||
|         res = db.floating_ip_fixed_ip_associate(ctxt, floating, fixed, 'foo') |         res = db.floating_ip_fixed_ip_associate(ctxt, floating, fixed, 'foo') | ||||||
|         self.assertEqual(res, fixed) |         self.assertEqual(res['address'], fixed) | ||||||
|         res = db.floating_ip_fixed_ip_associate(ctxt, floating, fixed, 'foo') |         res = db.floating_ip_fixed_ip_associate(ctxt, floating, fixed, 'foo') | ||||||
|         self.assertEqual(res, None) |         self.assertEqual(res, None) | ||||||
|         res = db.floating_ip_disassociate(ctxt, floating) |         res = db.floating_ip_disassociate(ctxt, floating) | ||||||
|         self.assertEqual(res, fixed) |         self.assertEqual(res['address'], fixed) | ||||||
|         res = db.floating_ip_disassociate(ctxt, floating) |         res = db.floating_ip_disassociate(ctxt, floating) | ||||||
|         self.assertEqual(res, None) |         self.assertEqual(res, None) | ||||||
|  |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Vishvananda Ishaya
					Vishvananda Ishaya