mirror of
https://github.com/Icinga/icingaweb2.git
synced 2025-07-23 22:04:25 +02:00
Rewrite php test-runner.
--include and --exclude will affect group annotations. (See: http://phpunit.de/manual/current/en/appendixes.annotations.html#appendixes.annotations.group) refs #4244
This commit is contained in:
parent
521baeba5e
commit
72c1255dc6
@ -1,24 +1,5 @@
|
||||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<phpunit backupGlobals="true"
|
||||
backupStaticAttributes="true"
|
||||
colors="false"
|
||||
convertErrorsToExceptions="true"
|
||||
convertNoticesToExceptions="true"
|
||||
convertWarningsToExceptions="true"
|
||||
forceCoversAnnotation="false"
|
||||
processIsolation="false"
|
||||
stopOnError="false"
|
||||
stopOnFailure="false"
|
||||
stopOnIncomplete="false"
|
||||
stopOnSkipped="false"
|
||||
strict="false"
|
||||
verbose="false">
|
||||
|
||||
<logging>
|
||||
<log type="coverage-clover" target="../../build/log/phpunit_coverage.xml"/>
|
||||
<log type="junit" target="../../build/log/phpunit_results.xml" logIncompleteSkipped="true"/>
|
||||
</logging>
|
||||
|
||||
<phpunit>
|
||||
<testsuites>
|
||||
<!--
|
||||
Unit testing
|
||||
@ -36,4 +17,4 @@
|
||||
<directory>regression/</directory>
|
||||
</testsuite>
|
||||
</testsuites>
|
||||
</phpunit>
|
||||
</phpunit>
|
||||
|
111
test/php/runtests
Executable file
111
test/php/runtests
Executable file
@ -0,0 +1,111 @@
|
||||
#!/usr/bin/env python
|
||||
|
||||
import os
|
||||
import sys
|
||||
import subprocess
|
||||
from optparse import OptionParser, BadOptionError, AmbiguousOptionError
|
||||
|
||||
|
||||
APPLICATION = 'phpunit'
|
||||
DEFAULT_ARGS = ['--strict', '--static-backup']
|
||||
|
||||
REPORT_DIRECTORY = '../../build/log'
|
||||
|
||||
|
||||
class PassThroughOptionParser(OptionParser):
|
||||
"""
|
||||
An unknown option pass-through implementation of OptionParser.
|
||||
|
||||
When unknown arguments are encountered, bundle with largs and try again,
|
||||
until rargs is depleted.
|
||||
|
||||
sys.exit(status) will still be called if a known argument is passed
|
||||
incorrectly (e.g. missing arguments or bad argument types, etc.)
|
||||
|
||||
Borrowed from: http://stackoverflow.com/a/9307174
|
||||
"""
|
||||
def _process_args(self, largs, rargs, values):
|
||||
while rargs:
|
||||
try:
|
||||
OptionParser._process_args(self, largs, rargs, values)
|
||||
except (BadOptionError, AmbiguousOptionError), error:
|
||||
largs.append(error.opt_str)
|
||||
|
||||
|
||||
def execute_command(command, return_output=False, shell=False):
|
||||
prog = subprocess.Popen(command, shell=shell,
|
||||
stdout=subprocess.PIPE
|
||||
if return_output
|
||||
else None)
|
||||
return prog.wait() if not return_output else \
|
||||
prog.communicate()[0]
|
||||
|
||||
|
||||
def get_report_directory():
|
||||
path = os.path.abspath(REPORT_DIRECTORY)
|
||||
|
||||
try:
|
||||
os.makedirs(REPORT_DIRECTORY)
|
||||
except OSError:
|
||||
pass
|
||||
|
||||
return path
|
||||
|
||||
|
||||
def get_script_directory():
|
||||
return os.path.dirname(os.path.abspath(sys.argv[0]))
|
||||
|
||||
|
||||
def parse_commandline():
|
||||
parser = PassThroughOptionParser(usage='%prog [options] [additional arguments'
|
||||
' for {0}]'.format(APPLICATION))
|
||||
parser.add_option('-b', '--build', action='store_true',
|
||||
help='Enable reporting.')
|
||||
parser.add_option('-v', '--verbose', action='store_true',
|
||||
help='Be more verbose.')
|
||||
parser.add_option('-i', '--include', metavar='PATTERN', action='append',
|
||||
help='Include only specific files/test cases.'
|
||||
' (Can be supplied multiple times.)')
|
||||
parser.add_option('-e', '--exclude', metavar='PATTERN', action='append',
|
||||
help='Exclude specific files/test cases. '
|
||||
'(Can be supplied multiple times.)')
|
||||
return parser.parse_args()
|
||||
|
||||
|
||||
def main():
|
||||
options, arguments = parse_commandline()
|
||||
|
||||
# Environment preparation and verification
|
||||
os.chdir(get_script_directory())
|
||||
application_path = execute_command('which {0}'.format(APPLICATION),
|
||||
True, True).strip()
|
||||
if not application_path:
|
||||
print 'ERROR: {0} not found!'.format(APPLICATION)
|
||||
return 2
|
||||
|
||||
# Commandline preparation
|
||||
command_options = []
|
||||
if options.verbose:
|
||||
command_options.append('--verbose')
|
||||
if options.build:
|
||||
report_directory = get_report_directory()
|
||||
command_options.append('--log-junit')
|
||||
command_options.append(os.path.join(report_directory,
|
||||
'phpunit_results.xml'))
|
||||
command_options.append('--coverage-clover')
|
||||
command_options.append(os.path.join(report_directory,
|
||||
'phpunit_coverage.xml'))
|
||||
if options.include:
|
||||
command_options.extend(['--group', ','.join(options.include)])
|
||||
if options.exclude:
|
||||
command_options.extend(['--exclude-group',
|
||||
','.join(options.exclude)])
|
||||
|
||||
# Application invocation..
|
||||
execute_command([application_path] + DEFAULT_ARGS +
|
||||
command_options + arguments)
|
||||
return 0
|
||||
|
||||
|
||||
if __name__ == '__main__':
|
||||
sys.exit(main())
|
@ -1,26 +0,0 @@
|
||||
#!/bin/sh
|
||||
|
||||
set -o nounset
|
||||
|
||||
SCRIPTNAME=$(readlink -f $0)
|
||||
DIR=$(dirname $SCRIPTNAME)
|
||||
PHPUNIT=$(which phpunit)
|
||||
|
||||
if [[ ! -x $PHPUNIT ]]; then
|
||||
echo "PHPUnit not found!"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
# Make sure that the destination directory for logs and reports exists
|
||||
mkdir -p $DIR/../../build/log
|
||||
|
||||
cd $DIR
|
||||
|
||||
if [[ ! -x ./bin/extcmd_test ]]; then
|
||||
make
|
||||
fi;
|
||||
|
||||
|
||||
$PHPUNIT "$@"
|
||||
|
||||
exit 0
|
Loading…
x
Reference in New Issue
Block a user