Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
N
neo
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Stefane Fermigier
neo
Commits
0ae3482b
Commit
0ae3482b
authored
Dec 27, 2016
by
Julien Muchembled
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
qa: extend runner arguments to filter tests
parent
f2796d9c
Changes
2
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
53 additions
and
20 deletions
+53
-20
neo/scripts/runner.py
neo/scripts/runner.py
+45
-13
neo/tests/benchmark.py
neo/tests/benchmark.py
+8
-7
No files found.
neo/scripts/runner.py
View file @
0ae3482b
...
@@ -23,6 +23,7 @@ import os
...
@@ -23,6 +23,7 @@ import os
import
re
import
re
from
collections
import
Counter
,
defaultdict
from
collections
import
Counter
,
defaultdict
from
cStringIO
import
StringIO
from
cStringIO
import
StringIO
from
fnmatch
import
fnmatchcase
from
unittest.runner
import
_WritelnDecorator
from
unittest.runner
import
_WritelnDecorator
if
filter
(
re
.
compile
(
r'--coverage$|-\
w*c
').match, sys.argv[1:]):
if
filter
(
re
.
compile
(
r'--coverage$|-\
w*c
').match, sys.argv[1:]):
...
@@ -114,17 +115,32 @@ class NeoTestRunner(unittest.TextTestResult):
...
@@ -114,17 +115,32 @@ class NeoTestRunner(unittest.TextTestResult):
def wasSuccessful(self):
def wasSuccessful(self):
return not (self.failures or self.errors or self.unexpectedSuccesses)
return not (self.failures or self.errors or self.unexpectedSuccesses)
def run(self, name, modules):
def run(self, name, modules, only):
print '
\
n
', name
suite = unittest.TestSuite()
suite = unittest.TestSuite()
loader = unittest.defaultTestLoader
loader = unittest.TestLoader()
if only:
exclude = only[0] == '
!
'
test_only = only[exclude + 1:]
only = only[exclude]
if test_only:
def getTestCaseNames(testCaseClass):
tests = loader.__class__.getTestCaseNames(
loader, testCaseClass)
x = testCaseClass.__name__ + '
.
'
return [t for t in tests
if exclude != any(fnmatchcase(x + t, o)
for o in test_only)]
loader.getTestCaseNames = getTestCaseNames
if not only:
only = '
*
'
else:
print '
\
n
', name
for test_module in modules:
for test_module in modules:
# load prefix if supplied
# load prefix if supplied
if isinstance(test_module, tuple):
if isinstance(test_module, tuple):
test_module, prefix = test_module
test_module, loader.testMethodPrefix = test_module
loader.testMethodPrefix = prefix
if only and exclude == fnmatchcase(test_module, only):
else:
continue
loader.testMethodPrefix = '
test
'
try:
try:
test_module = __import__(test_module, globals(), locals(), ['
*
'])
test_module = __import__(test_module, globals(), locals(), ['
*
'])
except ImportError, err:
except ImportError, err:
...
@@ -201,7 +217,8 @@ class NeoTestRunner(unittest.TextTestResult):
...
@@ -201,7 +217,8 @@ class NeoTestRunner(unittest.TextTestResult):
for test in self.unexpectedSuccesses:
for test in self.unexpectedSuccesses:
body.write("UNEXPECTED SUCCESS: %s
\
n
" % self.getDescription(test))
body.write("UNEXPECTED SUCCESS: %s
\
n
" % self.getDescription(test))
self.stream = _WritelnDecorator(body)
self.stream = _WritelnDecorator(body)
self.printErrors()
self.printErrorList('
ERROR
', self.errors)
self.printErrorList('
FAIL
', self.failures)
return subject, body.getvalue()
return subject, body.getvalue()
class TestRunner(BenchmarkRunner):
class TestRunner(BenchmarkRunner):
...
@@ -217,7 +234,12 @@ class TestRunner(BenchmarkRunner):
...
@@ -217,7 +234,12 @@ class TestRunner(BenchmarkRunner):
help='
ZODB
test
suite
running
on
a
NEO
')
help='
ZODB
test
suite
running
on
a
NEO
')
parser.add_option('
-
v
', '
--
verbose
', action='
store_true
',
parser.add_option('
-
v
', '
--
verbose
', action='
store_true
',
help='
Verbose
output
')
help='
Verbose
output
')
parser.usage += " [[!] module [test...]]"
parser.format_epilog = lambda _: """
parser.format_epilog = lambda _: """
Positional:
Filter by given module/test. These arguments are shell patterns.
This implies -ufz if none of this option is passed.
Environment Variables:
Environment Variables:
NEO_TESTS_ADAPTER Default is SQLite for threaded clusters,
NEO_TESTS_ADAPTER Default is SQLite for threaded clusters,
MySQL otherwise.
MySQL otherwise.
...
@@ -239,27 +261,31 @@ Environment Variables:
...
@@ -239,27 +261,31 @@ Environment Variables:
""" % neo_tests__dict__
""" % neo_tests__dict__
def load_options(self, options, args):
def load_options(self, options, args):
if not (options.unit or options.functional or options.zodb or args):
if not (options.unit or options.functional or options.zodb):
if not args:
sys.exit('
Nothing
to
run
,
please
give
one
of
-
f
,
-
u
,
-
z
')
sys.exit('
Nothing
to
run
,
please
give
one
of
-
f
,
-
u
,
-
z
')
options.unit = options.functional = options.zodb = True
return dict(
return dict(
unit = options.unit,
unit = options.unit,
functional = options.functional,
functional = options.functional,
zodb = options.zodb,
zodb = options.zodb,
verbosity = 2 if options.verbose else 1,
verbosity = 2 if options.verbose else 1,
coverage = options.coverage,
coverage = options.coverage,
only = args,
)
)
def start(self):
def start(self):
config = self._config
config = self._config
only = config.only
# run requested tests
# run requested tests
runner = NeoTestRunner(config.title or '
Neo
', config.verbosity)
runner = NeoTestRunner(config.title or '
Neo
', config.verbosity)
try:
try:
if config.unit:
if config.unit:
runner.run('
Unit
tests
', UNIT_TEST_MODULES)
runner.run('
Unit
tests
', UNIT_TEST_MODULES
, only
)
if config.functional:
if config.functional:
runner.run('
Functional
tests
', FUNC_TEST_MODULES)
runner.run('
Functional
tests
', FUNC_TEST_MODULES
, only
)
if config.zodb:
if config.zodb:
runner.run('
ZODB
tests
', ZODB_TEST_MODULES)
runner.run('
ZODB
tests
', ZODB_TEST_MODULES
, only
)
except KeyboardInterrupt:
except KeyboardInterrupt:
config['
mail_to
'] = None
config['
mail_to
'] = None
traceback.print_exc()
traceback.print_exc()
...
@@ -268,7 +294,13 @@ Environment Variables:
...
@@ -268,7 +294,13 @@ Environment Variables:
if coverage.neotestrunner:
if coverage.neotestrunner:
coverage.combine(coverage.neotestrunner)
coverage.combine(coverage.neotestrunner)
coverage.save()
coverage.save()
if runner.dots:
print
# build report
# build report
if only and not config.mail_to:
runner._buildSummary = lambda *args: (
runner.__class__._buildSummary(runner, *args)[0], '')
self.build_report = str
self._successful = runner.wasSuccessful()
self._successful = runner.wasSuccessful()
return runner.buildReport(self.add_status)
return runner.buildReport(self.add_status)
...
...
neo/tests/benchmark.py
View file @
0ae3482b
from
__future__
import
print_function
import
sys
import
sys
import
smtplib
import
smtplib
import
optparse
import
optparse
...
@@ -34,13 +34,13 @@ class BenchmarkRunner(object):
...
@@ -34,13 +34,13 @@ class BenchmarkRunner(object):
parser
.
add_option
(
''
,
'--repeat'
,
type
=
'int'
,
default
=
1
)
parser
.
add_option
(
''
,
'--repeat'
,
type
=
'int'
,
default
=
1
)
self
.
add_options
(
parser
)
self
.
add_options
(
parser
)
# check common arguments
# check common arguments
options
,
self
.
_
args
=
parser
.
parse_args
()
options
,
args
=
parser
.
parse_args
()
if
bool
(
options
.
mail_to
)
^
bool
(
options
.
mail_from
):
if
bool
(
options
.
mail_to
)
^
bool
(
options
.
mail_from
):
sys
.
exit
(
'Need a sender and recipients to mail report'
)
sys
.
exit
(
'Need a sender and recipients to mail report'
)
mail_server
=
options
.
mail_server
or
MAIL_SERVER
mail_server
=
options
.
mail_server
or
MAIL_SERVER
# check specifics arguments
# check specifics arguments
self
.
_config
=
AttributeDict
()
self
.
_config
=
AttributeDict
()
self
.
_config
.
update
(
self
.
load_options
(
options
,
self
.
_
args
))
self
.
_config
.
update
(
self
.
load_options
(
options
,
args
))
self
.
_config
.
update
(
self
.
_config
.
update
(
title
=
options
.
title
or
self
.
__class__
.
__name__
,
title
=
options
.
title
or
self
.
__class__
.
__name__
,
mail_from
=
options
.
mail_from
,
mail_from
=
options
.
mail_from
,
...
@@ -87,7 +87,7 @@ class BenchmarkRunner(object):
...
@@ -87,7 +87,7 @@ class BenchmarkRunner(object):
try
:
try
:
s
.
sendmail
(
self
.
_config
.
mail_from
,
recipient
,
mail
)
s
.
sendmail
(
self
.
_config
.
mail_from
,
recipient
,
mail
)
except
smtplib
.
SMTPRecipientsRefused
:
except
smtplib
.
SMTPRecipientsRefused
:
print
"Mail for %s fails"
%
recipient
print
(
"Mail for %s fails"
%
recipient
)
s
.
close
()
s
.
close
()
def
run
(
self
):
def
run
(
self
):
...
@@ -95,9 +95,10 @@ class BenchmarkRunner(object):
...
@@ -95,9 +95,10 @@ class BenchmarkRunner(object):
report
=
self
.
build_report
(
report
)
report
=
self
.
build_report
(
report
)
if
self
.
_config
.
mail_to
:
if
self
.
_config
.
mail_to
:
self
.
send_report
(
subject
,
report
)
self
.
send_report
(
subject
,
report
)
print
subject
print
(
subject
)
print
if
report
:
print
report
print
()
print
(
report
,
end
=
''
)
def
was_successful
(
self
):
def
was_successful
(
self
):
return
self
.
_successful
return
self
.
_successful
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment