import os import infra.basetest class TestLtrace(infra.basetest.BRTest): config = infra.basetest.BASIC_TOOLCHAIN_CONFIG + \ """ BR2_PACKAGE_LTRACE=y BR2_TARGET_ROOTFS_CPIO=y # BR2_TARGET_ROOTFS_TAR is not set """ def test_run(self): cpio_file = os.path.join(self.builddir, "images", "rootfs.cpio") self.emulator.boot(arch="armv5", kernel="builtin", options=["-initrd", cpio_file]) self.emulator.login() # Check the program can execute self.assertRunOk("ltrace --version") # Run ltrace on a ls cmd = "ltrace -a 0 -o ltrace.log ls /" self.assertRunOk(cmd) # Check the ltrace log contains occurrences of libc malloc() cmd = "grep -Ec 'malloc\\([0-9]+\\)' ltrace.log" out, ret = self.emulator.run(cmd) self.assertEqual(ret, 0) self.assertGreater(int(out[0]), 0)