summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authortermie <code@term.ie>2010-12-28 01:40:24 -0800
committertermie <code@term.ie>2010-12-28 01:40:24 -0800
commit7e469690f04b06f2371650fdf419ba028388c5e9 (patch)
tree49b7188c442efcf003f70e869ab3332a8490a8d4
parenta40f3e0b14bc761b5f45ac6f5d927fbfdb85160b (diff)
Output of run_tests.sh to be closer to trial
-rw-r--r--run_tests.py68
-rwxr-xr-xrun_tests.sh10
2 files changed, 74 insertions, 4 deletions
diff --git a/run_tests.py b/run_tests.py
new file mode 100644
index 000000000..56a8bffe7
--- /dev/null
+++ b/run_tests.py
@@ -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(core.run(config=c, testRunner=runner))
diff --git a/run_tests.sh b/run_tests.sh
index 67214996d..2e536a636 100755
--- a/run_tests.sh
+++ b/run_tests.sh
@@ -30,6 +30,7 @@ always_venv=0
never_venv=0
force=0
+
for arg in "$@"; do
process_option $arg
done
@@ -37,7 +38,7 @@ done
if [ $never_venv -eq 1 ]; then
# Just run the test suites in current environment
rm -f nova.sqlite
- nosetests -v
+ python run_tests.py $@ 2> run_tests.err.log
exit
fi
@@ -49,7 +50,7 @@ fi
if [ -e ${venv} ]; then
${with_venv} rm -f nova.sqlite
- ${with_venv} nosetests -v $@
+ ${with_venv} python run_tests.py $@ 2> run_tests.err.log
else
if [ $always_venv -eq 1 ]; then
# Automatically install the virtualenv
@@ -62,10 +63,11 @@ else
python tools/install_venv.py
else
rm -f nova.sqlite
- nosetests -v
+ #nosetests -v
+ python run_tests.py 2> run_tests.err.log
exit
fi
fi
${with_venv} rm -f nova.sqlite
- ${with_venv} nosetests -v $@
+ ${with_venv} python run_tests.py $@ 2> run_tests.err.log
fi