Commit fb75e7d3 authored by Rafael Monnerat's avatar Rafael Monnerat

slapos_cloud/SlapOSTestCaseMixin: Add methods to replace the default templates

     Create methods to replace the templates on preferences by their clones with small modifications.

    The goal is allow us to ensure that the values on the templates aren't harcoded on other locations, making it impossible to reconfigure the site.
parent 14085ec1
...@@ -85,11 +85,59 @@ class SlapOSTestCaseMixin(testSlapOSMixin): ...@@ -85,11 +85,59 @@ class SlapOSTestCaseMixin(testSlapOSMixin):
self.portal.portal_activities.unsubscribe() self.portal.portal_activities.unsubscribe()
self.new_id = self.generateNewId() self.new_id = self.generateNewId()
# Define default Organisation
self.slapos_organisation = self.portal.organisation_module.slapos
instance_template = self.portal.software_instance_module.template_software_instance instance_template = self.portal.software_instance_module.template_software_instance
if len(instance_template.objectValues()): if len(instance_template.objectValues()):
instance_template.manage_delObjects( instance_template.manage_delObjects(
ids=[i.getId() for i in instance_template.objectValues()]) ids=[i.getId() for i in instance_template.objectValues()])
def makeCustomOrganisation(self, new_id=None, index=True):
# Create a custom organisation same as slapos, for ensure we can have
# multiple organisations working on the site
if new_id is None:
new_id = self.generateNewId()
custom_organisation = self.portal.organisation_module.slapos.\
Base_createCloneDocument(batch_mode=1)
custom_organisation.edit(
title="organisation_live_test_%s" % new_id,
reference="organisation_live_test_%s" % new_id,
default_email_text="organisation_live_test_%s@example.org" % new_id,
)
custom_organisation.validate()
self.assertEqual(custom_organisation.getGroup(),
"company")
self.assertEqual("currency_module/EUR",
custom_organisation.getPriceCurrency())
self.assertNotEqual(getattr(custom_organisation, "bank_account", None), None)
if index:
custom_organisation.updateLocalRolesOnSecurityGroups()
custom_organisation.bank_account.updateLocalRolesOnSecurityGroups()
transaction.commit()
custom_organisation.immediateReindexObject()
return custom_organisation
def _addERP5Login(self, document, **kw):
if document.getPortalType() == "Person":
kw["password"] = "%s-aA$1" % self.generateNewId()
login = document.newContent(
portal_type="ERP5 Login",
reference=document.getReference(),
**kw)
login.validate()
return login
def makePerson(self, new_id=None, index=True, user=True): def makePerson(self, new_id=None, index=True, user=True):
if new_id is None: if new_id is None:
...@@ -119,16 +167,6 @@ class SlapOSTestCaseMixin(testSlapOSMixin): ...@@ -119,16 +167,6 @@ class SlapOSTestCaseMixin(testSlapOSMixin):
return person_user return person_user
def _addERP5Login(self, document, **kw):
if document.getPortalType() == "Person":
kw["password"] = "%s-aA$1" % self.generateNewId()
login = document.newContent(
portal_type="ERP5 Login",
reference=document.getReference(),
**kw)
login.validate()
return login
def _makeTree(self, requested_template_id='template_software_instance'): def _makeTree(self, requested_template_id='template_software_instance'):
new_id = self.generateNewId() new_id = self.generateNewId()
...@@ -616,7 +654,106 @@ portal_workflow.doActionFor(context, action='edit_action', comment='Visited by % ...@@ -616,7 +654,106 @@ portal_workflow.doActionFor(context, action='edit_action', comment='Visited by %
self._dropScript(script_name) self._dropScript(script_name)
self.assertScriptNotVisited(document, script_name) self.assertScriptNotVisited(document, script_name)
def restoreAccountingTemplatesOnPreferences(self):
self.login()
system_preference = self.portal.portal_preferences.slapos_default_system_preference
system_preference.edit(
preferred_aggregated_consumption_sale_trade_condition=\
'sale_trade_condition_module/slapos_aggregated_consumption_trade_condition',
preferred_aggregated_sale_trade_condition=\
'sale_trade_condition_module/slapos_aggregated_trade_condition',
preferred_aggregated_subscription_sale_trade_condition=\
'sale_trade_condition_module/slapos_aggregated_subscription_trade_condition',
preferred_default_pre_payment_template=\
'accounting_module/slapos_pre_payment_template',
preferred_instance_delivery_template=\
'sale_packing_list_module/slapos_accounting_instance_delivery_template',
preferred_open_sale_order_line_template=\
'open_sale_order_module/slapos_accounting_open_sale_order_line_template/slapos_accounting_open_sale_order_line_template',
preferred_open_sale_order_template=\
'open_sale_order_module/slapos_accounting_open_sale_order_template',
preferred_zh_pre_payment_template=\
'accounting_module/slapos_wechat_pre_payment_template',
preferred_zh_pre_payment_subscription_invoice_template=\
'accounting_module/template_wechat_pre_payment_subscription_sale_invoice_transaction',
preferred_default_pre_payment_subscription_invoice_template=\
'accounting_module/template_pre_payment_subscription_sale_invoice_transaction'
)
self.tic()
def redefineAccountingTemplatesonPreferences(self):
# Define a new set of templates and change organisation on them, in this way tests should
# behave the same.
self.login()
organisation = self.makeCustomOrganisation()
accounting_module = self.portal.accounting_module
sale_packing_list_module = self.portal.sale_packing_list_module
preferred_zh_pre_payment_template = \
accounting_module.slapos_wechat_pre_payment_template.Base_createCloneDocument(batch_mode=1)
preferred_zh_pre_payment_template.edit(
source_section_value = organisation,
source_payment_value=organisation.bank_account
)
preferred_default_pre_payment_template = \
accounting_module.slapos_pre_payment_template.Base_createCloneDocument(batch_mode=1)
preferred_default_pre_payment_template.edit(
source_section_value = organisation,
source_payment_value=organisation.bank_account
)
preferred_zh_pre_payment_subscription_invoice_template = \
accounting_module.template_wechat_pre_payment_subscription_sale_invoice_transaction.Base_createCloneDocument(batch_mode=1)
preferred_zh_pre_payment_subscription_invoice_template.edit(
source_section_value = organisation,
source_value=organisation
)
preferred_default_pre_payment_subscription_invoice_template = \
accounting_module.template_pre_payment_subscription_sale_invoice_transaction.Base_createCloneDocument(batch_mode=1)
preferred_default_pre_payment_subscription_invoice_template.edit(
source_section_value = organisation,
source_value=organisation
)
preferred_instance_delivery_template = \
sale_packing_list_module.slapos_accounting_instance_delivery_template.Base_createCloneDocument(batch_mode=1)
preferred_instance_delivery_template.edit(
source_section_value = organisation,
source_value=organisation
)
open_sale_order_module = self.portal.open_sale_order_module
preferred_open_sale_order_template=\
open_sale_order_module.slapos_accounting_open_sale_order_template.Base_createCloneDocument(batch_mode=1)
preferred_open_sale_order_template.edit(
source_section_value = organisation,
source_value=organisation
)
system_preference = self.portal.portal_preferences.slapos_default_system_preference
system_preference.edit(
preferred_default_pre_payment_template=preferred_default_pre_payment_template.getRelativeUrl(),
preferred_zh_pre_payment_template=preferred_zh_pre_payment_template.getRelativeUrl(),
preferred_zh_pre_payment_subscription_invoice_template=\
preferred_zh_pre_payment_subscription_invoice_template.getRelativeUrl(),
preferred_default_pre_payment_subscription_invoice_template=\
preferred_default_pre_payment_subscription_invoice_template.getRelativeUrl(),
preferred_instance_delivery_template=\
preferred_instance_delivery_template.getRelativeUrl(),
preferred_open_sale_order_template=\
preferred_open_sale_order_template.getRelativeUrl()
)
self.tic()
return organisation
class SlapOSTestCaseMixinWithAbort(SlapOSTestCaseMixin): class SlapOSTestCaseMixinWithAbort(SlapOSTestCaseMixin):
abort_transaction = 1 abort_transaction = 1
...@@ -100,11 +100,13 @@ ...@@ -100,11 +100,13 @@
</record> </record>
<record id="4" aka="AAAAAAAAAAQ="> <record id="4" aka="AAAAAAAAAAQ=">
<pickle> <pickle>
<global name="WorkflowHistoryList" module="Products.ERP5Type.patches.WorkflowTool"/> <global name="WorkflowHistoryList" module="Products.ERP5Type.Workflow"/>
</pickle> </pickle>
<pickle> <pickle>
<tuple> <dictionary>
<none/> <item>
<key> <string>_log</string> </key>
<value>
<list> <list>
<dictionary> <dictionary>
<item> <item>
...@@ -117,8 +119,9 @@ ...@@ -117,8 +119,9 @@
</item> </item>
</dictionary> </dictionary>
</list> </list>
<none/> </value>
</tuple> </item>
</dictionary>
</pickle> </pickle>
</record> </record>
</ZopeData> </ZopeData>
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment