llvm/lldb/test/API/commands/expression/static-initializers/TestStaticInitializers.py

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


class StaticInitializers(TestBase):
    @expectedFailureAll(
        archs="aarch64",
        oslist=["freebsd"],
        bugnumber="llvm.org/pr44053",
    )
    def test(self):
        """Test a static initializer."""
        self.build()

        lldbutil.run_to_source_breakpoint(
            self, "// break here", lldb.SBFileSpec("main.cpp", False)
        )

        # We use counter to observe if the initializer was called.
        self.expect_expr("counter", result_type="int", result_value="0")
        self.expect("expr -p -- struct Foo { Foo() { inc_counter(); } }; Foo f;")
        self.expect_expr("counter", result_type="int", result_value="1")

    def test_failing_init(self):
        """Test a static initializer that fails to execute."""
        self.build()

        lldbutil.run_to_source_breakpoint(
            self, "// break here", lldb.SBFileSpec("main.cpp", False)
        )

        # FIXME: This error message is not even remotely helpful.
        self.expect(
            "expr -p -- struct Foo2 { Foo2() { do_abort(); } }; Foo2 f;",
            error=True,
            substrs=["couldn't run static initializer:"],
        )

    def test_without_process(self):
        """Test a static initializer without a running process."""
        self.expect(
            "expr -p -- int i = 0; struct Foo3 { Foo3() { ++i; } }; Foo3 f;",
            error=True,
            substrs=["Top-level code needs to be inserted into a runnable target"],
        )