Files
clang-p2996/lldb/test/API/commands/log/basic/TestLogging.py
Michał Górny afcdd43bf7 [llvm] [Support] Fix segv if argv0 is null in getMainExecutable()
When LLDB Python bindings are used and stack backtraces are enabled
for logging, getMainExecutable() is called with argv0 being null.
This caused the fallback function getprogpath() (used on FreeBSD, NetBSD
and Linux) to segfault.  Make it handle null executable name gracefully.

Differential Revision: https://reviews.llvm.org/D91012
2020-11-09 11:35:11 +01:00

105 lines
3.1 KiB
Python

"""
Test lldb logging. This test just makes sure logging doesn't crash, and produces some output.
"""
import os
import lldb
from lldbsuite.test.decorators import *
from lldbsuite.test.lldbtest import *
from lldbsuite.test import lldbutil
class LogTestCase(TestBase):
mydir = TestBase.compute_mydir(__file__)
NO_DEBUG_INFO_TESTCASE = True
def setUp(self):
super(LogTestCase, self).setUp()
self.log_file = self.getBuildArtifact("log-file.txt")
if configuration.is_reproducer_replay():
self.log_file = self.getReproducerRemappedPath(self.log_file)
def test_file_writing(self):
self.build()
exe = self.getBuildArtifact("a.out")
self.expect("file " + exe,
patterns=["Current executable set to .*a.out"])
if (os.path.exists(self.log_file)):
os.remove(self.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" % (self.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(self.log_file))
with open(self.log_file, 'r') as f:
log_lines = f.read()
os.remove(self.log_file)
self.assertGreater(
len(log_lines),
0,
"Something was written to the log file.")
# Check that lldb truncates its log files
def test_log_truncate(self):
# put something in our log file
with open(self.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.log_file)
self.runCmd("help log")
self.runCmd("log disable lldb")
self.assertTrue(os.path.isfile(self.log_file))
with open(self.log_file, "r") as f:
contents = f.read()
# check that it got removed
self.assertEquals(contents.find("bacon"), -1)
# Check that lldb can append to a log file
def test_log_append(self):
# put something in our log file
with open(self.log_file, "w") as f:
f.write("bacon\n")
self.runCmd( "log enable -t -a -f '%s' lldb commands" % self.log_file)
self.runCmd("help log")
self.runCmd("log disable lldb")
self.assertTrue(os.path.isfile(self.log_file))
with open(self.log_file, 'r') as f:
contents = f.read()
# check that it is still there
self.assertEquals(contents.find("bacon"), 0)
# Enable all log options and check that nothing crashes.
@skipIfWindows
def test_all_log_options(self):
if (os.path.exists(self.log_file)):
os.remove(self.log_file)
self.runCmd("log enable -v -t -s -T -p -n -S -F -f '%s' lldb commands" % self.log_file)
self.runCmd("help log")
self.runCmd("log disable lldb")
self.assertTrue(os.path.isfile(self.log_file))