[tor-commits] [ooni-probe/master] Further refactoring of nettest and runner
isis at torproject.org
isis at torproject.org
Thu Nov 1 12:14:01 UTC 2012
commit d95034f8eb912771bcf2b0613d49ab307880246d
Author: Arturo Filastò <arturo at filasto.net>
Date: Wed Oct 24 15:49:06 2012 +0000
Further refactoring of nettest and runner
* Add some notes on running tests in threads
* Define and document _tests attribute of out nettest TestSuite
* Remove unused code
---
ooni/nettest.py | 69 +++++++++++++++++++-----------------------------------
ooni/runner.py | 1 -
2 files changed, 24 insertions(+), 46 deletions(-)
diff --git a/ooni/nettest.py b/ooni/nettest.py
index b17117d..1d46218 100644
--- a/ooni/nettest.py
+++ b/ooni/nettest.py
@@ -1,10 +1,17 @@
-# -*- coding: utf-8 -*-
+# -*- encoding: utf-8 -*-
+#
+# :authors: Arturo "hellais" Filastò <art at fuffa.org>
+# :licence: see LICENSE
-import itertools
+import sys
import os
+import itertools
+import traceback
from twisted.trial import unittest, itrial, util
from twisted.internet import defer, utils
+from twisted.python import usage
+
from ooni.utils import log
pyunit = __import__('unittest')
@@ -14,6 +21,10 @@ class InputTestSuite(pyunit.TestSuite):
This in an extension of a unittest test suite. It adds support for inputs
and the tracking of current index via idx.
"""
+
+ # This is used to keep track of the tests that are associated with our
+ # special test suite
+ _tests = None
def run(self, result, idx=0):
log.debug("Running test suite")
self._idx = idx
@@ -31,25 +42,16 @@ class InputTestSuite(pyunit.TestSuite):
test.input = self.input
test._idx = self._idx
except Exception, e:
- log.debug("Error in some stuff")
+ log.debug("Error in setting test attributes")
+ log.debug("This is probably because the test case you are "\
+ "running is not a nettest")
log.debug(e)
- import sys
- print sys.exc_info()
- try:
- log.debug("Running test")
- test(result)
- log.debug("Ran.")
- except Exception, e:
- log.debug("Attribute error thing")
- log.debug("Had some problems with _idx")
- log.debug(e)
- import traceback, sys
- print sys.exc_info()
- traceback.print_exc()
- print e
-
- test(result)
+ log.debug("Running test")
+ # XXX we may want in a future to put all of these tests inside of a
+ # thread pool and run them all in parallel
+ test(result)
+ log.debug("Ran.")
self._idx += 1
return result
@@ -95,9 +97,9 @@ class TestCase(unittest.TestCase):
* version: is the version string of the test.
"""
- name = "I Did Not Change The Name"
- author = "John Doe <foo at example.com>"
- version = "0.0.0"
+ name = "I Did Not Change The Name"
+ author = "Jane Doe <foo at example.com>"
+ version = "0"
inputFile = None
inputs = [None]
@@ -109,29 +111,6 @@ class TestCase(unittest.TestCase):
optFlags = None
subCommands = None
- def setUpClass(self, *args, **kwargs):
- """
- Create a TestCase instance. This function is equivalent to '__init__'.
- To add futher setup steps before a set of tests in a TestCase instance
- run, create a function called 'setUp'.
-
- Class attributes, such as `report`, `optParameters`, `name`, and
- `author` should be overriden statically as class attributes in any
- subclass of :class:`ooni.nettest.TestCase`, so that the calling
- functions in ooni.runner can handle them correctly.
- """
- methodName = 'runTest'
- if kwargs:
- if 'methodName' in kwargs:
- methodName = kwargs['methodName']
-
- super(TestCase, self).__init__(methodName=methodName)
-
- #for key, value in kwargs.items():
- # setattr(self.__class__, key, value)
- #
- #self.inputs = self.getInputs()
-
def deferSetUp(self, ignored, result):
"""
If we have the reporterFactory set we need to write the header. If
diff --git a/ooni/runner.py b/ooni/runner.py
index dd5f8a9..ff5dd33 100644
--- a/ooni/runner.py
+++ b/ooni/runner.py
@@ -168,7 +168,6 @@ def loadTestsAndOptions(classes, config):
method_prefix = 'test'
options = []
test_cases = []
- names = []
_old_class_type = LegacyOONITest
More information about the tor-commits
mailing list