[resultdb] Make suffixes more distinguishable
Test ids would get an uniform format between different kinds of tests: prefix//test_id//suffix - prefix: - empty for regular tests - or 'special test' token, as in 'numfuzz' - test_id is the full name of the test as generated by test runner: - suite_name/path/to/actual/test_name - suffix is anything a test runner processor might want to add to the name: - numfuzz processor will add 'analysis' of a numeric value - variant processor will add the variant name Bug: v8:13316 Change-Id: Ied8f958173f82d8e26c62e39ccc21167ca2928ab Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/4084763 Commit-Queue: Liviu Rau <liviurau@google.com> Reviewed-by: Michael Achenbach <machenbach@chromium.org> Cr-Commit-Position: refs/heads/main@{#84736}
This commit is contained in:
parent
ada6f41e91
commit
46efa1b1c8
@ -460,11 +460,18 @@ class TestCase(object):
|
|||||||
def __str__(self):
|
def __str__(self):
|
||||||
return self.full_name
|
return self.full_name
|
||||||
|
|
||||||
|
def test_suffixes(self):
|
||||||
|
suffixes = self.origin.test_suffixes() if self.origin else []
|
||||||
|
current_suffix = self.processor.test_suffix(self)
|
||||||
|
if current_suffix:
|
||||||
|
suffixes.append(str(current_suffix))
|
||||||
|
return suffixes
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def rdb_test_id(self):
|
def rdb_test_id(self):
|
||||||
rdb_id = self.origin.rdb_test_id if self.origin else self.full_name
|
suffixes = '/'.join(self.test_suffixes())
|
||||||
rdb_id += self.processor.test_suffix(self)
|
full_suffix = ('//' + suffixes) if suffixes else ''
|
||||||
return rdb_id
|
return self.full_name + full_suffix
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def processor_name(self):
|
def processor_name(self):
|
||||||
@ -475,7 +482,7 @@ class DuckProcessor:
|
|||||||
"""Dummy default processor for original tests implemented by duck-typing."""
|
"""Dummy default processor for original tests implemented by duck-typing."""
|
||||||
|
|
||||||
def test_suffix(self, test):
|
def test_suffix(self, test):
|
||||||
return ''
|
return None
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def name(self):
|
def name(self):
|
||||||
|
@ -31,14 +31,15 @@ class TestCaseTest(unittest.TestCase):
|
|||||||
self.assertEqual(test.keep_output, False)
|
self.assertEqual(test.keep_output, False)
|
||||||
|
|
||||||
subtest = test.create_subtest(FakeProcessor(), 0, keep_output=True)
|
subtest = test.create_subtest(FakeProcessor(), 0, keep_output=True)
|
||||||
self.assertEqual(subtest.rdb_test_id, 'fakeSuite/parent/fakep/0')
|
self.assertEqual(subtest.rdb_test_id, 'fakeSuite/parent//fakep/0')
|
||||||
# provide by FakeProcessor
|
# provide by FakeProcessor
|
||||||
self.assertEqual(subtest.processor.name, 'fake_processor1')
|
self.assertEqual(subtest.processor.name, 'fake_processor1')
|
||||||
self.assertEqual(subtest.procid, 'fakeSuite/parent.fake_processor1-0')
|
self.assertEqual(subtest.procid, 'fakeSuite/parent.fake_processor1-0')
|
||||||
self.assertEqual(subtest.keep_output, True)
|
self.assertEqual(subtest.keep_output, True)
|
||||||
|
|
||||||
subsubtest = subtest.create_subtest(FakeProcessor(), 1)
|
subsubtest = subtest.create_subtest(FakeProcessor(), 1)
|
||||||
self.assertEqual(subsubtest.rdb_test_id, 'fakeSuite/parent/fakep/0/fakep/1')
|
self.assertEqual(subsubtest.rdb_test_id,
|
||||||
|
'fakeSuite/parent//fakep/0/fakep/1')
|
||||||
# provide by FakeProcessor
|
# provide by FakeProcessor
|
||||||
self.assertEqual(subsubtest.processor.name, 'fake_processor2')
|
self.assertEqual(subsubtest.processor.name, 'fake_processor2')
|
||||||
self.assertEqual(subsubtest.procid,
|
self.assertEqual(subsubtest.procid,
|
||||||
@ -68,7 +69,7 @@ class FakeProcessor:
|
|||||||
return f'fake_processor{self.idx}'
|
return f'fake_processor{self.idx}'
|
||||||
|
|
||||||
def test_suffix(self, test):
|
def test_suffix(self, test):
|
||||||
return f'/fakep/{test.subtest_id}'
|
return f'fakep/{test.subtest_id}'
|
||||||
|
|
||||||
|
|
||||||
if __name__ == '__main__':
|
if __name__ == '__main__':
|
||||||
|
@ -179,15 +179,15 @@ class StandardRunnerTest(TestRunnerTest):
|
|||||||
)
|
)
|
||||||
|
|
||||||
self.assertEquals(len(records), 3)
|
self.assertEquals(len(records), 3)
|
||||||
self.assertEquals(records[0]['testId'], 'sweet/bananaflakes/stress')
|
self.assertEquals(records[0]['testId'], 'sweet/bananaflakes//stress')
|
||||||
self.assertEquals(tag_dict(records[0]['tags'])['run'], '1')
|
self.assertEquals(tag_dict(records[0]['tags'])['run'], '1')
|
||||||
self.assertFalse(records[0]['expected'])
|
self.assertFalse(records[0]['expected'])
|
||||||
|
|
||||||
self.assertEquals(records[1]['testId'], 'sweet/bananaflakes/stress')
|
self.assertEquals(records[1]['testId'], 'sweet/bananaflakes//stress')
|
||||||
self.assertEquals(tag_dict(records[1]['tags'])['run'], '2')
|
self.assertEquals(tag_dict(records[1]['tags'])['run'], '2')
|
||||||
self.assertTrue(records[1]['expected'])
|
self.assertTrue(records[1]['expected'])
|
||||||
|
|
||||||
self.assertEquals(records[2]['testId'], 'sweet/bananaflakes/default')
|
self.assertEquals(records[2]['testId'], 'sweet/bananaflakes//default')
|
||||||
self.assertEquals(tag_dict(records[2]['tags'])['run'], '1')
|
self.assertEquals(tag_dict(records[2]['tags'])['run'], '1')
|
||||||
self.assertTrue(records[2]['expected'])
|
self.assertTrue(records[2]['expected'])
|
||||||
|
|
||||||
|
@ -163,7 +163,7 @@ class TestProcProducer(TestProc):
|
|||||||
|
|
||||||
def test_suffix(self, test):
|
def test_suffix(self, test):
|
||||||
"""Default implementation of rdb test id suffix generated by a producer"""
|
"""Default implementation of rdb test id suffix generated by a producer"""
|
||||||
return ''
|
return None
|
||||||
|
|
||||||
|
|
||||||
class TestProcFilter(TestProc):
|
class TestProcFilter(TestProc):
|
||||||
|
@ -173,7 +173,7 @@ class FuzzerProc(base.TestProcProducer):
|
|||||||
self._gens = {}
|
self._gens = {}
|
||||||
|
|
||||||
def test_suffix(self, test):
|
def test_suffix(self, test):
|
||||||
return '/' + test.subtest_id
|
return test.subtest_id
|
||||||
|
|
||||||
def _next_test(self, test):
|
def _next_test(self, test):
|
||||||
if self.is_stopped:
|
if self.is_stopped:
|
||||||
|
@ -29,7 +29,7 @@ class VariantProc(base.TestProcProducer):
|
|||||||
self._variants = variants
|
self._variants = variants
|
||||||
|
|
||||||
def test_suffix(self, test):
|
def test_suffix(self, test):
|
||||||
return f'/{test.variant}'
|
return test.variant
|
||||||
|
|
||||||
def _next_test(self, test):
|
def _next_test(self, test):
|
||||||
gen = self._variants_gen(test)
|
gen = self._variants_gen(test)
|
||||||
|
Loading…
Reference in New Issue
Block a user