From 9bfe70bd7998a66118f3f374b7a9ca2e47b323a3 Mon Sep 17 00:00:00 2001 From: Rafael Monnerat <rafael@nexedi.com> Date: Wed, 17 Oct 2012 23:26:08 -0300 Subject: [PATCH] Create promise.cfg when during unit tests Create promise configuration on-the-fly with the configurations reusing existing API to get cloudooo, memcached and kumofs informations from environment. This approach allow us use erp5_promise alarms at any unit test to configure cloudooo, memcached and kumofs, instead implement ad-hoc configurations on tests afterSetup methods. --- product/ERP5Type/tests/ERP5TypeTestCase.py | 32 ++++++++++++++++++++++ 1 file changed, 32 insertions(+) diff --git a/product/ERP5Type/tests/ERP5TypeTestCase.py b/product/ERP5Type/tests/ERP5TypeTestCase.py index 352206493e..ab378ee66a 100644 --- a/product/ERP5Type/tests/ERP5TypeTestCase.py +++ b/product/ERP5Type/tests/ERP5TypeTestCase.py @@ -19,6 +19,7 @@ import sys import time import traceback import urllib +import ConfigParser from cStringIO import StringIO from cPickle import dumps from glob import glob @@ -263,6 +264,27 @@ def _getPersistentMemcachedServerDict(): port = os.environ.get('persistent_memcached_server_port', '12121') return dict(hostname=hostname, port=port) +def _createTestPromiseConfigurationFile(promise_path): + kumofs_url = "memcached://%(hostname)s:%(port)s/" % \ + _getVolatileMemcachedServerDict() + memcached_url = "memcached://%(hostname)s:%(port)s/" % \ + _getPersistentMemcachedServerDict() + cloudooo_url = "cloudooo://%(hostname)s:%(port)s/" % \ + _getConversionServerDict() + + promise_config = ConfigParser.RawConfigParser() + promise_config.add_section('external_service') + promise_config.set('external_service', 'cloudooo_url', cloudooo_url) + promise_config.set('external_service', 'memcached_url',memcached_url) + promise_config.set('external_service', 'kumofs_url', kumofs_url) + + if os.environ.get('TEST_CA_PATH') is not None: + promise_config.add_section('portal_certificate_authority') + promise_config.set('portal_certificate_authority', 'certificate_authority_path', + os.environ['TEST_CA_PATH']) + + promise_config.write(open(promise_path, 'w')) + def profile_if_environ(environment_var_name): if int(os.environ.get(environment_var_name, 0)): def decorator(self, method): @@ -928,6 +950,15 @@ class ERP5TypeCommandLineTestCase(ERP5TypeTestCaseMixin): """ return () + def loadPromise(self): + """ Create promise configuration file and load it into configuration + """ + promise_path = os.path.join(instancehome, "promise.cfg") + ZopeTestCase._print('Adding Promise at %s...\n' % promise_path) + _createTestPromiseConfigurationFile(promise_path) + config.product_config["/%s" % self.getPortalName()] = \ + {"promise_path": promise_path} + def _updateConnectionStrings(self): """Update connection strings with values passed by the testRunner """ @@ -1088,6 +1119,7 @@ class ERP5TypeCommandLineTestCase(ERP5TypeTestCaseMixin): self._setUpDummyMailHost() self.serverhost, self.serverport = self.startZServer(verbose=True) self._registerNode(distributing=1, processing=1) + self.loadPromise() self._updateConnectionStrings() self._recreateCatalog() -- 2.30.9