Imported Upstream version 6.10.0.49

Former-commit-id: 1d6753294b2993e1fbf92de9366bb9544db4189b
This commit is contained in:
Xamarin Public Jenkins (auto-signing)
2020-01-16 16:38:04 +00:00
parent d94e79959b
commit 468663ddbb
48518 changed files with 2789335 additions and 61176 deletions

View File

@ -0,0 +1,13 @@
from __future__ import print_function
from lldbsuite.test import lldbtest
from lldbsuite.test import decorators
class NonExistentDecoratorTestCase(lldbtest.TestBase):
mydir = lldbtest.TestBase.compute_mydir(__file__)
@decorators.nonExistentDecorator(bugnumber="yt/1300")
def test(self):
"""Verify non-existent decorators are picked up by test runner."""
pass

View File

@ -0,0 +1,70 @@
#!/usr/bin/env python
"""
Tests that the event system reports issues during decorator
handling as errors.
"""
# System-provided imports
import os
import unittest
# Local-provided imports
import event_collector
class TestCatchInvalidDecorator(unittest.TestCase):
TEST_DIR = os.path.join(
os.path.dirname(__file__),
os.path.pardir,
"resources",
"invalid_decorator")
def test_with_whole_file(self):
"""
Test that a non-existent decorator generates a test-event error
when running all tests in the file.
"""
# Determine the test case file we're using.
test_file = os.path.join(self.TEST_DIR, "TestInvalidDecorator.py")
# Collect all test events generated for this file.
error_results = _filter_error_results(
event_collector.collect_events_whole_file(test_file))
self.assertGreater(
len(error_results),
0,
"At least one job or test error result should have been returned")
def test_with_function_filter(self):
"""
Test that a non-existent decorator generates a test-event error
when running a filtered test.
"""
# Collect all test events generated during running of tests
# in a given directory using a test name filter. Internally,
# this runs through a different code path that needs to be
# set up to catch exceptions.
error_results = _filter_error_results(
event_collector.collect_events_for_directory_with_filter(
self.TEST_DIR,
"NonExistentDecoratorTestCase.test"))
self.assertGreater(
len(error_results),
0,
"At least one job or test error result should have been returned")
def _filter_error_results(events):
# Filter out job result events.
return [
event
for event in events
if event.get("event", None) in ["job_result", "test_result"] and
event.get("status", None) == "error"
]
if __name__ == "__main__":
unittest.main()

View File

@ -0,0 +1,85 @@
from __future__ import absolute_import
from __future__ import print_function
import os
import subprocess
import sys
import tempfile
# noinspection PyUnresolvedReferences
from six.moves import cPickle
def path_to_dotest_py():
return os.path.join(
os.path.dirname(__file__),
os.path.pardir,
os.path.pardir,
os.path.pardir,
os.path.pardir,
os.path.pardir,
os.path.pardir,
"test",
"dotest.py")
def _make_pickled_events_filename():
with tempfile.NamedTemporaryFile(
prefix="lldb_test_event_pickled_event_output",
delete=False) as temp_file:
return temp_file.name
def _collect_events_with_command(command, events_filename):
# Run the single test with dotest.py, outputting
# the raw pickled events to a temp file.
with open(os.devnull, 'w') as dev_null_file:
subprocess.call(
command,
stdout=dev_null_file,
stderr=dev_null_file)
# Unpickle the events
events = []
if os.path.exists(events_filename):
with open(events_filename, "rb") as events_file:
while True:
try:
# print("reading event")
event = cPickle.load(events_file)
# print("read event: {}".format(event))
if event:
events.append(event)
except EOFError:
# This is okay.
break
os.remove(events_filename)
return events
def collect_events_whole_file(test_filename):
events_filename = _make_pickled_events_filename()
command = [
sys.executable,
path_to_dotest_py(),
"--inferior",
"--results-formatter=lldbsuite.test_event.formatter.pickled.RawPickledFormatter",
"--results-file={}".format(events_filename),
"-p",
os.path.basename(test_filename),
os.path.dirname(test_filename)]
return _collect_events_with_command(command, events_filename)
def collect_events_for_directory_with_filter(test_filename, filter_desc):
events_filename = _make_pickled_events_filename()
command = [
sys.executable,
path_to_dotest_py(),
"--inferior",
"--results-formatter=lldbsuite.test_event.formatter.pickled.RawPickledFormatter",
"--results-file={}".format(events_filename),
"-f",
filter_desc,
os.path.dirname(test_filename)]
return _collect_events_with_command(command, events_filename)