mirror of
https://github.com/Gericom/teak-llvm.git
synced 2025-06-21 20:45:53 -04:00

expectedFailureWindows is equivalent to using the general expectedFailureAll decorator with oslist="windows". Additionally, by moving towards these common decorators we can solve the issue of having to support decorators that can be called with or without arguments. Once all decorators are always called with arguments, and this is enforced by design (because you can't specify the condition you're decorating for without passing an argument) the implementation of the decorators can become much simpler Differential Revision: http://reviews.llvm.org/D16936 llvm-svn: 260134
45 lines
1.5 KiB
Python
45 lines
1.5 KiB
Python
"""
|
|
Test calling std::String member functions.
|
|
"""
|
|
|
|
from __future__ import print_function
|
|
|
|
|
|
|
|
import lldb
|
|
from lldbsuite.test.decorators import *
|
|
from lldbsuite.test.lldbtest import *
|
|
from lldbsuite.test import lldbutil
|
|
|
|
class ExprCommandCallFunctionTestCase(TestBase):
|
|
|
|
mydir = TestBase.compute_mydir(__file__)
|
|
|
|
def setUp(self):
|
|
# Call super's setUp().
|
|
TestBase.setUp(self)
|
|
# Find the line number to break for main.c.
|
|
self.line = line_number('main.cpp',
|
|
'// Please test these expressions while stopped at this line:')
|
|
|
|
@expectedFailureIcc # llvm.org/pr14437, fails with ICC 13.1
|
|
@expectedFailureFreeBSD('llvm.org/pr17807') # Fails on FreeBSD buildbot
|
|
@expectedFailureAll(oslist=["windows"], bugnumber="llvm.org/pr21765")
|
|
def test_with(self):
|
|
"""Test calling std::String member function."""
|
|
self.build()
|
|
self.runCmd("file a.out", CURRENT_EXECUTABLE_SET)
|
|
|
|
# Some versions of GCC encode two locations for the 'return' statement in main.cpp
|
|
lldbutil.run_break_set_by_file_and_line (self, "main.cpp", self.line, num_expected_locations=-1, loc_exact=True)
|
|
|
|
self.runCmd("run", RUN_SUCCEEDED)
|
|
|
|
self.expect("print str",
|
|
substrs = ['Hello world'])
|
|
|
|
# Calling this function now succeeds, but we follow the typedef return type through to
|
|
# const char *, and thus don't invoke the Summary formatter.
|
|
self.expect("print str.c_str()",
|
|
substrs = ['Hello world'])
|