diff options
Diffstat (limited to 'packages/Python/lldbsuite/test/python_api/frame/get-variables')
| -rw-r--r-- | packages/Python/lldbsuite/test/python_api/frame/get-variables/TestGetVariables.py | 210 | 
1 files changed, 158 insertions, 52 deletions
| diff --git a/packages/Python/lldbsuite/test/python_api/frame/get-variables/TestGetVariables.py b/packages/Python/lldbsuite/test/python_api/frame/get-variables/TestGetVariables.py index 914c3d25fd5d..86585d8d02e2 100644 --- a/packages/Python/lldbsuite/test/python_api/frame/get-variables/TestGetVariables.py +++ b/packages/Python/lldbsuite/test/python_api/frame/get-variables/TestGetVariables.py @@ -5,20 +5,22 @@ Test that SBFrame::GetVariables() calls work correctly.  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 lldbplatform  from lldbsuite.test import lldbutil +  def get_names_from_value_list(value_list):      names = list()      for value in value_list:          names.append(value.GetName())      return names +  class TestGetVariables(TestBase):      mydir = TestBase.compute_mydir(__file__) @@ -35,12 +37,16 @@ class TestGetVariables(TestBase):              if name in copy_names:                  copy_names.remove(name)              else: -                self.assertTrue(False, "didn't find '%s' in %s" % (name, copy_names)) -        self.assertEqual(len(copy_names), 0, "%s: we didn't find variables: %s in value list (%s)" % (description, copy_names, actual_names)) +                self.assertTrue( +                    False, "didn't find '%s' in %s" % +                    (name, copy_names)) +        self.assertEqual( +            len(copy_names), 0, "%s: we didn't find variables: %s in value list (%s)" % +            (description, copy_names, actual_names)) + +    def test(self): +        self.build() -    def test (self): -        self.build () -                  # Set debugger into synchronous mode          self.dbg.SetAsync(False) @@ -48,36 +54,42 @@ class TestGetVariables(TestBase):          exe = os.path.join(os.getcwd(), "a.out")          target = self.dbg.CreateTarget(exe)          self.assertTrue(target, VALID_TARGET) -                                                                               +          line1 = line_number(self.source, '// breakpoint 1')          line2 = line_number(self.source, '// breakpoint 2')          line3 = line_number(self.source, '// breakpoint 3') -        breakpoint1 = target.BreakpointCreateByLocation (self.source, line1); -        breakpoint2 = target.BreakpointCreateByLocation (self.source, line2); -        breakpoint3 = target.BreakpointCreateByLocation (self.source, line3); +        breakpoint1 = target.BreakpointCreateByLocation(self.source, line1) +        breakpoint2 = target.BreakpointCreateByLocation(self.source, line2) +        breakpoint3 = target.BreakpointCreateByLocation(self.source, line3)          self.assertTrue(breakpoint1.GetNumLocations() >= 1, PROCESS_IS_VALID)          self.assertTrue(breakpoint2.GetNumLocations() >= 1, PROCESS_IS_VALID)          self.assertTrue(breakpoint3.GetNumLocations() >= 1, PROCESS_IS_VALID) -        # Register our shared libraries for remote targets so they get automatically uploaded +        # Register our shared libraries for remote targets so they get +        # automatically uploaded          arguments = None -        environment = None  +        environment = None          # Now launch the process, and do not stop at entry point. -        process = target.LaunchSimple (arguments, environment, self.get_process_working_directory()) +        process = target.LaunchSimple( +            arguments, environment, self.get_process_working_directory())          self.assertTrue(process, PROCESS_IS_VALID) -         -        threads = lldbutil.get_threads_stopped_at_breakpoint (process, breakpoint1) -        self.assertEqual(len(threads), 1, "There should be a thread stopped at breakpoint 1") -                         + +        threads = lldbutil.get_threads_stopped_at_breakpoint( +            process, breakpoint1) +        self.assertEqual( +            len(threads), +            1, +            "There should be a thread stopped at breakpoint 1") +          thread = threads[0]          self.assertTrue(thread.IsValid(), "Thread must be valid")          frame = thread.GetFrameAtIndex(0)          self.assertTrue(frame.IsValid(), "Frame must be valid") -         -        arg_names = ['argc', 'argv']    + +        arg_names = ['argc', 'argv']          local_names = ['i', 'j', 'k']          static_names = ['static_var', 'g_global_var', 'g_static_var']          breakpoint1_locals = ['i'] @@ -95,96 +107,190 @@ class TestGetVariables(TestBase):          ignore_scope = False          # Verify if we ask for only arguments that we got what we expect -        vars = frame.GetVariables(args_yes, locals_no, statics_no, ignore_scope) -        self.assertEqual(vars.GetSize(), num_args, "There should be %i arguments, but we are reporting %i" % (num_args, vars.GetSize()))     +        vars = frame.GetVariables( +            args_yes, locals_no, statics_no, ignore_scope) +        self.assertEqual( +            vars.GetSize(), +            num_args, +            "There should be %i arguments, but we are reporting %i" % +            (num_args, +             vars.GetSize()))          self.verify_variable_names("check names of arguments", vars, arg_names) -        self.assertEqual(len(arg_names), num_args, "make sure verify_variable_names() didn't mutate list") +        self.assertEqual( +            len(arg_names), +            num_args, +            "make sure verify_variable_names() didn't mutate list")          # Verify if we ask for only locals that we got what we expect -        vars = frame.GetVariables(args_no, locals_yes, statics_no, ignore_scope)    -        self.assertEqual(vars.GetSize(), num_locals, "There should be %i local variables, but we are reporting %i" % (num_locals, vars.GetSize()))     +        vars = frame.GetVariables( +            args_no, locals_yes, statics_no, ignore_scope) +        self.assertEqual( +            vars.GetSize(), +            num_locals, +            "There should be %i local variables, but we are reporting %i" % +            (num_locals, +             vars.GetSize()))          self.verify_variable_names("check names of locals", vars, local_names)          # Verify if we ask for only statics that we got what we expect -        vars = frame.GetVariables(args_no, locals_no, statics_yes, ignore_scope)    +        vars = frame.GetVariables( +            args_no, locals_no, statics_yes, ignore_scope)          print('statics: ', str(vars)) -        self.assertEqual(vars.GetSize(), num_statics, "There should be %i static variables, but we are reporting %i" % (num_statics, vars.GetSize()))     -        self.verify_variable_names("check names of statics", vars, static_names) +        self.assertEqual( +            vars.GetSize(), +            num_statics, +            "There should be %i static variables, but we are reporting %i" % +            (num_statics, +             vars.GetSize())) +        self.verify_variable_names( +            "check names of statics", vars, static_names)          # Verify if we ask for arguments and locals that we got what we expect -        vars = frame.GetVariables(args_yes, locals_yes, statics_no, ignore_scope) +        vars = frame.GetVariables( +            args_yes, locals_yes, statics_no, ignore_scope)          desc = 'arguments + locals'          names = arg_names + local_names          count = len(names) -        self.assertEqual(vars.GetSize(), count, "There should be %i %s (%s) but we are reporting %i (%s)" % (count, desc, names, vars.GetSize(), get_names_from_value_list(vars)))     +        self.assertEqual( +            vars.GetSize(), +            count, +            "There should be %i %s (%s) but we are reporting %i (%s)" % +            (count, +             desc, +             names, +             vars.GetSize(), +             get_names_from_value_list(vars)))          self.verify_variable_names("check names of %s" % (desc), vars, names)          # Verify if we ask for arguments and statics that we got what we expect -        vars = frame.GetVariables(args_yes, locals_no, statics_yes, ignore_scope) +        vars = frame.GetVariables( +            args_yes, locals_no, statics_yes, ignore_scope)          desc = 'arguments + statics'          names = arg_names + static_names          count = len(names) -        self.assertEqual(vars.GetSize(), count, "There should be %i %s (%s) but we are reporting %i (%s)" % (count, desc, names, vars.GetSize(), get_names_from_value_list(vars)))     +        self.assertEqual( +            vars.GetSize(), +            count, +            "There should be %i %s (%s) but we are reporting %i (%s)" % +            (count, +             desc, +             names, +             vars.GetSize(), +             get_names_from_value_list(vars)))          self.verify_variable_names("check names of %s" % (desc), vars, names)          # Verify if we ask for locals and statics that we got what we expect -        vars = frame.GetVariables(args_no, locals_yes, statics_yes, ignore_scope) +        vars = frame.GetVariables( +            args_no, locals_yes, statics_yes, ignore_scope)          desc = 'locals + statics'          names = local_names + static_names          count = len(names) -        self.assertEqual(vars.GetSize(), count, "There should be %i %s (%s) but we are reporting %i (%s)" % (count, desc, names, vars.GetSize(), get_names_from_value_list(vars)))     +        self.assertEqual( +            vars.GetSize(), +            count, +            "There should be %i %s (%s) but we are reporting %i (%s)" % +            (count, +             desc, +             names, +             vars.GetSize(), +             get_names_from_value_list(vars)))          self.verify_variable_names("check names of %s" % (desc), vars, names) -        # Verify if we ask for arguments, locals and statics that we got what we expect -        vars = frame.GetVariables(args_yes, locals_yes, statics_yes, ignore_scope) +        # Verify if we ask for arguments, locals and statics that we got what +        # we expect +        vars = frame.GetVariables( +            args_yes, locals_yes, statics_yes, ignore_scope)          desc = 'arguments + locals + statics'          names = arg_names + local_names + static_names          count = len(names) -        self.assertEqual(vars.GetSize(), count, "There should be %i %s (%s) but we are reporting %i (%s)" % (count, desc, names, vars.GetSize(), get_names_from_value_list(vars)))     +        self.assertEqual( +            vars.GetSize(), +            count, +            "There should be %i %s (%s) but we are reporting %i (%s)" % +            (count, +             desc, +             names, +             vars.GetSize(), +             get_names_from_value_list(vars)))          self.verify_variable_names("check names of %s" % (desc), vars, names)          # Verify if we ask for in scope locals that we got what we expect -        vars = frame.GetVariables(args_no, locals_yes, statics_no, in_scopy_only)    +        vars = frame.GetVariables( +            args_no, locals_yes, statics_no, in_scopy_only)          desc = 'in scope locals at breakpoint 1'          names = ['i']          count = len(names) -        self.assertEqual(vars.GetSize(), count, "There should be %i %s (%s) but we are reporting %i (%s)" % (count, desc, names, vars.GetSize(), get_names_from_value_list(vars)))     +        self.assertEqual( +            vars.GetSize(), +            count, +            "There should be %i %s (%s) but we are reporting %i (%s)" % +            (count, +             desc, +             names, +             vars.GetSize(), +             get_names_from_value_list(vars)))          self.verify_variable_names("check names of %s" % (desc), vars, names) -                              +          # Continue to breakpoint 2          process.Continue() -                                      -        threads = lldbutil.get_threads_stopped_at_breakpoint (process, breakpoint2) -        self.assertEqual(len(threads), 1, "There should be a thread stopped at breakpoint 2") -                         + +        threads = lldbutil.get_threads_stopped_at_breakpoint( +            process, breakpoint2) +        self.assertEqual( +            len(threads), +            1, +            "There should be a thread stopped at breakpoint 2") +          thread = threads[0]          self.assertTrue(thread.IsValid(), "Thread must be valid")          frame = thread.GetFrameAtIndex(0)          self.assertTrue(frame.IsValid(), "Frame must be valid")          # Verify if we ask for in scope locals that we got what we expect -        vars = frame.GetVariables(args_no, locals_yes, statics_no, in_scopy_only)    +        vars = frame.GetVariables( +            args_no, locals_yes, statics_no, in_scopy_only)          desc = 'in scope locals at breakpoint 2'          names = ['i', 'j']          count = len(names) -        self.assertEqual(vars.GetSize(), count, "There should be %i %s (%s) but we are reporting %i (%s)" % (count, desc, names, vars.GetSize(), get_names_from_value_list(vars)))     +        self.assertEqual( +            vars.GetSize(), +            count, +            "There should be %i %s (%s) but we are reporting %i (%s)" % +            (count, +             desc, +             names, +             vars.GetSize(), +             get_names_from_value_list(vars)))          self.verify_variable_names("check names of %s" % (desc), vars, names)          # Continue to breakpoint 3          process.Continue() -                                      -        threads = lldbutil.get_threads_stopped_at_breakpoint (process, breakpoint3) -        self.assertEqual(len(threads), 1, "There should be a thread stopped at breakpoint 3") -                         + +        threads = lldbutil.get_threads_stopped_at_breakpoint( +            process, breakpoint3) +        self.assertEqual( +            len(threads), +            1, +            "There should be a thread stopped at breakpoint 3") +          thread = threads[0]          self.assertTrue(thread.IsValid(), "Thread must be valid")          frame = thread.GetFrameAtIndex(0)          self.assertTrue(frame.IsValid(), "Frame must be valid")          # Verify if we ask for in scope locals that we got what we expect -        vars = frame.GetVariables(args_no, locals_yes, statics_no, in_scopy_only)    +        vars = frame.GetVariables( +            args_no, locals_yes, statics_no, in_scopy_only)          desc = 'in scope locals at breakpoint 3'          names = ['i', 'j', 'k']          count = len(names) -        self.assertEqual(vars.GetSize(), count, "There should be %i %s (%s) but we are reporting %i (%s)" % (count, desc, names, vars.GetSize(), get_names_from_value_list(vars)))     +        self.assertEqual( +            vars.GetSize(), +            count, +            "There should be %i %s (%s) but we are reporting %i (%s)" % +            (count, +             desc, +             names, +             vars.GetSize(), +             get_names_from_value_list(vars)))          self.verify_variable_names("check names of %s" % (desc), vars, names) | 
