Cleans up the output of run_tests.sh to look closer to Trial.

Example output:

VolumeTestCase
    test_concurrent_volumes_get_different_targets               ok
    test_create_delete_volume                                   ok
    test_multi_node                                             ok
    test_run_attach_detach_volume                               ok
    test_too_big_volume                                         ok
    test_too_many_volumes                                       ok
XenAPIVMTestCase
    test_list_instances_0                                       ok
    test_spawn                                                  ok
XenAPIVolumeTestCase
    test_attach_volume                                          ok
    test_attach_volume_raise_exception                          ok
    test_create_iscsi_storage                                   ok
    test_parse_volume_info_raise_exception                      ok

----------------------------------------------------------------------
Ran 232 tests in 82.677s

Launchpad is removing a bunch of spaces from the output, but the 'ok' parts are all lined up in the 65th column
This commit is contained in:
termie
2010-12-30 22:04:29 +00:00
committed by Tarmac

68
run_tests.py Normal file
View File

@@ -0,0 +1,68 @@
#!/usr/bin/env python
# vim: tabstop=4 shiftwidth=4 softtabstop=4
# Copyright 2010 United States Government as represented by the
# Administrator of the National Aeronautics and Space Administration.
# All Rights Reserved.
#
# 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.
import os
import unittest
import sys
from nose import config
from nose import result
from nose import core
class NovaTestResult(result.TextTestResult):
def __init__(self, *args, **kw):
result.TextTestResult.__init__(self, *args, **kw)
self._last_case = None
def getDescription(self, test):
return str(test)
def startTest(self, test):
unittest.TestResult.startTest(self, test)
current_case = test.test.__class__.__name__
if self.showAll:
if current_case != self._last_case:
self.stream.writeln(current_case)
self._last_case = current_case
self.stream.write(
' %s' % str(test.test._testMethodName).ljust(60))
self.stream.flush()
class NovaTestRunner(core.TextTestRunner):
def _makeResult(self):
return NovaTestResult(self.stream,
self.descriptions,
self.verbosity,
self.config)
if __name__ == '__main__':
c = config.Config(stream=sys.stdout,
env=os.environ,
verbosity=3)
runner = NovaTestRunner(stream=c.stream,
verbosity=c.verbosity,
config=c)
sys.exit(not core.run(config=c, testRunner=runner))