diff options
author | Klement Sekera <ksekera@cisco.com> | 2021-04-08 19:37:41 +0200 |
---|---|---|
committer | Andrew Yourtchenko <ayourtch@gmail.com> | 2021-04-16 09:26:33 +0000 |
commit | 558ceabc6c08f275ce6c6e7ff295e74272eb851a (patch) | |
tree | 778bb375cdd8f3b11537b6b638a4b00f53211ba5 /test/test_util.py | |
parent | f70cf2337683a97b06fe30ea56fab9ebab556ae7 (diff) |
tests: cpus awareness
Introduce MAX_CPUS parameters to control maximum number of CPUs used by
VPP(s) during testing, with default value 'auto' corresponding to all
CPUs available.
Calculate test CPU requirements by taking into account the number of
workers, so a test requires 1 (main thread) + # of worker CPUs.
When running tests, keep track of both running test jobs (controlled by
TEST_JOBS parameter) and free CPUs. This then causes two limits in the
system - to not exceed number of jobs in parallel but also to not exceed
number of CPUs available.
Skip tests which require more CPUs than are available in system (or more
than MAX_CPUS) and print a warning message.
Type: improvement
Change-Id: Ib8fda54e4c6a36179d64160bb87fbd3a0011762d
Signed-off-by: Klement Sekera <ksekera@cisco.com>
Diffstat (limited to 'test/test_util.py')
-rwxr-xr-x | test/test_util.py | 8 |
1 files changed, 6 insertions, 2 deletions
diff --git a/test/test_util.py b/test/test_util.py index 421afce4d5d..3a61d64b28f 100755 --- a/test/test_util.py +++ b/test/test_util.py @@ -2,11 +2,11 @@ """Test framework utility functions tests""" import unittest -from framework import VppTestRunner +from framework import VppTestRunner, CPUInterface from vpp_papi import mac_pton, mac_ntop -class TestUtil (unittest.TestCase): +class TestUtil (CPUInterface, unittest.TestCase): """ Test framework utility tests """ @classmethod @@ -23,6 +23,10 @@ class TestUtil (unittest.TestCase): pass return False + @classmethod + def get_cpus_required(cls): + return 0 + def test_mac_to_binary(self): """ MAC to binary and back """ mac = 'aa:bb:cc:dd:ee:ff' |