199451b44SJordan Rupprecht"""Test that importing modules in C works as expected.""" 299451b44SJordan Rupprecht 399451b44SJordan Rupprecht 499451b44SJordan Rupprechtimport os 599451b44SJordan Rupprecht 699451b44SJordan Rupprechtimport lldb 799451b44SJordan Rupprechtfrom lldbsuite.test.decorators import * 899451b44SJordan Rupprechtfrom lldbsuite.test.lldbtest import * 999451b44SJordan Rupprechtfrom lldbsuite.test import lldbutil 1099451b44SJordan Rupprecht 1199451b44SJordan Rupprecht 1299451b44SJordan Rupprechtclass CModulesTestCase(TestBase): 1399451b44SJordan Rupprecht @expectedFailureAll( 142c2eb5e6SMichał Górny oslist=["freebsd", "linux"], 15*2238dcc3SJonas Devlieghere bugnumber="http://llvm.org/pr23456 'fopen' has unknown return type", 16*2238dcc3SJonas Devlieghere ) 1799451b44SJordan Rupprecht @expectedFailureAll( 1899451b44SJordan Rupprecht oslist=["windows"], 19*2238dcc3SJonas Devlieghere bugnumber="llvm.org/pr24489: Name lookup not working correctly on Windows", 20*2238dcc3SJonas Devlieghere ) 2199451b44SJordan Rupprecht @skipIf(macos_version=["<", "10.12"]) 2299451b44SJordan Rupprecht @expectedFailureNetBSD 2399451b44SJordan Rupprecht def test_expr(self): 2499451b44SJordan Rupprecht self.build() 2599451b44SJordan Rupprecht exe = self.getBuildArtifact("a.out") 2699451b44SJordan Rupprecht self.runCmd("file " + exe, CURRENT_EXECUTABLE_SET) 2799451b44SJordan Rupprecht 2899451b44SJordan Rupprecht # Break inside the foo function which takes a bar_ptr argument. 2999451b44SJordan Rupprecht lldbutil.run_break_set_by_file_and_line( 30*2238dcc3SJonas Devlieghere self, "main.c", self.line, num_expected_locations=1, loc_exact=True 31*2238dcc3SJonas Devlieghere ) 3299451b44SJordan Rupprecht 3399451b44SJordan Rupprecht self.runCmd("run", RUN_SUCCEEDED) 3499451b44SJordan Rupprecht 3599451b44SJordan Rupprecht # The stop reason of the thread should be breakpoint. 36*2238dcc3SJonas Devlieghere self.expect( 37*2238dcc3SJonas Devlieghere "thread list", 38*2238dcc3SJonas Devlieghere STOPPED_DUE_TO_BREAKPOINT, 39*2238dcc3SJonas Devlieghere substrs=["stopped", "stop reason = breakpoint"], 40*2238dcc3SJonas Devlieghere ) 4199451b44SJordan Rupprecht 4299451b44SJordan Rupprecht # The breakpoint should have a hit count of 1. 439f0b5f9aSSYNOPSYS\georgiev lldbutil.check_breakpoint(self, bpno=1, expected_hit_count=1) 4499451b44SJordan Rupprecht 4599451b44SJordan Rupprecht # Enable logging of the imported AST. 4664c87a94SJonas Devlieghere log_file = self.getBuildArtifact("lldb-ast-log.txt") 4799451b44SJordan Rupprecht self.runCmd("log enable lldb ast -f '%s'" % log_file) 4899451b44SJordan Rupprecht 4999451b44SJordan Rupprecht self.expect( 5099451b44SJordan Rupprecht "expr -l objc++ -- @import Darwin; 3", 5199451b44SJordan Rupprecht VARIABLES_DISPLAYED_CORRECTLY, 52*2238dcc3SJonas Devlieghere substrs=["int", "3"], 53*2238dcc3SJonas Devlieghere ) 5499451b44SJordan Rupprecht 5599451b44SJordan Rupprecht # This expr command imports __sFILE with definition 5699451b44SJordan Rupprecht # (FILE is a typedef to __sFILE.) 5799451b44SJordan Rupprecht self.expect( 58*2238dcc3SJonas Devlieghere 'expr *fopen("/dev/zero", "w")', 5999451b44SJordan Rupprecht VARIABLES_DISPLAYED_CORRECTLY, 60*2238dcc3SJonas Devlieghere substrs=["FILE", "_close"], 61*2238dcc3SJonas Devlieghere ) 6299451b44SJordan Rupprecht 6399451b44SJordan Rupprecht # Check that the AST log contains exactly one definition of __sFILE. 6499451b44SJordan Rupprecht f = open(log_file) 6599451b44SJordan Rupprecht log_lines = f.readlines() 6699451b44SJordan Rupprecht f.close() 6799451b44SJordan Rupprecht os.remove(log_file) 68*2238dcc3SJonas Devlieghere self.assertEqual(" ".join(log_lines).count("struct __sFILE definition"), 1) 6999451b44SJordan Rupprecht 70*2238dcc3SJonas Devlieghere self.expect( 71*2238dcc3SJonas Devlieghere "expr *myFile", VARIABLES_DISPLAYED_CORRECTLY, substrs=["a", "5", "b", "9"] 72*2238dcc3SJonas Devlieghere ) 7399451b44SJordan Rupprecht 7499451b44SJordan Rupprecht self.expect( 7599451b44SJordan Rupprecht "expr MIN((uint64_t)2, (uint64_t)3)", 7699451b44SJordan Rupprecht VARIABLES_DISPLAYED_CORRECTLY, 77*2238dcc3SJonas Devlieghere substrs=["uint64_t", "2"], 78*2238dcc3SJonas Devlieghere ) 7999451b44SJordan Rupprecht 80*2238dcc3SJonas Devlieghere self.expect( 81*2238dcc3SJonas Devlieghere "expr stdin", VARIABLES_DISPLAYED_CORRECTLY, substrs=["(FILE *)", "0x"] 82*2238dcc3SJonas Devlieghere ) 8399451b44SJordan Rupprecht 8499451b44SJordan Rupprecht def setUp(self): 8599451b44SJordan Rupprecht # Call super's setUp(). 8699451b44SJordan Rupprecht TestBase.setUp(self) 8799451b44SJordan Rupprecht # Find the line number to break inside main(). 88*2238dcc3SJonas Devlieghere self.line = line_number("main.c", "// Set breakpoint 0 here.") 89