[PATCH] D51930: Add a basic test for 'memory region'
Raphael Isemann via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Wed Sep 12 03:05:55 PDT 2018
This revision was automatically updated to reflect the committed changes.
Closed by commit rL342042: Add a basic test for 'memory region' (authored by teemperor, committed by ).
Herald added a subscriber: llvm-commits.
Changed prior to commit:
https://reviews.llvm.org/D51930?vs=164862&id=165045#toc
Repository:
rL LLVM
https://reviews.llvm.org/D51930
Files:
lldb/trunk/packages/Python/lldbsuite/test/functionalities/memory-region/Makefile
lldb/trunk/packages/Python/lldbsuite/test/functionalities/memory-region/TestMemoryRegion.py
lldb/trunk/packages/Python/lldbsuite/test/functionalities/memory-region/main.cpp
Index: lldb/trunk/packages/Python/lldbsuite/test/functionalities/memory-region/main.cpp
===================================================================
--- lldb/trunk/packages/Python/lldbsuite/test/functionalities/memory-region/main.cpp
+++ lldb/trunk/packages/Python/lldbsuite/test/functionalities/memory-region/main.cpp
@@ -0,0 +1,6 @@
+#include <iostream>
+
+int main (int argc, char const **argv) {
+ std::cout << "Program with sections" << std::endl;
+ return 0; // Run here before printing memory regions
+}
Index: lldb/trunk/packages/Python/lldbsuite/test/functionalities/memory-region/TestMemoryRegion.py
===================================================================
--- lldb/trunk/packages/Python/lldbsuite/test/functionalities/memory-region/TestMemoryRegion.py
+++ lldb/trunk/packages/Python/lldbsuite/test/functionalities/memory-region/TestMemoryRegion.py
@@ -0,0 +1,59 @@
+"""
+Test the 'memory region' command.
+"""
+
+from __future__ import print_function
+
+
+import lldb
+from lldbsuite.test.decorators import *
+from lldbsuite.test.lldbtest import *
+from lldbsuite.test import lldbutil
+
+
+class MemoryCommandRegion(TestBase):
+
+ mydir = TestBase.compute_mydir(__file__)
+
+ NO_DEBUG_INFO_TESTCASE = True
+
+ def setUp(self):
+ TestBase.setUp(self)
+ # Find the line number to break for main.c.
+ self.line = line_number(
+ 'main.cpp',
+ '// Run here before printing memory regions')
+
+ def test(self):
+ self.build()
+
+ # Set breakpoint in main and run
+ self.runCmd("file " + self.getBuildArtifact("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)
+
+ self.runCmd("run", RUN_SUCCEEDED)
+
+ interp = self.dbg.GetCommandInterpreter()
+ result = lldb.SBCommandReturnObject()
+
+ # Test that the first 'memory region' command prints the usage.
+ interp.HandleCommand("memory region", result)
+ self.assertFalse(result.Succeeded())
+ self.assertRegexpMatches(result.GetError(), "Usage: memory region ADDR")
+
+ # Now let's print the memory region starting at 0 which should always work.
+ interp.HandleCommand("memory region 0x0", result)
+ self.assertTrue(result.Succeeded())
+ self.assertRegexpMatches(result.GetOutput(), "\\[0x0+-")
+
+ # Keep printing memory regions until we printed all of them.
+ while True:
+ interp.HandleCommand("memory region", result)
+ if not result.Succeeded():
+ break
+
+ # Now that we reached the end, 'memory region' should again print the usage.
+ interp.HandleCommand("memory region", result)
+ self.assertFalse(result.Succeeded())
+ self.assertRegexpMatches(result.GetError(), "Usage: memory region ADDR")
Index: lldb/trunk/packages/Python/lldbsuite/test/functionalities/memory-region/Makefile
===================================================================
--- lldb/trunk/packages/Python/lldbsuite/test/functionalities/memory-region/Makefile
+++ lldb/trunk/packages/Python/lldbsuite/test/functionalities/memory-region/Makefile
@@ -0,0 +1,8 @@
+LEVEL = ../../make
+
+CXX_SOURCES := main.cpp
+
+include $(LEVEL)/Makefile.rules
+
+clean::
+ rm -rf $(wildcard *.o *.d *.dSYM)
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D51930.165045.patch
Type: text/x-patch
Size: 3396 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20180912/d5d8dfd4/attachment.bin>
More information about the llvm-commits
mailing list