Add support for workspaces to tempest run
This commit enables tempest run to natively run in a workspace. It adds 2 new CLI options to specify the workspace you want to run in. If set tempest run will automatically switch to using that workspace and run the tests in there. Change-Id: I703397cd11d95169c69b48107d0dd8ae762cfeab
This commit is contained in:
parent
a6b4da9f5f
commit
c89a951ba7
@ -54,6 +54,16 @@ tempest will run in parallel with a worker for each CPU present on the machine.
|
|||||||
If you want to adjust the number of workers use the **--concurrency** option
|
If you want to adjust the number of workers use the **--concurrency** option
|
||||||
and if you want to run tests serially use **--serial**
|
and if you want to run tests serially use **--serial**
|
||||||
|
|
||||||
|
Running with Workspaces
|
||||||
|
-----------------------
|
||||||
|
Tempest run enables you to run your tempest tests from any setup tempest
|
||||||
|
workspace it relies on you having setup a tempest workspace with either the
|
||||||
|
``tempest init`` or ``tempest workspace`` commands. Then using the
|
||||||
|
``--workspace`` CLI option you can specify which one of your workspaces you
|
||||||
|
want to run tempest from. Using this option you don't have to run Tempest
|
||||||
|
directly with you current working directory being the workspace, Tempest will
|
||||||
|
take care of managing everything to be executed from there.
|
||||||
|
|
||||||
Test Output
|
Test Output
|
||||||
===========
|
===========
|
||||||
By default tempest run's output to STDOUT will be generated using the
|
By default tempest run's output to STDOUT will be generated using the
|
||||||
@ -73,6 +83,7 @@ from os_testr import subunit_trace
|
|||||||
from oslo_log import log as logging
|
from oslo_log import log as logging
|
||||||
from testrepository.commands import run_argv
|
from testrepository.commands import run_argv
|
||||||
|
|
||||||
|
from tempest.cmd import workspace
|
||||||
from tempest import config
|
from tempest import config
|
||||||
|
|
||||||
|
|
||||||
@ -90,18 +101,31 @@ class TempestRun(command.Command):
|
|||||||
else:
|
else:
|
||||||
os.environ["TESTR_PDB"] = ""
|
os.environ["TESTR_PDB"] = ""
|
||||||
|
|
||||||
def take_action(self, parsed_args):
|
def _create_testrepository(self):
|
||||||
self._set_env()
|
|
||||||
returncode = 0
|
|
||||||
# Local execution mode
|
|
||||||
if os.path.isfile('.testr.conf'):
|
|
||||||
# If you're running in local execution mode and there is not a
|
|
||||||
# testrepository dir create one
|
|
||||||
if not os.path.isdir('.testrepository'):
|
if not os.path.isdir('.testrepository'):
|
||||||
returncode = run_argv(['testr', 'init'], sys.stdin, sys.stdout,
|
returncode = run_argv(['testr', 'init'], sys.stdin, sys.stdout,
|
||||||
sys.stderr)
|
sys.stderr)
|
||||||
if returncode:
|
if returncode:
|
||||||
sys.exit(returncode)
|
sys.exit(returncode)
|
||||||
|
|
||||||
|
def take_action(self, parsed_args):
|
||||||
|
self._set_env()
|
||||||
|
returncode = 0
|
||||||
|
# Workspace execution mode
|
||||||
|
if parsed_args.workspace:
|
||||||
|
workspace_mgr = workspace.WorkspaceManager(
|
||||||
|
parsed_args.workspace_path)
|
||||||
|
path = workspace_mgr.get_workspace(parsed_args.workspace)
|
||||||
|
os.chdir(path)
|
||||||
|
# NOTE(mtreinish): tempest init should create a .testrepository dir
|
||||||
|
# but since workspaces can be imported let's sanity check and
|
||||||
|
# ensure that one is created
|
||||||
|
self._create_testrepository()
|
||||||
|
# Local execution mode
|
||||||
|
elif os.path.isfile('.testr.conf'):
|
||||||
|
# If you're running in local execution mode and there is not a
|
||||||
|
# testrepository dir create one
|
||||||
|
self._create_testrepository()
|
||||||
else:
|
else:
|
||||||
print("No .testr.conf file was found for local execution")
|
print("No .testr.conf file was found for local execution")
|
||||||
sys.exit(2)
|
sys.exit(2)
|
||||||
@ -124,6 +148,15 @@ class TempestRun(command.Command):
|
|||||||
return parser
|
return parser
|
||||||
|
|
||||||
def _add_args(self, parser):
|
def _add_args(self, parser):
|
||||||
|
# workspace args
|
||||||
|
parser.add_argument('--workspace', default=None,
|
||||||
|
help='Name of tempest workspace to use for running'
|
||||||
|
' tests. You can see a list of workspaces '
|
||||||
|
'with tempest workspace list')
|
||||||
|
parser.add_argument('--workspace-path', default=None,
|
||||||
|
dest='workspace_path',
|
||||||
|
help="The path to the workspace file, the default "
|
||||||
|
"is ~/.tempest/workspace.yaml")
|
||||||
# test selection args
|
# test selection args
|
||||||
regex = parser.add_mutually_exclusive_group()
|
regex = parser.add_mutually_exclusive_group()
|
||||||
regex.add_argument('--smoke', action='store_true',
|
regex.add_argument('--smoke', action='store_true',
|
||||||
|
Loading…
Reference in New Issue
Block a user