[tor-commits] [bridgedb/develop] Add dynamic unittests for all translations in bridgedb/i18n/.
isis at torproject.org
isis at torproject.org
Sun Jul 26 12:22:00 UTC 2015
commit 93fbdec690c3603f3a963668bf88fb29434ead57
Author: Isis Lovecruft <isis at torproject.org>
Date: Sun Jul 26 12:15:07 2015 +0000
Add dynamic unittests for all translations in bridgedb/i18n/.
---
test/test_https.py | 77 ++++++++++++++++++++++++++++++++++++++++++++++++++++
1 file changed, 77 insertions(+)
diff --git a/test/test_https.py b/test/test_https.py
index 090bab5..bc1890b 100644
--- a/test/test_https.py
+++ b/test/test_https.py
@@ -26,6 +26,7 @@ repository.
from __future__ import print_function
+import gettext
import ipaddr
import mechanize
import os
@@ -33,9 +34,11 @@ import os
from BeautifulSoup import BeautifulSoup
from twisted.trial import unittest
+from twisted.trial.reporter import TestResult
from twisted.trial.unittest import FailTest
from twisted.trial.unittest import SkipTest
+from .test_Tests import DynamicTestCaseMeta
from .util import processExists
from .util import getBridgeDBPID
@@ -358,3 +361,77 @@ class HTTPTests(unittest.TestCase):
self.assertTrue(hasNodeID,
"obfs4 bridge line is missing 'node-id' PT arg.")
+
+
+class _HTTPTranslationsTests(unittest.TestCase):
+ """Build a TestCase with dynamic methods which tests all HTTP rendering of
+ all translations in the bridgedb/i18n/ directory.
+ """
+ i18n = os.path.join(TOPDIR, 'bridgedb', 'i18n')
+
+ def setUp(self):
+ if not os.environ.get("CI"):
+ raise SkipTest(("The mechanize tests cannot handle self-signed "
+ "TLS certificates, and thus require opening "
+ "another port for running a plaintext HTTP-only "
+ "BridgeDB webserver. Because of this, these tests "
+ "are only run on CI servers."))
+
+ if not PID or not processExists(PID):
+ raise FailTest("Could not start BridgeDB process on CI server!")
+
+ self.br = None
+
+ @classmethod
+ def makeTestMethod(cls, locale):
+ """Dynamically generate a test_ method for **locale**."""
+
+ def test(self):
+ pageArgs = '/?lang=%s' % locale
+ language = gettext.translation("bridgedb",
+ localedir=self.i18n,
+ languages=[locale,],
+ fallback=True)
+ expected = language.gettext("What are bridges?")
+
+ if not locale.startswith('en'):
+ self.assertNotEqual(expected, "What are bridges?")
+
+ self.openBrowser()
+ self.br.open(HTTP_ROOT + pageArgs)
+ self.assertSubstring(expected, self.br.response().read())
+
+ test.__name__ = 'test_%s' % locale
+ setattr(cls, test.__name__, test)
+
+ return test
+
+ def tearDown(self):
+ self.br = None
+
+ def openBrowser(self):
+ self.br = mechanize.Browser()
+ self.br.set_handle_robots(False)
+
+ def test_self(self):
+ self.assertTrue(self)
+
+
+def createHTTPTranslationsTestSuite():
+ suite = unittest.TestSuite()
+ translations = os.listdir(_HTTPTranslationsTests.i18n)
+ translations.remove('templates')
+
+ for locale in translations:
+ klass = _HTTPTranslationsTests
+ method = klass.makeTestMethod(locale)
+ case = klass()
+ suite.addTest(case)
+
+ return [suite,]
+
+
+class HTTPTranslationsTests(unittest.TestCase):
+ __metaclass__ = DynamicTestCaseMeta
+ testResult = TestResult()
+ testSuites = createHTTPTranslationsTestSuite()
More information about the tor-commits
mailing list