2013-06-06 15:41:47 +02:00
|
|
|
#!/usr/bin/env python
|
|
|
|
|
|
|
|
import os
|
|
|
|
import sys
|
|
|
|
import subprocess
|
2013-06-14 13:01:19 +02:00
|
|
|
from pipes import quote
|
2013-06-11 16:05:29 +02:00
|
|
|
from fnmatch import fnmatch
|
2013-06-06 15:41:47 +02:00
|
|
|
from optparse import OptionParser, BadOptionError, AmbiguousOptionError
|
|
|
|
|
|
|
|
|
|
|
|
APPLICATION = 'phpunit'
|
2013-08-06 10:50:52 +02:00
|
|
|
DEFAULT_ARGS = []
|
2013-06-06 15:41:47 +02:00
|
|
|
|
2013-06-14 13:01:19 +02:00
|
|
|
VAGRANT_SCRIPT = '/vagrant/test/php/runtests'
|
2013-06-06 15:41:47 +02:00
|
|
|
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.')
|
2013-06-14 13:01:19 +02:00
|
|
|
parser.add_option('-i', '--include', metavar='PATTERN',
|
2013-06-11 16:05:29 +02:00
|
|
|
help='Include only specific files/test cases.')
|
2013-06-14 13:01:19 +02:00
|
|
|
parser.add_option('-V', '--vagrant', action='store_true',
|
|
|
|
help='Run in vagrant VM')
|
2013-06-06 15:41:47 +02:00
|
|
|
return parser.parse_args()
|
|
|
|
|
|
|
|
|
|
|
|
def main():
|
|
|
|
options, arguments = parse_commandline()
|
|
|
|
|
2013-06-14 13:01:19 +02:00
|
|
|
if options.vagrant and os.environ['USER'] != 'vagrant':
|
|
|
|
# Check if vagrant is installed
|
|
|
|
vagrant_path = execute_command('which vagrant', True, True).strip()
|
|
|
|
if not vagrant_path:
|
|
|
|
print 'ERROR: vagrant not found!'
|
|
|
|
return 2
|
|
|
|
|
|
|
|
# Call the script in the Vagrant VM with the same parameters
|
|
|
|
commandline = ' '.join(quote(p) for p in sys.argv[1:])
|
|
|
|
return execute_command('vagrant ssh -c "{0} {1}"'
|
|
|
|
''.format(VAGRANT_SCRIPT, commandline),
|
|
|
|
shell=True)
|
|
|
|
else:
|
|
|
|
# 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
|
|
|
|
if not os.path.isfile('./bin/extcmd_test'):
|
|
|
|
execute_command('make', shell=True)
|
|
|
|
|
|
|
|
# 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'))
|
2013-07-09 10:43:19 +02:00
|
|
|
command_options.append('--coverage-html')
|
2013-06-14 13:01:19 +02:00
|
|
|
command_options.append(os.path.join(report_directory,
|
2013-07-09 10:43:19 +02:00
|
|
|
'php_html_coverage'))
|
2013-06-14 13:01:19 +02:00
|
|
|
if options.include:
|
|
|
|
command_options.append('--filter')
|
|
|
|
command_options.append(options.include)
|
|
|
|
|
|
|
|
# Application invocation..
|
|
|
|
execute_command([application_path] + DEFAULT_ARGS +
|
|
|
|
command_options + arguments)
|
|
|
|
return 0
|
2013-06-06 15:41:47 +02:00
|
|
|
|
|
|
|
if __name__ == '__main__':
|
|
|
|
sys.exit(main())
|