[Lldb-commits] [lldb] 85e7e3b - [lldb] Fix TestComplexInt on ARM

Raphael Isemann via lldb-commits lldb-commits at lists.llvm.org
Fri Jun 19 08:48:02 PDT 2020


Author: Raphael Isemann
Date: 2020-06-19T17:47:16+02:00
New Revision: 85e7e3b1c93ebdaaaf1f63d0d5b3b778e81fdd9c

URL: https://github.com/llvm/llvm-project/commit/85e7e3b1c93ebdaaaf1f63d0d5b3b778e81fdd9c
DIFF: https://github.com/llvm/llvm-project/commit/85e7e3b1c93ebdaaaf1f63d0d5b3b778e81fdd9c.diff

LOG: [lldb] Fix TestComplexInt on ARM

On the buildbot long and int have the same size but long and long long don't,
so the bug where we find the first type by size will produce a different error.
Make the test dynamic based on int/long/long long size to fix the bot.

Added: 
    

Modified: 
    lldb/test/API/lang/c/complex_int/TestComplexInt.py

Removed: 
    


################################################################################
diff  --git a/lldb/test/API/lang/c/complex_int/TestComplexInt.py b/lldb/test/API/lang/c/complex_int/TestComplexInt.py
index 8d9344ee0f7a..9bd0c3700def 100644
--- a/lldb/test/API/lang/c/complex_int/TestComplexInt.py
+++ b/lldb/test/API/lang/c/complex_int/TestComplexInt.py
@@ -16,12 +16,19 @@ def test(self):
         self.build()
         lldbutil.run_to_source_breakpoint(self, "// break here", lldb.SBFileSpec("main.c"))
 
+        long_size_eq_int = self.frame().EvaluateExpression("sizeof(long) == sizeof(int)")
+
         # FIXME: LLDB treats all complex ints as unsigned, so the value is wrong.
         self.expect_expr("complex_int", result_type="_Complex int", result_value="4294967295 + 4294967294i")
-        self.expect_expr("complex_long", result_type="_Complex long")
-
         self.expect_expr("complex_unsigned", result_type="_Complex int", result_value="1 + 2i")
-        self.expect_expr("complex_unsigned_long", result_type="_Complex long", result_value="1 + 2i")
+
+        # FIXME: We get the type wrong if long has the same size as int.
+        if long_size_eq_int.GetValue() == "true":
+            self.expect_expr("complex_long", result_type="_Complex int")
+            self.expect_expr("complex_unsigned_long", result_type="_Complex int", result_value="1 + 2i")
+        else:
+            self.expect_expr("complex_long", result_type="_Complex long")
+            self.expect_expr("complex_unsigned_long", result_type="_Complex long", result_value="1 + 2i")
 
     @no_debug_info_test
     def test_long_long(self):
@@ -30,5 +37,10 @@ def test_long_long(self):
 
         # FIXME: We get the type wrong if long has the same size as long long.
         # FIXME: LLDB treats all complex ints as unsigned, so the value is wrong.
-        self.expect_expr("complex_long_long", result_type="_Complex long")
-        self.expect_expr("complex_unsigned_long_long", result_type="_Complex long", result_value="1 + 2i")
+        long_size_eq_long_long = self.frame().EvaluateExpression("sizeof(long) == sizeof(long long)")
+        if long_size_eq_long_long.GetValue() == "true":
+            self.expect_expr("complex_long_long", result_type="_Complex long")
+            self.expect_expr("complex_unsigned_long_long", result_type="_Complex long", result_value="1 + 2i")
+        else:
+            self.expect_expr("complex_long_long", result_type="_Complex long long")
+            self.expect_expr("complex_unsigned_long_long", result_type="_Complex long long", result_value="1 + 2i")


        


More information about the lldb-commits mailing list