| #!/usr/bin/env vpython3 |
| |
| # Copyright (c) 2018 The WebRTC project authors. All Rights Reserved. |
| # |
| # Use of this source code is governed by a BSD-style license |
| # that can be found in the LICENSE file in the root of the source |
| # tree. An additional intellectual property rights grant can be found |
| # in the file PATENTS. All contributing project authors may |
| # be found in the AUTHORS file in the root of the source tree. |
| |
| from contextlib import contextmanager |
| |
| import multiprocessing |
| import os |
| import tempfile |
| import unittest |
| |
| # pylint: disable=invalid-name |
| gtest_parallel_wrapper = __import__('gtest-parallel-wrapper') |
| |
| |
| @contextmanager |
| def TemporaryDirectory(): |
| tmp_dir = tempfile.mkdtemp() |
| yield tmp_dir |
| os.rmdir(tmp_dir) |
| |
| |
| class GtestParallelWrapperHelpersTest(unittest.TestCase): |
| def testGetWorkersAsIs(self): |
| # pylint: disable=protected-access |
| self.assertEqual(gtest_parallel_wrapper._ParseWorkersOption('12'), 12) |
| |
| def testGetTwiceWorkers(self): |
| expected = 2 * multiprocessing.cpu_count() |
| # pylint: disable=protected-access |
| self.assertEqual(gtest_parallel_wrapper._ParseWorkersOption('2x'), expected) |
| |
| def testGetHalfWorkers(self): |
| expected = max(multiprocessing.cpu_count() // 2, 1) |
| # pylint: disable=protected-access |
| self.assertEqual(gtest_parallel_wrapper._ParseWorkersOption('0.5x'), |
| expected) |
| |
| |
| class GtestParallelWrapperTest(unittest.TestCase): |
| @classmethod |
| def _Expected(cls, gtest_parallel_args): |
| return ['--shard_index=0', '--shard_count=1'] + gtest_parallel_args |
| |
| def testOverwrite(self): |
| result = gtest_parallel_wrapper.ParseArgs( |
| ['--timeout=123', 'exec', '--timeout', '124']) |
| expected = self._Expected(['--timeout=124', 'exec']) |
| self.assertEqual(result.gtest_parallel_args, expected) |
| |
| def testMixing(self): |
| result = gtest_parallel_wrapper.ParseArgs( |
| ['--timeout=123', '--param1', 'exec', '--param2', '--timeout', '124']) |
| expected = self._Expected( |
| ['--timeout=124', 'exec', '--', '--param1', '--param2']) |
| self.assertEqual(result.gtest_parallel_args, expected) |
| |
| def testMixingPositional(self): |
| result = gtest_parallel_wrapper.ParseArgs([ |
| '--timeout=123', 'exec', '--foo1', 'bar1', '--timeout', '124', '--foo2', |
| 'bar2' |
| ]) |
| expected = self._Expected( |
| ['--timeout=124', 'exec', '--', '--foo1', 'bar1', '--foo2', 'bar2']) |
| self.assertEqual(result.gtest_parallel_args, expected) |
| |
| def testDoubleDash1(self): |
| result = gtest_parallel_wrapper.ParseArgs( |
| ['--timeout', '123', 'exec', '--', '--timeout', '124']) |
| expected = self._Expected( |
| ['--timeout=123', 'exec', '--', '--timeout', '124']) |
| self.assertEqual(result.gtest_parallel_args, expected) |
| |
| def testDoubleDash2(self): |
| result = gtest_parallel_wrapper.ParseArgs( |
| ['--timeout=123', '--', 'exec', '--timeout=124']) |
| expected = self._Expected(['--timeout=123', 'exec', '--', '--timeout=124']) |
| self.assertEqual(result.gtest_parallel_args, expected) |
| |
| def testArtifacts(self): |
| with TemporaryDirectory() as tmp_dir: |
| output_dir = os.path.join(tmp_dir, 'foo') |
| result = gtest_parallel_wrapper.ParseArgs( |
| ['exec', '--store-test-artifacts', '--output_dir', output_dir]) |
| exp_artifacts_dir = os.path.join(output_dir, 'test_artifacts') |
| exp = self._Expected([ |
| '--output_dir=' + output_dir, 'exec', '--', |
| '--test_artifacts_dir=' + exp_artifacts_dir |
| ]) |
| self.assertEqual(result.gtest_parallel_args, exp) |
| self.assertEqual(result.output_dir, output_dir) |
| self.assertEqual(result.test_artifacts_dir, exp_artifacts_dir) |
| |
| def testNoDirsSpecified(self): |
| result = gtest_parallel_wrapper.ParseArgs(['exec']) |
| self.assertEqual(result.output_dir, None) |
| self.assertEqual(result.test_artifacts_dir, None) |
| |
| def testOutputDirSpecified(self): |
| result = gtest_parallel_wrapper.ParseArgs( |
| ['exec', '--output_dir', '/tmp/foo']) |
| self.assertEqual(result.output_dir, '/tmp/foo') |
| self.assertEqual(result.test_artifacts_dir, None) |
| |
| def testJsonTestResults(self): |
| result = gtest_parallel_wrapper.ParseArgs( |
| ['--isolated-script-test-output', '/tmp/foo', 'exec']) |
| expected = self._Expected(['--dump_json_test_results=/tmp/foo', 'exec']) |
| self.assertEqual(result.gtest_parallel_args, expected) |
| |
| def testShortArg(self): |
| result = gtest_parallel_wrapper.ParseArgs(['-d', '/tmp/foo', 'exec']) |
| expected = self._Expected(['--output_dir=/tmp/foo', 'exec']) |
| self.assertEqual(result.gtest_parallel_args, expected) |
| self.assertEqual(result.output_dir, '/tmp/foo') |
| |
| def testBoolArg(self): |
| result = gtest_parallel_wrapper.ParseArgs( |
| ['--gtest_also_run_disabled_tests', 'exec']) |
| expected = self._Expected(['--gtest_also_run_disabled_tests', 'exec']) |
| self.assertEqual(result.gtest_parallel_args, expected) |
| |
| def testNoArgs(self): |
| result = gtest_parallel_wrapper.ParseArgs(['exec']) |
| expected = self._Expected(['exec']) |
| self.assertEqual(result.gtest_parallel_args, expected) |
| |
| def testDocExample(self): |
| with TemporaryDirectory() as tmp_dir: |
| output_dir = os.path.join(tmp_dir, 'foo') |
| result = gtest_parallel_wrapper.ParseArgs([ |
| 'some_test', '--some_flag=some_value', '--another_flag', |
| '--output_dir=' + output_dir, '--store-test-artifacts', |
| '--isolated-script-test-output=SOME_DIR', |
| '--isolated-script-test-perf-output=SOME_OTHER_DIR', '--foo=bar', |
| '--baz' |
| ]) |
| expected_artifacts_dir = os.path.join(output_dir, 'test_artifacts') |
| expected = self._Expected([ |
| '--output_dir=' + output_dir, '--dump_json_test_results=SOME_DIR', |
| 'some_test', '--', '--test_artifacts_dir=' + expected_artifacts_dir, |
| '--some_flag=some_value', '--another_flag', |
| '--isolated_script_test_perf_output=SOME_OTHER_DIR', '--foo=bar', |
| '--baz' |
| ]) |
| self.assertEqual(result.gtest_parallel_args, expected) |
| |
| def testStandardWorkers(self): |
| """Check integer value is passed as-is.""" |
| result = gtest_parallel_wrapper.ParseArgs(['--workers', '17', 'exec']) |
| expected = self._Expected(['--workers=17', 'exec']) |
| self.assertEqual(result.gtest_parallel_args, expected) |
| |
| def testTwoWorkersPerCpuCore(self): |
| result = gtest_parallel_wrapper.ParseArgs(['--workers', '2x', 'exec']) |
| workers = 2 * multiprocessing.cpu_count() |
| expected = self._Expected(['--workers=%s' % workers, 'exec']) |
| self.assertEqual(result.gtest_parallel_args, expected) |
| |
| def testUseHalfTheCpuCores(self): |
| result = gtest_parallel_wrapper.ParseArgs(['--workers', '0.5x', 'exec']) |
| workers = max(multiprocessing.cpu_count() // 2, 1) |
| expected = self._Expected(['--workers=%s' % workers, 'exec']) |
| self.assertEqual(result.gtest_parallel_args, expected) |
| |
| |
| if __name__ == '__main__': |
| unittest.main() |