Merge pull request #241 from practicalswift/testcases

Add test cases for issues #236 (potential memory leak) and #237 (OS X crash)
This commit is contained in:
Nguyen Anh Quynh 2015-11-03 09:47:16 +08:00
commit 01671683be
2 changed files with 49 additions and 0 deletions

View File

@ -0,0 +1,20 @@
#!/usr/bin/env python
import platform
import resource
from unicorn import *
import regress
# OS X: OK with 2047 iterations.
# OS X: Crashes at 2048:th iteration ("qemu: qemu_thread_create: Resource temporarily unavailable").
# Linux: No crashes observed.
class ThreadCreateCrash(regress.RegressTest):
def test(self):
for i in xrange(2048):
Uc(UC_ARCH_X86, UC_MODE_64)
self.assertTrue(True, "If not reached, then we have a crashing bug.")
if __name__ == '__main__':
regress.main()

View File

@ -0,0 +1,29 @@
#!/usr/bin/env python
import platform
import resource
from unicorn import *
import regress
class MemoryLeak(regress.RegressTest):
def test(self):
if platform.system() == "Darwin":
rusage_multiplier = 1
elif platform.system() == "Linux":
rusage_multiplier = 1024
else:
# resource.getrusage(...) is platform dependent. Only tested under OS X and Linux.
return
max_rss_before = resource.getrusage(resource.RUSAGE_SELF).ru_maxrss * rusage_multiplier
for i in xrange(10000):
mu = Uc(UC_ARCH_X86, UC_MODE_64)
mu.mem_map(0, 4096)
mu.emu_start(0, 0)
max_rss_after = resource.getrusage(resource.RUSAGE_SELF).ru_maxrss * rusage_multiplier
rss_increase_per_iteration = (max_rss_after - max_rss_before) / i
self.assertLess(rss_increase_per_iteration, 8000)
if __name__ == '__main__':
regress.main()