Files
clang-p2996/lldb/test/logging/TestLogging.py
Robert Flack 13c7ad9cd2 Replace sys.platform skips in tests with @skip decorators which check against remote platform.
Adds @skipIfPlatform and @skipUnlessPlatform decorators which will skip if /
unless the target platform is in the provided platform list.

Test Plan:
ninja check-lldb shows no regressions.
When running cross platform, tests which cannot run on the target platform are
skipped.

Differential Revision: http://reviews.llvm.org/D8665

llvm-svn: 233547
2015-03-30 14:12:17 +00:00

116 lines
3.7 KiB
Python

"""
Test lldb logging. This test just makes sure logging doesn't crash, and produces some output.
"""
import os, time, string
import unittest2
import lldb
from lldbtest import *
class LogTestCase(TestBase):
mydir = TestBase.compute_mydir(__file__)
append_log_file = "lldb-commands-log-append.txt"
truncate_log_file = "lldb-commands-log-truncate.txt"
@classmethod
def classCleanup(cls):
"""Cleanup the test byproducts."""
cls.RemoveTempFile(cls.truncate_log_file)
cls.RemoveTempFile(cls.append_log_file)
@skipUnlessDarwin
@dsym_test
def test_with_dsym (self):
self.buildDsym ()
self.command_log_tests ("dsym")
@dwarf_test
def test_with_dwarf (self):
self.buildDwarf ()
self.command_log_tests ("dwarf")
def command_log_tests (self, type):
exe = os.path.join (os.getcwd(), "a.out")
self.expect("file " + exe,
patterns = [ "Current executable set to .*a.out" ])
log_file = os.path.join (os.getcwd(), "lldb-commands-log-%s-%s-%s.txt" % (type,
os.path.basename(self.getCompiler()),
self.getArchitecture()))
if (os.path.exists (log_file)):
os.remove (log_file)
# By default, Debugger::EnableLog() will set log options to
# PREPEND_THREAD_NAME + OPTION_THREADSAFE. We don't want the
# threadnames here, so we enable just threadsafe (-t).
self.runCmd ("log enable -t -f '%s' lldb commands" % (log_file))
self.runCmd ("command alias bp breakpoint")
self.runCmd ("bp set -n main")
self.runCmd ("bp l")
self.runCmd("log disable lldb")
self.assertTrue (os.path.isfile (log_file))
f = open (log_file)
log_lines = f.readlines()
f.close ()
os.remove (log_file)
self.assertTrue(log_lines > 0, "Something was written to the log file.")
# Check that lldb truncates its log files
def test_log_truncate (self):
if (os.path.exists (self.truncate_log_file)):
os.remove (self.truncate_log_file)
# put something in our log file
with open(self.truncate_log_file, "w") as f:
for i in range(1, 1000):
f.write("bacon\n")
self.runCmd ("log enable -t -f '%s' lldb commands" % (self.truncate_log_file))
self.runCmd ("help log")
self.runCmd ("log disable lldb")
self.assertTrue (os.path.isfile (self.truncate_log_file))
with open(self.truncate_log_file, "r") as f:
contents = f.read ()
# check that it got removed
self.assertTrue(string.find(contents, "bacon") == -1)
# Check that lldb can append to a log file
def test_log_append (self):
if (os.path.exists (self.append_log_file)):
os.remove (self.append_log_file)
# put something in our log file
with open(self.append_log_file, "w") as f:
f.write("bacon\n")
self.runCmd ("log enable -t -a -f '%s' lldb commands" % (self.append_log_file))
self.runCmd ("help log")
self.runCmd ("log disable lldb")
self.assertTrue (os.path.isfile (self.append_log_file))
with open(self.append_log_file, "r") as f:
contents = f.read ()
# check that it is still there
self.assertTrue(string.find(contents, "bacon") == 0)
if __name__ == '__main__':
import atexit
lldb.SBDebugger.Initialize()
atexit.register(lambda: lldb.SBDebugger.Terminate())
unittest2.main()