aboutsummaryrefslogtreecommitdiff
path: root/packages/Python/lldbsuite/test/functionalities/type_completion/TestTypeCompletion.py
diff options
context:
space:
mode:
Diffstat (limited to 'packages/Python/lldbsuite/test/functionalities/type_completion/TestTypeCompletion.py')
-rw-r--r--packages/Python/lldbsuite/test/functionalities/type_completion/TestTypeCompletion.py115
1 files changed, 82 insertions, 33 deletions
diff --git a/packages/Python/lldbsuite/test/functionalities/type_completion/TestTypeCompletion.py b/packages/Python/lldbsuite/test/functionalities/type_completion/TestTypeCompletion.py
index 2bf10204ea6b..8d6311e42b93 100644
--- a/packages/Python/lldbsuite/test/functionalities/type_completion/TestTypeCompletion.py
+++ b/packages/Python/lldbsuite/test/functionalities/type_completion/TestTypeCompletion.py
@@ -5,32 +5,37 @@ Check that types only get completed when necessary.
from __future__ import print_function
-
-import os, time
+import os
+import time
import lldb
from lldbsuite.test.decorators import *
from lldbsuite.test.lldbtest import *
from lldbsuite.test import lldbutil
+
class TypeCompletionTestCase(TestBase):
mydir = TestBase.compute_mydir(__file__)
- @expectedFailureAll(compiler="icc", bugnumber="often fails with 'NameAndAddress should be valid.")
- # Fails with gcc 4.8.1 with llvm.org/pr15301 LLDB prints incorrect sizes of STL containers
+ @expectedFailureAll(
+ compiler="icc",
+ bugnumber="often fails with 'NameAndAddress should be valid.")
+ # Fails with gcc 4.8.1 with llvm.org/pr15301 LLDB prints incorrect sizes
+ # of STL containers
def test_with_run_command(self):
"""Check that types only get completed when necessary."""
self.build()
self.runCmd("file a.out", CURRENT_EXECUTABLE_SET)
- lldbutil.run_break_set_by_source_regexp (self, "// Set break point at this line.")
+ lldbutil.run_break_set_by_source_regexp(
+ self, "// Set break point at this line.")
self.runCmd("run", RUN_SUCCEEDED)
# The stop reason of the thread should be breakpoint.
self.expect("thread list", STOPPED_DUE_TO_BREAKPOINT,
- substrs = ['stopped',
- 'stop reason = breakpoint'])
+ substrs=['stopped',
+ 'stop reason = breakpoint'])
# This is the function to remove the custom formats in order to have a
# clean slate for the next test case.
@@ -42,68 +47,112 @@ class TypeCompletionTestCase(TestBase):
# Execute the cleanup function during test case tear down.
self.addTearDownHook(cleanup)
- p_vector = self.dbg.GetSelectedTarget().GetProcess().GetSelectedThread().GetSelectedFrame().FindVariable('p')
+ p_vector = self.dbg.GetSelectedTarget().GetProcess(
+ ).GetSelectedThread().GetSelectedFrame().FindVariable('p')
p_type = p_vector.GetType()
- self.assertFalse(p_type.IsTypeComplete(), 'vector<T> complete but it should not be')
+ self.assertFalse(
+ p_type.IsTypeComplete(),
+ 'vector<T> complete but it should not be')
self.runCmd("continue")
- p_vector = self.dbg.GetSelectedTarget().GetProcess().GetSelectedThread().GetSelectedFrame().FindVariable('p')
+ p_vector = self.dbg.GetSelectedTarget().GetProcess(
+ ).GetSelectedThread().GetSelectedFrame().FindVariable('p')
p_type = p_vector.GetType()
- self.assertFalse(p_type.IsTypeComplete(), 'vector<T> complete but it should not be')
+ self.assertFalse(
+ p_type.IsTypeComplete(),
+ 'vector<T> complete but it should not be')
self.runCmd("continue")
self.runCmd("frame variable p --show-types")
- p_vector = self.dbg.GetSelectedTarget().GetProcess().GetSelectedThread().GetSelectedFrame().FindVariable('p')
+ p_vector = self.dbg.GetSelectedTarget().GetProcess(
+ ).GetSelectedThread().GetSelectedFrame().FindVariable('p')
p_type = p_vector.GetType()
- self.assertTrue(p_type.IsTypeComplete(), 'vector<T> should now be complete')
+ self.assertTrue(
+ p_type.IsTypeComplete(),
+ 'vector<T> should now be complete')
name_address_type = p_type.GetTemplateArgumentType(0)
- self.assertTrue(name_address_type.IsValid(), 'NameAndAddress should be valid')
- self.assertFalse(name_address_type.IsTypeComplete(), 'NameAndAddress complete but it should not be')
+ self.assertTrue(
+ name_address_type.IsValid(),
+ 'NameAndAddress should be valid')
+ self.assertFalse(
+ name_address_type.IsTypeComplete(),
+ 'NameAndAddress complete but it should not be')
self.runCmd("continue")
self.runCmd("frame variable guy --show-types")
- p_vector = self.dbg.GetSelectedTarget().GetProcess().GetSelectedThread().GetSelectedFrame().FindVariable('p')
+ p_vector = self.dbg.GetSelectedTarget().GetProcess(
+ ).GetSelectedThread().GetSelectedFrame().FindVariable('p')
p_type = p_vector.GetType()
- self.assertTrue(p_type.IsTypeComplete(), 'vector<T> should now be complete')
+ self.assertTrue(
+ p_type.IsTypeComplete(),
+ 'vector<T> should now be complete')
name_address_type = p_type.GetTemplateArgumentType(0)
- self.assertTrue(name_address_type.IsValid(), 'NameAndAddress should be valid')
- self.assertTrue(name_address_type.IsTypeComplete(), 'NameAndAddress should now be complete')
+ self.assertTrue(
+ name_address_type.IsValid(),
+ 'NameAndAddress should be valid')
+ self.assertTrue(
+ name_address_type.IsTypeComplete(),
+ 'NameAndAddress should now be complete')
field0 = name_address_type.GetFieldAtIndex(0)
- self.assertTrue(field0.IsValid(), 'NameAndAddress::m_name should be valid')
+ self.assertTrue(
+ field0.IsValid(),
+ 'NameAndAddress::m_name should be valid')
string = field0.GetType().GetPointeeType()
self.assertTrue(string.IsValid(), 'CustomString should be valid')
- self.assertFalse(string.IsTypeComplete(), 'CustomString complete but it should not be')
+ self.assertFalse(string.IsTypeComplete(),
+ 'CustomString complete but it should not be')
self.runCmd("continue")
- p_vector = self.dbg.GetSelectedTarget().GetProcess().GetSelectedThread().GetSelectedFrame().FindVariable('p')
+ p_vector = self.dbg.GetSelectedTarget().GetProcess(
+ ).GetSelectedThread().GetSelectedFrame().FindVariable('p')
p_type = p_vector.GetType()
- self.assertTrue(p_type.IsTypeComplete(), 'vector<T> should now be complete')
+ self.assertTrue(
+ p_type.IsTypeComplete(),
+ 'vector<T> should now be complete')
name_address_type = p_type.GetTemplateArgumentType(0)
- self.assertTrue(name_address_type.IsValid(), 'NameAndAddress should be valid')
- self.assertTrue(name_address_type.IsTypeComplete(), 'NameAndAddress should now be complete')
+ self.assertTrue(
+ name_address_type.IsValid(),
+ 'NameAndAddress should be valid')
+ self.assertTrue(
+ name_address_type.IsTypeComplete(),
+ 'NameAndAddress should now be complete')
field0 = name_address_type.GetFieldAtIndex(0)
- self.assertTrue(field0.IsValid(), 'NameAndAddress::m_name should be valid')
+ self.assertTrue(
+ field0.IsValid(),
+ 'NameAndAddress::m_name should be valid')
string = field0.GetType().GetPointeeType()
self.assertTrue(string.IsValid(), 'CustomString should be valid')
- self.assertFalse(string.IsTypeComplete(), 'CustomString complete but it should not be')
+ self.assertFalse(string.IsTypeComplete(),
+ 'CustomString complete but it should not be')
self.runCmd('type category enable -l c++', check=False)
self.runCmd('frame variable guy --show-types --ptr-depth=1')
- p_vector = self.dbg.GetSelectedTarget().GetProcess().GetSelectedThread().GetSelectedFrame().FindVariable('p')
+ p_vector = self.dbg.GetSelectedTarget().GetProcess(
+ ).GetSelectedThread().GetSelectedFrame().FindVariable('p')
p_type = p_vector.GetType()
- self.assertTrue(p_type.IsTypeComplete(), 'vector<T> should now be complete')
+ self.assertTrue(
+ p_type.IsTypeComplete(),
+ 'vector<T> should now be complete')
name_address_type = p_type.GetTemplateArgumentType(0)
- self.assertTrue(name_address_type.IsValid(), 'NameAndAddress should be valid')
- self.assertTrue(name_address_type.IsTypeComplete(), 'NameAndAddress should now be complete')
+ self.assertTrue(
+ name_address_type.IsValid(),
+ 'NameAndAddress should be valid')
+ self.assertTrue(
+ name_address_type.IsTypeComplete(),
+ 'NameAndAddress should now be complete')
field0 = name_address_type.GetFieldAtIndex(0)
- self.assertTrue(field0.IsValid(), 'NameAndAddress::m_name should be valid')
+ self.assertTrue(
+ field0.IsValid(),
+ 'NameAndAddress::m_name should be valid')
string = field0.GetType().GetPointeeType()
self.assertTrue(string.IsValid(), 'CustomString should be valid')
- self.assertTrue(string.IsTypeComplete(), 'CustomString should now be complete')
+ self.assertTrue(
+ string.IsTypeComplete(),
+ 'CustomString should now be complete')