summaryrefslogtreecommitdiff
path: root/lldb/test/API/lang/cpp/const_static_integral_member_int128/TestConstStaticIntegralMemberInt128.py
blob: 2b73580ff6bba7d88eebb1aee189ca089a824736 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
"""
Tests const static data members as specified by C++11 [class.static.data]p3
with (u)int128_t types.
"""

import lldb
from lldbsuite.test.decorators import *
from lldbsuite.test.lldbtest import *
from lldbsuite.test import lldbutil


class TestCase(TestBase):
    # int128 is not available on 32-bit ARM.
    @skipIf(archs=["arm$"])
    def test_int128(self):
        self.build()
        lldbutil.run_to_source_breakpoint(
            self, "// break here", lldb.SBFileSpec("main.cpp")
        )

        # Try to use the (u)int128_t data members which are not supported at
        # the moment. Just verify that LLDB doesn't report an incorrect value
        # for them and just treats them as normal variables (which will lead
        # to linker errors as they are not defined anywhere).
        self.expect(
            "expr A::int128_max", error=True, substrs=["Couldn't look up symbols:"]
        )
        self.expect(
            "expr A::uint128_max", error=True, substrs=["Couldn't look up symbols:"]
        )
        self.expect(
            "expr A::int128_min", error=True, substrs=["Couldn't look up symbols:"]
        )
        self.expect(
            "expr A::uint128_min", error=True, substrs=["Couldn't look up symbols:"]
        )