tests: fix various object and FD leaks
- Prefer instance attributes over local variables - the former ones do not leak into traceback object and are cleaned up by tests framework. - Use 'with' syntax for handling files. - Use subprocess.DEVNULL instead of open('/dev/null') where applicable - Delete local variables when not needed anymore.
This commit is contained in:
parent
d96d4a94e1
commit
3c54244fdc
@ -183,6 +183,10 @@ class TC_01_Properties(qubes.tests.SystemTestCase):
|
|||||||
self.assertEqual(testvm1.firewall.rules,
|
self.assertEqual(testvm1.firewall.rules,
|
||||||
testvm2.firewall.rules)
|
testvm2.firewall.rules)
|
||||||
finally:
|
finally:
|
||||||
|
try:
|
||||||
|
del firewall
|
||||||
|
except NameError:
|
||||||
|
pass
|
||||||
try:
|
try:
|
||||||
del testvm1
|
del testvm1
|
||||||
except NameError:
|
except NameError:
|
||||||
@ -483,29 +487,29 @@ class TC_05_StandaloneVM(qubes.tests.SystemTestCase):
|
|||||||
self.init_default_template()
|
self.init_default_template()
|
||||||
|
|
||||||
def test_000_create_start(self):
|
def test_000_create_start(self):
|
||||||
testvm1 = self.app.add_new_vm(qubes.vm.standalonevm.StandaloneVM,
|
self.testvm1 = self.app.add_new_vm(qubes.vm.standalonevm.StandaloneVM,
|
||||||
name=self.make_vm_name('vm1'), label='red')
|
name=self.make_vm_name('vm1'), label='red')
|
||||||
testvm1.features['qrexec'] = True
|
self.testvm1.features['qrexec'] = True
|
||||||
self.loop.run_until_complete(
|
self.loop.run_until_complete(
|
||||||
testvm1.clone_disk_files(self.app.default_template))
|
self.testvm1.clone_disk_files(self.app.default_template))
|
||||||
self.app.save()
|
self.app.save()
|
||||||
self.loop.run_until_complete(testvm1.start())
|
self.loop.run_until_complete(self.testvm1.start())
|
||||||
self.assertEqual(testvm1.get_power_state(), "Running")
|
self.assertEqual(self.testvm1.get_power_state(), "Running")
|
||||||
|
|
||||||
def test_100_resize_root_img(self):
|
def test_100_resize_root_img(self):
|
||||||
testvm1 = self.app.add_new_vm(qubes.vm.standalonevm.StandaloneVM,
|
self.testvm1 = self.app.add_new_vm(qubes.vm.standalonevm.StandaloneVM,
|
||||||
name=self.make_vm_name('vm1'), label='red')
|
name=self.make_vm_name('vm1'), label='red')
|
||||||
testvm1.features['qrexec'] = True
|
self.testvm1.features['qrexec'] = True
|
||||||
self.loop.run_until_complete(
|
self.loop.run_until_complete(
|
||||||
testvm1.clone_disk_files(self.app.default_template))
|
self.testvm1.clone_disk_files(self.app.default_template))
|
||||||
self.app.save()
|
self.app.save()
|
||||||
self.loop.run_until_complete(
|
self.loop.run_until_complete(
|
||||||
testvm1.storage.resize(testvm1.volumes['root'], 20 * 1024 ** 3))
|
self.testvm1.storage.resize(self.testvm1.volumes['root'], 20 * 1024 ** 3))
|
||||||
self.assertEqual(testvm1.volumes['root'].size, 20 * 1024 ** 3)
|
self.assertEqual(self.testvm1.volumes['root'].size, 20 * 1024 ** 3)
|
||||||
self.loop.run_until_complete(testvm1.start())
|
self.loop.run_until_complete(self.testvm1.start())
|
||||||
# new_size in 1k-blocks
|
# new_size in 1k-blocks
|
||||||
(new_size, _) = self.loop.run_until_complete(
|
(new_size, _) = self.loop.run_until_complete(
|
||||||
testvm1.run_for_stdio('df --output=size /|tail -n 1'))
|
self.testvm1.run_for_stdio('df --output=size /|tail -n 1'))
|
||||||
# some safety margin for FS metadata
|
# some safety margin for FS metadata
|
||||||
self.assertGreater(int(new_size.strip()), 19 * 1024 ** 2)
|
self.assertGreater(int(new_size.strip()), 19 * 1024 ** 2)
|
||||||
|
|
||||||
|
@ -115,7 +115,7 @@ enabled = 1
|
|||||||
self.app.updatevm = self.updatevm
|
self.app.updatevm = self.updatevm
|
||||||
self.app.save()
|
self.app.save()
|
||||||
subprocess.call(['sudo', 'rpm', '-e', self.pkg_name],
|
subprocess.call(['sudo', 'rpm', '-e', self.pkg_name],
|
||||||
stderr=open(os.devnull, 'w'))
|
stderr=subprocess.DEVNULL)
|
||||||
subprocess.check_call(['sudo', 'rpm', '--import',
|
subprocess.check_call(['sudo', 'rpm', '--import',
|
||||||
os.path.join(self.tmpdir, 'pubkey.asc')])
|
os.path.join(self.tmpdir, 'pubkey.asc')])
|
||||||
self.loop.run_until_complete(self.updatevm.start())
|
self.loop.run_until_complete(self.updatevm.start())
|
||||||
@ -129,10 +129,10 @@ enabled = 1
|
|||||||
del self.repo_proc
|
del self.repo_proc
|
||||||
super(TC_00_Dom0UpgradeMixin, self).tearDown()
|
super(TC_00_Dom0UpgradeMixin, self).tearDown()
|
||||||
|
|
||||||
subprocess.call(['sudo', 'rpm', '-e', self.pkg_name], stderr=open(
|
subprocess.call(['sudo', 'rpm', '-e', self.pkg_name],
|
||||||
os.devnull, 'w'))
|
stderr=subprocess.DEVNULL)
|
||||||
subprocess.call(['sudo', 'rpm', '-e', 'gpg-pubkey-{}'.format(
|
subprocess.call(['sudo', 'rpm', '-e', 'gpg-pubkey-{}'.format(
|
||||||
self.keyid)], stderr=open(os.devnull, 'w'))
|
self.keyid)], stderr=subprocess.DEVNULL)
|
||||||
|
|
||||||
for pkg in os.listdir(self.tmpdir):
|
for pkg in os.listdir(self.tmpdir):
|
||||||
if pkg.endswith('.rpm'):
|
if pkg.endswith('.rpm'):
|
||||||
@ -171,17 +171,18 @@ Test package
|
|||||||
['rpm', '--quiet', '--define=_gpg_path {}'.format(dir),
|
['rpm', '--quiet', '--define=_gpg_path {}'.format(dir),
|
||||||
'--define=_gpg_name {}'.format("Qubes test"),
|
'--define=_gpg_name {}'.format("Qubes test"),
|
||||||
'--addsign', pkg_path],
|
'--addsign', pkg_path],
|
||||||
stdin=open(os.devnull),
|
stdin=subprocess.DEVNULL,
|
||||||
stdout=open(os.devnull, 'w'),
|
stdout=subprocess.DEVNULL,
|
||||||
stderr=subprocess.STDOUT)
|
stderr=subprocess.STDOUT)
|
||||||
subprocess.check_call(['sudo', 'chmod', 'go+rw', '/dev/tty'])
|
subprocess.check_call(['sudo', 'chmod', 'go+rw', '/dev/tty'])
|
||||||
return pkg_path
|
return pkg_path
|
||||||
|
|
||||||
def send_pkg(self, filename):
|
def send_pkg(self, filename):
|
||||||
self.loop.run_until_complete(self.updatevm.run_for_stdio(
|
with open(filename, 'rb') as f_pkg:
|
||||||
'mkdir -p /tmp/repo; cat > /tmp/repo/{}'.format(
|
self.loop.run_until_complete(self.updatevm.run_for_stdio(
|
||||||
os.path.basename(filename)),
|
'mkdir -p /tmp/repo; cat > /tmp/repo/{}'.format(
|
||||||
input=open(filename, 'rb').read()))
|
os.path.basename(filename)),
|
||||||
|
input=f_pkg.read()))
|
||||||
try:
|
try:
|
||||||
self.loop.run_until_complete(
|
self.loop.run_until_complete(
|
||||||
self.updatevm.run_for_stdio('cd /tmp/repo; createrepo .'))
|
self.updatevm.run_for_stdio('cd /tmp/repo; createrepo .'))
|
||||||
@ -229,11 +230,11 @@ Test package
|
|||||||
del proc
|
del proc
|
||||||
|
|
||||||
retcode = subprocess.call(['rpm', '-q', '{}-1.0'.format(
|
retcode = subprocess.call(['rpm', '-q', '{}-1.0'.format(
|
||||||
self.pkg_name)], stdout=open(os.devnull, 'w'))
|
self.pkg_name)], stdout=subprocess.DEVNULL)
|
||||||
self.assertEqual(retcode, 1, 'Package {}-1.0 still installed after '
|
self.assertEqual(retcode, 1, 'Package {}-1.0 still installed after '
|
||||||
'update'.format(self.pkg_name))
|
'update'.format(self.pkg_name))
|
||||||
retcode = subprocess.call(['rpm', '-q', '{}-2.0'.format(
|
retcode = subprocess.call(['rpm', '-q', '{}-2.0'.format(
|
||||||
self.pkg_name)], stdout=open(os.devnull, 'w'))
|
self.pkg_name)], stdout=subprocess.DEVNULL)
|
||||||
self.assertEqual(retcode, 0, 'Package {}-2.0 not installed after '
|
self.assertEqual(retcode, 0, 'Package {}-2.0 not installed after '
|
||||||
'update'.format(self.pkg_name))
|
'update'.format(self.pkg_name))
|
||||||
self.assertFalse(os.path.exists(self.update_flag_path),
|
self.assertFalse(os.path.exists(self.update_flag_path),
|
||||||
@ -350,7 +351,7 @@ Test package
|
|||||||
del proc
|
del proc
|
||||||
|
|
||||||
retcode = subprocess.call(['rpm', '-q', '{}-1.0'.format(
|
retcode = subprocess.call(['rpm', '-q', '{}-1.0'.format(
|
||||||
self.pkg_name)], stdout=open('/dev/null', 'w'))
|
self.pkg_name)], stdout=subprocess.DEVNULL)
|
||||||
self.assertEqual(retcode, 1,
|
self.assertEqual(retcode, 1,
|
||||||
'Package {}-1.0 installed although '
|
'Package {}-1.0 installed although '
|
||||||
'signature is invalid'.format(self.pkg_name))
|
'signature is invalid'.format(self.pkg_name))
|
||||||
@ -358,7 +359,7 @@ Test package
|
|||||||
def test_030_install_unsigned(self):
|
def test_030_install_unsigned(self):
|
||||||
filename = self.create_pkg(self.tmpdir, self.pkg_name, '1.0')
|
filename = self.create_pkg(self.tmpdir, self.pkg_name, '1.0')
|
||||||
subprocess.check_call(['rpm', '--delsign', filename],
|
subprocess.check_call(['rpm', '--delsign', filename],
|
||||||
stdout=open(os.devnull, 'w'),
|
stdout=subprocess.DEVNULL,
|
||||||
stderr=subprocess.STDOUT)
|
stderr=subprocess.STDOUT)
|
||||||
self.send_pkg(filename)
|
self.send_pkg(filename)
|
||||||
|
|
||||||
@ -378,7 +379,7 @@ Test package
|
|||||||
del proc
|
del proc
|
||||||
|
|
||||||
retcode = subprocess.call(['rpm', '-q', '{}-1.0'.format(
|
retcode = subprocess.call(['rpm', '-q', '{}-1.0'.format(
|
||||||
self.pkg_name)], stdout=open('/dev/null', 'w'))
|
self.pkg_name)], stdout=subprocess.DEVNULL)
|
||||||
self.assertEqual(retcode, 1,
|
self.assertEqual(retcode, 1,
|
||||||
'UNSIGNED package {}-1.0 installed'.format(self.pkg_name))
|
'UNSIGNED package {}-1.0 installed'.format(self.pkg_name))
|
||||||
|
|
||||||
|
@ -46,6 +46,12 @@ class StorageTestMixin(object):
|
|||||||
self.init_pool()
|
self.init_pool()
|
||||||
self.app.save()
|
self.app.save()
|
||||||
|
|
||||||
|
def tearDown(self):
|
||||||
|
del self.vm1
|
||||||
|
del self.vm2
|
||||||
|
del self.pool
|
||||||
|
super(StorageTestMixin, self).tearDown()
|
||||||
|
|
||||||
def init_pool(self):
|
def init_pool(self):
|
||||||
''' Initialize storage pool to be tested, store it in self.pool'''
|
''' Initialize storage pool to be tested, store it in self.pool'''
|
||||||
raise NotImplementedError
|
raise NotImplementedError
|
||||||
@ -65,8 +71,10 @@ class StorageTestMixin(object):
|
|||||||
}
|
}
|
||||||
testvol = self.vm1.storage.init_volume('testvol', volume_config)
|
testvol = self.vm1.storage.init_volume('testvol', volume_config)
|
||||||
coro_maybe = testvol.create()
|
coro_maybe = testvol.create()
|
||||||
|
del testvol
|
||||||
if asyncio.iscoroutine(coro_maybe):
|
if asyncio.iscoroutine(coro_maybe):
|
||||||
yield from coro_maybe
|
yield from coro_maybe
|
||||||
|
del coro_maybe
|
||||||
self.app.save()
|
self.app.save()
|
||||||
yield from (self.vm1.start())
|
yield from (self.vm1.start())
|
||||||
|
|
||||||
@ -98,8 +106,10 @@ class StorageTestMixin(object):
|
|||||||
}
|
}
|
||||||
testvol = self.vm1.storage.init_volume('testvol', volume_config)
|
testvol = self.vm1.storage.init_volume('testvol', volume_config)
|
||||||
coro_maybe = testvol.create()
|
coro_maybe = testvol.create()
|
||||||
|
del testvol
|
||||||
if asyncio.iscoroutine(coro_maybe):
|
if asyncio.iscoroutine(coro_maybe):
|
||||||
yield from coro_maybe
|
yield from coro_maybe
|
||||||
|
del coro_maybe
|
||||||
self.app.save()
|
self.app.save()
|
||||||
yield from self.vm1.start()
|
yield from self.vm1.start()
|
||||||
# non-volatile image not clean
|
# non-volatile image not clean
|
||||||
@ -133,8 +143,10 @@ class StorageTestMixin(object):
|
|||||||
}
|
}
|
||||||
testvol = self.vm1.storage.init_volume('testvol', volume_config)
|
testvol = self.vm1.storage.init_volume('testvol', volume_config)
|
||||||
coro_maybe = testvol.create()
|
coro_maybe = testvol.create()
|
||||||
|
del testvol
|
||||||
if asyncio.iscoroutine(coro_maybe):
|
if asyncio.iscoroutine(coro_maybe):
|
||||||
yield from coro_maybe
|
yield from coro_maybe
|
||||||
|
del coro_maybe
|
||||||
self.app.save()
|
self.app.save()
|
||||||
yield from self.vm1.start()
|
yield from self.vm1.start()
|
||||||
# non-volatile image not clean
|
# non-volatile image not clean
|
||||||
@ -167,6 +179,7 @@ class StorageTestMixin(object):
|
|||||||
coro_maybe = testvol.create()
|
coro_maybe = testvol.create()
|
||||||
if asyncio.iscoroutine(coro_maybe):
|
if asyncio.iscoroutine(coro_maybe):
|
||||||
yield from coro_maybe
|
yield from coro_maybe
|
||||||
|
del coro_maybe
|
||||||
volume_config = {
|
volume_config = {
|
||||||
'pool': self.pool.name,
|
'pool': self.pool.name,
|
||||||
'size': size,
|
'size': size,
|
||||||
@ -174,10 +187,13 @@ class StorageTestMixin(object):
|
|||||||
'source': testvol.vid,
|
'source': testvol.vid,
|
||||||
'rw': True,
|
'rw': True,
|
||||||
}
|
}
|
||||||
|
del testvol
|
||||||
testvol_snap = self.vm2.storage.init_volume('testvol', volume_config)
|
testvol_snap = self.vm2.storage.init_volume('testvol', volume_config)
|
||||||
coro_maybe = testvol_snap.create()
|
coro_maybe = testvol_snap.create()
|
||||||
|
del testvol_snap
|
||||||
if asyncio.iscoroutine(coro_maybe):
|
if asyncio.iscoroutine(coro_maybe):
|
||||||
yield from coro_maybe
|
yield from coro_maybe
|
||||||
|
del coro_maybe
|
||||||
self.app.save()
|
self.app.save()
|
||||||
yield from self.vm1.start()
|
yield from self.vm1.start()
|
||||||
yield from self.vm2.start()
|
yield from self.vm2.start()
|
||||||
@ -252,6 +268,7 @@ class StorageTestMixin(object):
|
|||||||
coro_maybe = testvol.create()
|
coro_maybe = testvol.create()
|
||||||
if asyncio.iscoroutine(coro_maybe):
|
if asyncio.iscoroutine(coro_maybe):
|
||||||
yield from coro_maybe
|
yield from coro_maybe
|
||||||
|
del coro_maybe
|
||||||
volume_config = {
|
volume_config = {
|
||||||
'pool': self.pool.name,
|
'pool': self.pool.name,
|
||||||
'size': size,
|
'size': size,
|
||||||
@ -259,10 +276,13 @@ class StorageTestMixin(object):
|
|||||||
'source': testvol.vid,
|
'source': testvol.vid,
|
||||||
'rw': True,
|
'rw': True,
|
||||||
}
|
}
|
||||||
|
del testvol
|
||||||
testvol_snap = self.vm2.storage.init_volume('testvol', volume_config)
|
testvol_snap = self.vm2.storage.init_volume('testvol', volume_config)
|
||||||
coro_maybe = testvol_snap.create()
|
coro_maybe = testvol_snap.create()
|
||||||
|
del testvol_snap
|
||||||
if asyncio.iscoroutine(coro_maybe):
|
if asyncio.iscoroutine(coro_maybe):
|
||||||
yield from coro_maybe
|
yield from coro_maybe
|
||||||
|
del coro_maybe
|
||||||
self.app.save()
|
self.app.save()
|
||||||
yield from self.vm2.start()
|
yield from self.vm2.start()
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user