# Copyright 2017 The Chromium OS Authors. All rights reserved. # Use of this source code is governed by a BSD-style license that can be # found in the LICENSE file. import os import unittest import tradefed_test def _load_data(filename): """Loads the test data of the given file name.""" with open(os.path.join(os.path.dirname(os.path.realpath(__file__)), 'tradefed_test_unittest_data', filename), 'r') as f: return f.read() class TradefedTestTest(unittest.TestCase): """Unittest for tradefed_test.""" def test_parse_tradefed_result(self): """Test for parse_tradefed_result.""" waivers = set([ 'android.app.cts.SystemFeaturesTest#testUsbAccessory', 'android.widget.cts.GridViewTest#testSetNumColumns', ]) # b/35605415 and b/36520623 # http://pantheon/storage/browser/chromeos-autotest-results/108103986-chromeos-test/ # CTS: Tradefed may split a module to multiple chunks. # Besides, the module name may not end with "TestCases". self.assertEquals((35, 33, 2, 0, 0), tradefed_test.parse_tradefed_result( _load_data('CtsHostsideNetworkTests.txt'), waivers=waivers)) # b/35530394 # http://pantheon/storage/browser/chromeos-autotest-results/108291418-chromeos-test/ # Crashed, but the automatic retry by tradefed executed the rest. self.assertEquals((1395, 1386, 9, 0, 0), tradefed_test.parse_tradefed_result( _load_data('CtsMediaTestCases.txt'), waivers=waivers)) # b/35530394 # http://pantheon/storage/browser/chromeos-autotest-results/106540705-chromeos-test/ # Crashed in the middle, and the device didn't came back. self.assertEquals((110, 27, 1, 82, 0), tradefed_test.parse_tradefed_result( _load_data('CtsSecurityTestCases.txt'), waivers=waivers)) # b/36629187 # http://pantheon/storage/browser/chromeos-autotest-results/108855595-chromeos-test/ # Crashed in the middle. Tradefed decided not to continue. self.assertEquals((739, 573, 3, 163, 0), tradefed_test.parse_tradefed_result( _load_data('CtsViewTestCases.txt'), waivers=waivers)) # b/36375690 # http://pantheon/storage/browser/chromeos-autotest-results/109040174-chromeos-test/ # Mixture of real failures and waivers. self.assertEquals((321, 316, 5, 0, 1), tradefed_test.parse_tradefed_result( _load_data('CtsAppTestCases.txt'), waivers=waivers)) # ... and the retry of the above failing iteration. self.assertEquals((5, 1, 4, 0, 1), tradefed_test.parse_tradefed_result( _load_data('CtsAppTestCases-retry.txt'), waivers=waivers)) # http://pantheon/storage/browser/chromeos-autotest-results/116875512-chromeos-test/ # When a test case crashed during teardown, tradefed prints the "fail" # message twice. Tolerate it and still return an (inconsistent) count. self.assertEquals((1194, 1185, 10, 0, 2), tradefed_test.parse_tradefed_result( _load_data('CtsWidgetTestCases.txt'), waivers=waivers)) # http://pantheon/storage/browser/chromeos-autotest-results/117914707-chromeos-test/ # When a test case unrecoverably crashed during teardown, tradefed # prints the "fail" and failure summary message twice. Tolerate it. self.assertEquals((71, 70, 1, 0, 0), tradefed_test.parse_tradefed_result( _load_data('CtsPrintTestCases.txt'), waivers=waivers)) gts_waivers = set([ ('com.google.android.placement.gts.CoreGmsAppsTest#' + 'testCoreGmsAppsPreloaded'), ('com.google.android.placement.gts.CoreGmsAppsTest#' + 'testGoogleDuoPreloaded'), 'com.google.android.placement.gts.UiPlacementTest#testPlayStore' ]) # crbug.com/748116 # http://pantheon/storage/browser/chromeos-autotest-results/130080763-chromeos-test/ # 3 ABIS: x86, x86_64, and armeabi-v7a self.assertEquals((15, 6, 9, 0, 9), tradefed_test.parse_tradefed_result( _load_data('GtsPlacementTestCases.txt'), waivers=gts_waivers)) # b/64095702 # http://pantheon/storage/browser/chromeos-autotest-results/130211812-chromeos-test/ # The result of the last chunk not reported by tradefed. # The actual dEQP log is too big, hence the test data here is trimmed. self.assertEquals((157871, 116916, 0, 40955, 0), tradefed_test.parse_tradefed_result( _load_data('CtsDeqpTestCases-trimmed.txt'), waivers=waivers)) if __name__ == '__main__': unittest.main()