fix netns delete so that it works when a ns is set
bug 1038759 This fixes the bug by ensuring that the netns deletion always runs in the root namespace. Tests were updated to reflect the change in execute invocation. Change-Id: I008e8ecbc4bae86129af7f4a7b5d33c6ae423e5c
This commit is contained in:
parent
23715d972d
commit
4ad296c591
@ -262,7 +262,12 @@ class IpNetnsCommand(IpCommandBase):
|
|||||||
return IPWrapper(self._parent.root_helper, name)
|
return IPWrapper(self._parent.root_helper, name)
|
||||||
|
|
||||||
def delete(self, name):
|
def delete(self, name):
|
||||||
self._as_root('delete', name)
|
if not self._parent.root_helper:
|
||||||
|
raise exceptions.SudoRequired()
|
||||||
|
else:
|
||||||
|
return utils.execute(
|
||||||
|
['ip', 'netns', 'delete', name],
|
||||||
|
root_helper=self._parent.root_helper)
|
||||||
|
|
||||||
def execute(self, cmds):
|
def execute(self, cmds):
|
||||||
if not self._parent.root_helper:
|
if not self._parent.root_helper:
|
||||||
|
@ -423,8 +423,10 @@ class TestIpNetnsCommand(TestIPCmdBase):
|
|||||||
self.assertEqual(ns.namespace, 'ns')
|
self.assertEqual(ns.namespace, 'ns')
|
||||||
|
|
||||||
def test_delete_namespace(self):
|
def test_delete_namespace(self):
|
||||||
self.netns_cmd.delete('ns')
|
with mock.patch('quantum.agent.linux.utils.execute') as execute:
|
||||||
self._assert_sudo([], ('delete', 'ns'))
|
self.netns_cmd.delete('ns')
|
||||||
|
execute.assert_called_once_with(['ip', 'netns', 'delete', 'ns'],
|
||||||
|
root_helper='sudo')
|
||||||
|
|
||||||
def test_namespace_exists(self):
|
def test_namespace_exists(self):
|
||||||
retval = '\n'.join(NETNS_SAMPLE)
|
retval = '\n'.join(NETNS_SAMPLE)
|
||||||
|
Loading…
Reference in New Issue
Block a user