aboutsummaryrefslogtreecommitdiff
path: root/packages/Python/lldbsuite/test/functionalities/data-formatter/data-formatter-named-summaries/TestDataFormatterNamedSummaries.py
diff options
context:
space:
mode:
Diffstat (limited to 'packages/Python/lldbsuite/test/functionalities/data-formatter/data-formatter-named-summaries/TestDataFormatterNamedSummaries.py')
-rw-r--r--packages/Python/lldbsuite/test/functionalities/data-formatter/data-formatter-named-summaries/TestDataFormatterNamedSummaries.py117
1 files changed, 63 insertions, 54 deletions
diff --git a/packages/Python/lldbsuite/test/functionalities/data-formatter/data-formatter-named-summaries/TestDataFormatterNamedSummaries.py b/packages/Python/lldbsuite/test/functionalities/data-formatter/data-formatter-named-summaries/TestDataFormatterNamedSummaries.py
index e9ac79ad08e2..f4f0a4859896 100644
--- a/packages/Python/lldbsuite/test/functionalities/data-formatter/data-formatter-named-summaries/TestDataFormatterNamedSummaries.py
+++ b/packages/Python/lldbsuite/test/functionalities/data-formatter/data-formatter-named-summaries/TestDataFormatterNamedSummaries.py
@@ -5,12 +5,13 @@ Test lldb data formatter subsystem.
from __future__ import print_function
-
-import os, time
+import os
+import time
import lldb
from lldbsuite.test.lldbtest import *
import lldbsuite.test.lldbutil as lldbutil
+
class NamedSummariesDataFormatterTestCase(TestBase):
mydir = TestBase.compute_mydir(__file__)
@@ -26,15 +27,16 @@ class NamedSummariesDataFormatterTestCase(TestBase):
self.build()
self.runCmd("file a.out", CURRENT_EXECUTABLE_SET)
- lldbutil.run_break_set_by_file_and_line (self, "main.cpp", self.line, num_expected_locations=1, loc_exact=True)
+ lldbutil.run_break_set_by_file_and_line(
+ self, "main.cpp", self.line, num_expected_locations=1, loc_exact=True)
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.
def cleanup():
@@ -44,81 +46,88 @@ class NamedSummariesDataFormatterTestCase(TestBase):
# Execute the cleanup function during test case tear down.
self.addTearDownHook(cleanup)
- self.runCmd("type summary add --summary-string \"AllUseIt: x=${var.x} {y=${var.y}} {z=${var.z}}\" --name AllUseIt")
- self.runCmd("type summary add --summary-string \"First: x=${var.x} y=${var.y} dummy=${var.dummy}\" First")
- self.runCmd("type summary add --summary-string \"Second: x=${var.x} y=${var.y%hex}\" Second")
- self.runCmd("type summary add --summary-string \"Third: x=${var.x} z=${var.z}\" Third")
-
+ self.runCmd(
+ "type summary add --summary-string \"AllUseIt: x=${var.x} {y=${var.y}} {z=${var.z}}\" --name AllUseIt")
+ self.runCmd(
+ "type summary add --summary-string \"First: x=${var.x} y=${var.y} dummy=${var.dummy}\" First")
+ self.runCmd(
+ "type summary add --summary-string \"Second: x=${var.x} y=${var.y%hex}\" Second")
+ self.runCmd(
+ "type summary add --summary-string \"Third: x=${var.x} z=${var.z}\" Third")
+
self.expect('type summary list', substrs=['AllUseIt'])
-
+
self.expect("frame variable first",
- substrs = ['First: x=12'])
+ substrs=['First: x=12'])
self.expect("frame variable first --summary AllUseIt",
- substrs = ['AllUseIt: x=12'])
-
+ substrs=['AllUseIt: x=12'])
+
# We *DO NOT* remember the summary choice anymore
self.expect("frame variable first", matching=False,
- substrs = ['AllUseIt: x=12'])
+ substrs=['AllUseIt: x=12'])
self.expect("frame variable first",
- substrs = ['First: x=12'])
+ substrs=['First: x=12'])
+
+ self.runCmd("thread step-over") # 2
- self.runCmd("thread step-over") # 2
-
self.expect("frame variable first",
- substrs = ['First: x=12'])
-
+ substrs=['First: x=12'])
+
self.expect("frame variable first --summary AllUseIt",
- substrs = ['AllUseIt: x=12',
- 'y=34'])
+ substrs=['AllUseIt: x=12',
+ 'y=34'])
self.expect("frame variable second --summary AllUseIt",
- substrs = ['AllUseIt: x=65',
- 'y=43.25'])
+ substrs=['AllUseIt: x=65',
+ 'y=43.25'])
self.expect("frame variable third --summary AllUseIt",
- substrs = ['AllUseIt: x=96',
- 'z=',
- 'E'])
+ substrs=['AllUseIt: x=96',
+ 'z=',
+ 'E'])
+
+ self.runCmd("thread step-over") # 3
- self.runCmd("thread step-over") # 3
-
self.expect("frame variable second",
- substrs = ['Second: x=65',
- 'y=0x'])
-
+ substrs=['Second: x=65',
+ 'y=0x'])
+
# <rdar://problem/11576143> decided that invalid summaries will raise an error
# instead of just defaulting to the base summary
- self.expect("frame variable second --summary NoSuchSummary",error=True,
- substrs = ['must specify a valid named summary'])
-
+ self.expect(
+ "frame variable second --summary NoSuchSummary",
+ error=True,
+ substrs=['must specify a valid named summary'])
+
self.runCmd("thread step-over")
-
- self.runCmd("type summary add --summary-string \"FirstAndFriends: x=${var.x} {y=${var.y}} {z=${var.z}}\" First --name FirstAndFriends")
-
+
+ self.runCmd(
+ "type summary add --summary-string \"FirstAndFriends: x=${var.x} {y=${var.y}} {z=${var.z}}\" First --name FirstAndFriends")
+
self.expect("frame variable first",
- substrs = ['FirstAndFriends: x=12',
- 'y=34'])
+ substrs=['FirstAndFriends: x=12',
+ 'y=34'])
self.runCmd("type summary delete First")
-
+
self.expect("frame variable first --summary FirstAndFriends",
- substrs = ['FirstAndFriends: x=12',
- 'y=34'])
-
+ substrs=['FirstAndFriends: x=12',
+ 'y=34'])
+
self.expect("frame variable first", matching=True,
- substrs = ['x = 12',
- 'y = 34'])
-
+ substrs=['x = 12',
+ 'y = 34'])
+
self.runCmd("type summary delete FirstAndFriends")
self.expect("type summary delete NoSuchSummary", error=True)
self.runCmd("type summary delete AllUseIt")
-
+
self.expect("frame variable first", matching=False,
- substrs = ['FirstAndFriends'])
+ substrs=['FirstAndFriends'])
- self.runCmd("thread step-over") # 4
+ self.runCmd("thread step-over") # 4
- self.expect("frame variable first",matching=False,
- substrs = ['FirstAndFriends: x=12',
- 'y=34'])
+ self.expect("frame variable first", matching=False,
+ substrs=['FirstAndFriends: x=12',
+ 'y=34'])