123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167 |
- # Copyright (c) 2013 Hewlett-Packard Development Company, L.P.
- #
- # Licensed under the Apache License, Version 2.0 (the "License");
- # you may not use this file except in compliance with the License.
- # You may obtain a copy of the License at
- #
- # http://www.apache.org/licenses/LICENSE-2.0
- #
- # Unless required by applicable law or agreed to in writing, software
- # distributed under the License is distributed on an "AS IS" BASIS,
- # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
- # implied.
- # See the License for the specific language governing permissions and
- # limitations under the License.
- #
- # Copyright (c) 2013 Testrepository Contributors
- #
- # Licensed under either the Apache License, Version 2.0 or the BSD 3-clause
- # license at the users choice. A copy of both licenses are available in the
- # project source as Apache-2.0 and BSD. You may not use this file except in
- # compliance with one of these two licences.
- #
- # Unless required by applicable law or agreed to in writing, software
- # distributed under these licenses is distributed on an "AS IS" BASIS, WITHOUT
- # WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
- # license you chose for the specific language governing permissions and
- # limitations under that license.
- """setuptools/distutils command to run testr via setup.py
- PBR will hook in the Testr class to provide "setup.py test" when
- .testr.conf is present in the repository (see pbr/hooks/commands.py).
- If we are activated but testrepository is not installed, we provide a
- sensible error.
- You can pass --coverage which will also export PYTHON='coverage run
- --source <your package>' and automatically combine the coverage from
- each testr backend test runner after the run completes.
- """
- from distutils import cmd
- import distutils.errors
- import logging
- import os
- import sys
- import warnings
- logger = logging.getLogger(__name__)
- class TestrReal(cmd.Command):
- description = "DEPRECATED: Run unit tests using testr"
- user_options = [
- ('coverage', None, "Replace PYTHON with coverage and merge coverage "
- "from each testr worker."),
- ('testr-args=', 't', "Run 'testr' with these args"),
- ('omit=', 'o', "Files to omit from coverage calculations"),
- ('coverage-package-name=', None, "Use this name to select packages "
- "for coverage (one or more, "
- "comma-separated)"),
- ('slowest', None, "Show slowest test times after tests complete."),
- ('no-parallel', None, "Run testr serially"),
- ('log-level=', 'l', "Log level (default: info)"),
- ]
- boolean_options = ['coverage', 'slowest', 'no_parallel']
- def _run_testr(self, *args):
- logger.debug("_run_testr called with args = %r", args)
- return commands.run_argv([sys.argv[0]] + list(args),
- sys.stdin, sys.stdout, sys.stderr)
- def initialize_options(self):
- self.testr_args = None
- self.coverage = None
- self.omit = ""
- self.slowest = None
- self.coverage_package_name = None
- self.no_parallel = None
- self.log_level = 'info'
- def finalize_options(self):
- self.log_level = getattr(
- logging,
- self.log_level.upper(),
- logging.INFO)
- logging.basicConfig(level=self.log_level)
- logger.debug("finalize_options called")
- if self.testr_args is None:
- self.testr_args = []
- else:
- self.testr_args = self.testr_args.split()
- if self.omit:
- self.omit = "--omit=%s" % self.omit
- logger.debug("finalize_options: self.__dict__ = %r", self.__dict__)
- def run(self):
- """Set up testr repo, then run testr."""
- logger.debug("run called")
- warnings.warn('testr integration in pbr is deprecated. Please use '
- 'the \'testr\' setup command or call testr directly',
- DeprecationWarning)
- if not os.path.isdir(".testrepository"):
- self._run_testr("init")
- if self.coverage:
- self._coverage_before()
- if not self.no_parallel:
- testr_ret = self._run_testr("run", "--parallel", *self.testr_args)
- else:
- testr_ret = self._run_testr("run", *self.testr_args)
- if testr_ret:
- raise distutils.errors.DistutilsError(
- "testr failed (%d)" % testr_ret)
- if self.slowest:
- print("Slowest Tests")
- self._run_testr("slowest")
- if self.coverage:
- self._coverage_after()
- def _coverage_before(self):
- logger.debug("_coverage_before called")
- package = self.distribution.get_name()
- if package.startswith('python-'):
- package = package[7:]
- # Use this as coverage package name
- if self.coverage_package_name:
- package = self.coverage_package_name
- options = "--source %s --parallel-mode" % package
- os.environ['PYTHON'] = ("coverage run %s" % options)
- logger.debug("os.environ['PYTHON'] = %r", os.environ['PYTHON'])
- def _coverage_after(self):
- logger.debug("_coverage_after called")
- os.system("coverage combine")
- os.system("coverage html -d ./cover %s" % self.omit)
- os.system("coverage xml -o ./cover/coverage.xml %s" % self.omit)
- class TestrFake(cmd.Command):
- description = "Run unit tests using testr"
- user_options = []
- def initialize_options(self):
- pass
- def finalize_options(self):
- pass
- def run(self):
- print("Install testrepository to run 'testr' command properly.")
- try:
- from testrepository import commands
- have_testr = True
- Testr = TestrReal
- except ImportError:
- have_testr = False
- Testr = TestrFake
|