Commit c71a47c8 authored by Jérome Perrin's avatar Jérome Perrin

Merge remote-tracking branch 'upstream/master' into zope4py2

parents 5252fde2 e9531ee8
...@@ -224,7 +224,7 @@ class BusinessTemplateMixin(ERP5TypeTestCase, LogInterceptor): ...@@ -224,7 +224,7 @@ class BusinessTemplateMixin(ERP5TypeTestCase, LogInterceptor):
file_path = os.path.join(cfg.instancehome, 'tests', test_title+'.py') file_path = os.path.join(cfg.instancehome, 'tests', test_title+'.py')
if os.path.exists(file_path): if os.path.exists(file_path):
os.remove(file_path) os.remove(file_path)
f = file(file_path, 'w') f = open(file_path, 'w')
f.write(test_data) f.write(test_data)
f.close() f.close()
self.assertTrue(os.path.exists(file_path)) self.assertTrue(os.path.exists(file_path))
...@@ -2371,7 +2371,7 @@ class BusinessTemplateMixin(ERP5TypeTestCase, LogInterceptor): ...@@ -2371,7 +2371,7 @@ class BusinessTemplateMixin(ERP5TypeTestCase, LogInterceptor):
file_path = os.path.join(cfg.instancehome, 'PropertySheet', ps_title+'.py') file_path = os.path.join(cfg.instancehome, 'PropertySheet', ps_title+'.py')
if os.path.exists(file_path): if os.path.exists(file_path):
os.remove(file_path) os.remove(file_path)
f = file(file_path, 'w') f = open(file_path, 'w')
f.write(ps_data) f.write(ps_data)
f.close() f.close()
self.assertTrue(os.path.exists(file_path)) self.assertTrue(os.path.exists(file_path))
...@@ -2463,7 +2463,7 @@ class BusinessTemplateMixin(ERP5TypeTestCase, LogInterceptor): ...@@ -2463,7 +2463,7 @@ class BusinessTemplateMixin(ERP5TypeTestCase, LogInterceptor):
file_path = os.path.join(cfg.instancehome, 'PropertySheet', ps_title+'.py') file_path = os.path.join(cfg.instancehome, 'PropertySheet', ps_title+'.py')
if os.path.exists(file_path): if os.path.exists(file_path):
os.remove(file_path) os.remove(file_path)
f = file(file_path, 'w') f = open(file_path, 'w')
f.write(ps_data) f.write(ps_data)
f.close() f.close()
self.assertTrue(os.path.exists(file_path)) self.assertTrue(os.path.exists(file_path))
...@@ -8036,7 +8036,7 @@ class _LocalTemplateItemMixin: ...@@ -8036,7 +8036,7 @@ class _LocalTemplateItemMixin:
file_path = os.path.join(self.document_base_path, self.document_title+'.py') file_path = os.path.join(self.document_base_path, self.document_title+'.py')
if os.path.exists(file_path): if os.path.exists(file_path):
os.remove(file_path) os.remove(file_path)
f = file(file_path, 'w') f = open(file_path, 'w')
f.write(self.document_data) f.write(self.document_data)
f.close() f.close()
self.assertTrue(os.path.exists(file_path)) self.assertTrue(os.path.exists(file_path))
...@@ -8048,7 +8048,7 @@ class _LocalTemplateItemMixin: ...@@ -8048,7 +8048,7 @@ class _LocalTemplateItemMixin:
file_path = os.path.join(self.document_base_path, self.document_title+'.py') file_path = os.path.join(self.document_base_path, self.document_title+'.py')
if os.path.exists(file_path): if os.path.exists(file_path):
os.remove(file_path) os.remove(file_path)
f = file(file_path, 'w') f = open(file_path, 'w')
f.write(self.document_data_updated) f.write(self.document_data_updated)
f.close() f.close()
self.assertTrue(os.path.exists(file_path)) self.assertTrue(os.path.exists(file_path))
...@@ -8070,12 +8070,12 @@ class _LocalTemplateItemMixin: ...@@ -8070,12 +8070,12 @@ class _LocalTemplateItemMixin:
def stepCheckDocumentExists(self, sequence=None, **kw): def stepCheckDocumentExists(self, sequence=None, **kw):
self.assertFalse(not os.path.exists(sequence['document_path'])) self.assertFalse(not os.path.exists(sequence['document_path']))
self.assertEqual(file(sequence['document_path']).read(), self.assertEqual(open(sequence['document_path']).read(),
sequence['document_data']) sequence['document_data'])
def stepCheckUpdatedDocumentExists(self, sequence=None, **kw): def stepCheckUpdatedDocumentExists(self, sequence=None, **kw):
self.assertFalse(not os.path.exists(sequence['document_path'])) self.assertFalse(not os.path.exists(sequence['document_path']))
self.assertEqual(file(sequence['document_path']).read(), self.assertEqual(open(sequence['document_path']).read(),
sequence['document_data_updated']) sequence['document_data_updated'])
def stepCheckDocumentRemoved(self, sequence=None, **kw): def stepCheckDocumentRemoved(self, sequence=None, **kw):
......
...@@ -693,7 +693,7 @@ class TestCRMMailIngestion(BaseTestCRM): ...@@ -693,7 +693,7 @@ class TestCRMMailIngestion(BaseTestCRM):
def _readTestData(self, filename): def _readTestData(self, filename):
"""read test data from data directory.""" """read test data from data directory."""
return file(makeFilePath(filename)).read() return open(makeFilePath(filename)).read()
def _ingestMail(self, filename=None, data=None): def _ingestMail(self, filename=None, data=None):
"""ingest an email from the mail in data dir named `filename`""" """ingest an email from the mail in data dir named `filename`"""
......
...@@ -32,7 +32,7 @@ class FileTransport: ...@@ -32,7 +32,7 @@ class FileTransport:
def send(self, to_url, data, sync_id, content_type): def send(self, to_url, data, sync_id, content_type):
filename = to_url[len('file:/'):] filename = to_url[len('file:/'):]
try: try:
stream = file(filename, 'w') stream = open(filename, 'w')
stream.write(data) stream.write(data)
stream.close() stream.close()
except IOError: except IOError:
......
...@@ -262,7 +262,7 @@ class SynchronizationTool(BaseTool): ...@@ -262,7 +262,7 @@ class SynchronizationTool(BaseTool):
filename = from_url[len('file:'):] filename = from_url[len('file:'):]
xml = None xml = None
try: try:
stream = file(filename, 'r') stream = open(filename, 'r')
except IOError: except IOError:
# XXX-Aurel : Why raising here make unit tests to fail ? # XXX-Aurel : Why raising here make unit tests to fail ?
# raise ValueError("Impossible to read file %s, error is %s" # raise ValueError("Impossible to read file %s, error is %s"
......
...@@ -536,7 +536,7 @@ class BaseTemplateItem(Implicit, Persistent): ...@@ -536,7 +536,7 @@ class BaseTemplateItem(Implicit, Persistent):
# if you choose remove, the object and all its subobjects will be removed # if you choose remove, the object and all its subobjects will be removed
# even if you choose backup or keep for subobjects # even if you choose backup or keep for subobjects
# it is same behaviour for backup_and_remove, all we be save # it is same behaviour for backup_and_remove, all we be save
for path in sorted(self._objects.keys()): for path in sorted(self._objects):
if path in remove_dict: if path in remove_dict:
action = remove_dict[path] action = remove_dict[path]
if action == 'save_and_remove': if action == 'save_and_remove':
...@@ -1193,7 +1193,7 @@ class ObjectTemplateItem(BaseTemplateItem): ...@@ -1193,7 +1193,7 @@ class ObjectTemplateItem(BaseTemplateItem):
def _getObjectKeyList(self): def _getObjectKeyList(self):
# sort to add objects before their subobjects # sort to add objects before their subobjects
return sorted(self._objects.keys()) return sorted(self._objects)
def unindexBrokenObject(self, item_path): def unindexBrokenObject(self, item_path):
""" """
...@@ -1446,7 +1446,7 @@ class ObjectTemplateItem(BaseTemplateItem): ...@@ -1446,7 +1446,7 @@ class ObjectTemplateItem(BaseTemplateItem):
#remove previous owners #remove previous owners
local_role_dict = obj.__ac_local_roles__ local_role_dict = obj.__ac_local_roles__
removable_role_key_list = [] removable_role_key_list = []
for key, value in local_role_dict.items(): for key, value in six.iteritems(local_role_dict):
if 'Owner' in value: if 'Owner' in value:
value.remove('Owner') value.remove('Owner')
if len(value) == 0: if len(value) == 0:
...@@ -1985,7 +1985,7 @@ class CategoryTemplateItem(ObjectTemplateItem): ...@@ -1985,7 +1985,7 @@ class CategoryTemplateItem(ObjectTemplateItem):
# as PathTemplateItem.install # as PathTemplateItem.install
kw['object_to_update'] = { kw['object_to_update'] = {
path: action path: action
for (path, action) in ensure_list(kw['object_to_update'].items()) for (path, action) in six.iteritems(kw['object_to_update'])
if path.split('/')[:-1] == ['portal_categories'] or path in self._objects if path.split('/')[:-1] == ['portal_categories'] or path in self._objects
} }
return super(CategoryTemplateItem, self).install(context, trashbin, **kw) return super(CategoryTemplateItem, self).install(context, trashbin, **kw)
...@@ -2075,11 +2075,11 @@ class RegisteredSkinSelectionTemplateItem(BaseTemplateItem): ...@@ -2075,11 +2075,11 @@ class RegisteredSkinSelectionTemplateItem(BaseTemplateItem):
# Function to generate XML Code Manually # Function to generate XML Code Manually
def generateXml(self, path=None): def generateXml(self, path=None):
xml_data = '<registered_skin_selection>' xml_data = '<registered_skin_selection>'
for key in sorted(self._objects.keys()): for key, value in sorted(six.iteritems(self._objects)):
xml_data += '\n <skin_folder_selection>' xml_data += '\n <skin_folder_selection>'
xml_data += '\n <skin_folder>%s</skin_folder>' % key xml_data += '\n <skin_folder>%s</skin_folder>' % key
xml_data += '\n <skin_selection>%s</skin_selection>' \ xml_data += '\n <skin_selection>%s</skin_selection>' \
% ','.join(sorted(self._objects[key])) % ','.join(sorted(value))
xml_data += '\n </skin_folder_selection>' xml_data += '\n </skin_folder_selection>'
xml_data += '\n</registered_skin_selection>' xml_data += '\n</registered_skin_selection>'
return xml_data return xml_data
...@@ -2551,11 +2551,11 @@ class PortalTypeWorkflowChainTemplateItem(BaseTemplateItem): ...@@ -2551,11 +2551,11 @@ class PortalTypeWorkflowChainTemplateItem(BaseTemplateItem):
# Function to generate XML Code Manually # Function to generate XML Code Manually
def generateXml(self, path=None): def generateXml(self, path=None):
xml_data = '<workflow_chain>' xml_data = '<workflow_chain>'
for key in sorted(self._objects.keys()): for key, value in sorted(six.iteritems(self._objects)):
xml_data += '\n <chain>' xml_data += '\n <chain>'
xml_data += '\n <type>%s</type>' %(key,) xml_data += '\n <type>%s</type>' %(key,)
xml_data += '\n <workflow>%s</workflow>' %( xml_data += '\n <workflow>%s</workflow>' %(
self._chain_string_separator.join(sorted(self._objects[key]))) self._chain_string_separator.join(sorted(value)))
xml_data += '\n </chain>' xml_data += '\n </chain>'
xml_data += '\n</workflow_chain>' xml_data += '\n</workflow_chain>'
return xml_data return xml_data
...@@ -2765,11 +2765,10 @@ class PortalTypeAllowedContentTypeTemplateItem(BaseTemplateItem): ...@@ -2765,11 +2765,10 @@ class PortalTypeAllowedContentTypeTemplateItem(BaseTemplateItem):
# Function to generate XML Code Manually # Function to generate XML Code Manually
def generateXml(self, path=None): def generateXml(self, path=None):
xml_data = '<%s>' %(self.xml_tag,) xml_data = '<%s>' %(self.xml_tag,)
for key in sorted(self._objects.keys()): for key, value in sorted(six.iteritems(self._objects)):
id_value = key.replace('%s/' % self.class_property, '') id_value = key.replace('%s/' % self.class_property, '')
allowed_item_list = sorted(self._objects[key])
xml_data += '\n <portal_type id="%s">' % (id_value) xml_data += '\n <portal_type id="%s">' % (id_value)
for allowed_item in allowed_item_list: for allowed_item in sorted(value):
xml_data += '\n <item>%s</item>' %(allowed_item,) xml_data += '\n <item>%s</item>' %(allowed_item,)
xml_data += '\n </portal_type>' xml_data += '\n </portal_type>'
xml_data += '\n</%s>' %(self.xml_tag,) xml_data += '\n</%s>' %(self.xml_tag,)
...@@ -2996,7 +2995,7 @@ class CatalogMethodTemplateItem(ObjectTemplateItem): ...@@ -2996,7 +2995,7 @@ class CatalogMethodTemplateItem(ObjectTemplateItem):
method_id = obj.id method_id = obj.id
xml_data = '<catalog_method>' xml_data = '<catalog_method>'
if method_id in self._method_properties: if method_id in self._method_properties:
for method_property, value in self._method_properties[method_id].items(): for method_property, value in six.iteritems(self._method_properties[method_id]):
xml_data += '\n <item key="%s" type="int">' %(method_property,) xml_data += '\n <item key="%s" type="int">' %(method_property,)
xml_data += '\n <value>%s</value>' %(value,) xml_data += '\n <value>%s</value>' %(value,)
xml_data += '\n </item>' xml_data += '\n </item>'
...@@ -3047,9 +3046,7 @@ class CatalogMethodTemplateItem(ObjectTemplateItem): ...@@ -3047,9 +3046,7 @@ class CatalogMethodTemplateItem(ObjectTemplateItem):
script_class = getattr(erp5.portal_type, 'Python Script') script_class = getattr(erp5.portal_type, 'Python Script')
portal = self.getPortalObject() portal = self.getPortalObject()
# Will be modifying dict, so better to use .items() for path, obj in six.iteritems(self._objects):
# XXX: In python3 it should be .copy.items().
for path, obj in ensure_list(self._objects.items()):
method = self.unrestrictedResolveValue(portal, path) method = self.unrestrictedResolveValue(portal, path)
method_id = path.split('/')[-1] method_id = path.split('/')[-1]
if method.meta_type == 'Z SQL Method': if method.meta_type == 'Z SQL Method':
...@@ -3060,7 +3057,7 @@ class CatalogMethodTemplateItem(ObjectTemplateItem): ...@@ -3060,7 +3057,7 @@ class CatalogMethodTemplateItem(ObjectTemplateItem):
self._objects[path] = new_obj self._objects[path] = new_obj
if force: # get all objects if force: # get all objects
values = ensure_list(self._objects.values()) values = six.itervalues(self._objects)
else: # get only selected object else: # get only selected object
for key, value in six.iteritems(self._objects): for key, value in six.iteritems(self._objects):
if key in update_dict or force: if key in update_dict or force:
...@@ -3153,7 +3150,7 @@ class CatalogMethodTemplateItem(ObjectTemplateItem): ...@@ -3153,7 +3150,7 @@ class CatalogMethodTemplateItem(ObjectTemplateItem):
object_path = kw.get('object_path', None) object_path = kw.get('object_path', None)
# get required values # get required values
if object_path is None: if object_path is None:
values = ensure_list(self._objects.values()) values = six.itervalues(self._objects)
else: else:
try: try:
value = self._objects[object_path] value = self._objects[object_path]
...@@ -3653,7 +3650,7 @@ class SitePropertyTemplateItem(BaseTemplateItem): ...@@ -3653,7 +3650,7 @@ class SitePropertyTemplateItem(BaseTemplateItem):
if len(self._objects) == 0: if len(self._objects) == 0:
return return
xml_data = '<site_property>' xml_data = '<site_property>'
for path in sorted(self._objects.keys()): for path in sorted(self._objects):
xml_data += self.generateXml(path) xml_data += self.generateXml(path)
xml_data += '\n</site_property>' xml_data += '\n</site_property>'
bta.addObject(xml_data, name='properties', path=self.__class__.__name__) bta.addObject(xml_data, name='properties', path=self.__class__.__name__)
...@@ -3677,12 +3674,11 @@ class ModuleTemplateItem(BaseTemplateItem): ...@@ -3677,12 +3674,11 @@ class ModuleTemplateItem(BaseTemplateItem):
def generateXml(self, path=None): def generateXml(self, path=None):
mapping = self._objects[path] mapping = self._objects[path]
xml_data = ['<module>'] xml_data = ['<module>']
for key in sorted(mapping): for key, value in sorted(six.iteritems(mapping)):
if key == 'permission_list': if key == 'permission_list':
# separe permission dict into xml # separe permission dict into xml
xml_data.append(' <%s>' % (key, )) xml_data.append(' <%s>' % (key, ))
permission_list = mapping[key] for perm in value:
for perm in permission_list:
# the type of the permission defined if we use acquired or not # the type of the permission defined if we use acquired or not
if isinstance(perm[1], list): if isinstance(perm[1], list):
ptype = "list" ptype = "list"
...@@ -3703,7 +3699,7 @@ class ModuleTemplateItem(BaseTemplateItem): ...@@ -3703,7 +3699,7 @@ class ModuleTemplateItem(BaseTemplateItem):
xml_data.append(' </permission>') xml_data.append(' </permission>')
xml_data.append(' </%s>' % (key, )) xml_data.append(' </%s>' % (key, ))
elif key == 'category_list': elif key == 'category_list':
category_list = mapping[key] category_list = value
if not category_list: if not category_list:
continue continue
xml_data.append(' <%s>' % (key, )) xml_data.append(' <%s>' % (key, ))
...@@ -3719,7 +3715,7 @@ class ModuleTemplateItem(BaseTemplateItem): ...@@ -3719,7 +3715,7 @@ class ModuleTemplateItem(BaseTemplateItem):
if len(self._objects) == 0: if len(self._objects) == 0:
return return
path = self.__class__.__name__ path = self.__class__.__name__
for key in sorted(self._objects.keys()): for key in sorted(self._objects):
# export modules one by one # export modules one by one
xml_data = self.generateXml(path=key) xml_data = self.generateXml(path=key)
bta.addObject(xml_data, name=key, path=path) bta.addObject(xml_data, name=key, path=path)
...@@ -4629,7 +4625,7 @@ class CatalogUniqueKeyTemplateItemBase(CatalogKeyTemplateItemBase): ...@@ -4629,7 +4625,7 @@ class CatalogUniqueKeyTemplateItemBase(CatalogKeyTemplateItemBase):
for key in key_list) for key in key_list)
def _getListFromKeyMap(self, key_map): def _getListFromKeyMap(self, key_map):
return [" | ".join(item) for item in sorted(key_map.items())] return [" | ".join(item) for item in sorted(six.iteritems(key_map))]
def _getUpdatedCatalogKeyList(self, catalog_key_list, new_key_list): def _getUpdatedCatalogKeyList(self, catalog_key_list, new_key_list):
# treat key lists as dictionaries, parse and update: # treat key lists as dictionaries, parse and update:
...@@ -4784,7 +4780,7 @@ class MessageTranslationTemplateItem(BaseTemplateItem): ...@@ -4784,7 +4780,7 @@ class MessageTranslationTemplateItem(BaseTemplateItem):
localizer = context.getPortalObject().Localizer localizer = context.getPortalObject().Localizer
update_dict = kw.get('object_to_update', {}) update_dict = kw.get('object_to_update', {})
force = kw.get('force') force = kw.get('force')
for key in sorted(self._objects.keys()): for key, value in sorted(six.iteritems(self._objects)):
if key in update_dict or force: if key in update_dict or force:
if not force: if not force:
action = update_dict[key] action = update_dict[key]
...@@ -4793,7 +4789,7 @@ class MessageTranslationTemplateItem(BaseTemplateItem): ...@@ -4793,7 +4789,7 @@ class MessageTranslationTemplateItem(BaseTemplateItem):
lang, catalog = self._splitKey(key) lang, catalog = self._splitKey(key)
if catalog is None: if catalog is None:
name = self._objects[key] name = value
for lang_dict in localizer.get_all_languages(): for lang_dict in localizer.get_all_languages():
if lang_dict['code'] == lang: if lang_dict['code'] == lang:
# When the Localizer has the language as a user-defined # When the Localizer has the language as a user-defined
...@@ -4810,7 +4806,7 @@ class MessageTranslationTemplateItem(BaseTemplateItem): ...@@ -4810,7 +4806,7 @@ class MessageTranslationTemplateItem(BaseTemplateItem):
if lang not in localizer.get_languages(): if lang not in localizer.get_languages():
localizer.manage_addLanguage(lang) localizer.manage_addLanguage(lang)
else: else:
po = self._objects[key] po = value
if lang not in localizer.get_languages(): if lang not in localizer.get_languages():
localizer.manage_addLanguage(lang) localizer.manage_addLanguage(lang)
self._importCatalogLanguage(localizer, catalog, lang, po) self._importCatalogLanguage(localizer, catalog, lang, po)
...@@ -4904,7 +4900,7 @@ class LocalRolesTemplateItem(BaseTemplateItem): ...@@ -4904,7 +4900,7 @@ class LocalRolesTemplateItem(BaseTemplateItem):
xml_data = '<local_roles_item>' xml_data = '<local_roles_item>'
# local roles # local roles
xml_data += '\n <local_roles>' xml_data += '\n <local_roles>'
for user_id, role_list in sorted(local_roles_dict.items()): for user_id, role_list in sorted(six.iteritems(local_roles_dict)):
if 'Owner' in role_list: if 'Owner' in role_list:
# We don't export Owner role as it set automatically when installing business template. # We don't export Owner role as it set automatically when installing business template.
role_list.remove('Owner') role_list.remove('Owner')
...@@ -4919,7 +4915,7 @@ class LocalRolesTemplateItem(BaseTemplateItem): ...@@ -4919,7 +4915,7 @@ class LocalRolesTemplateItem(BaseTemplateItem):
# local roles group id dict (not included by default to be stable with # local roles group id dict (not included by default to be stable with
# old bts) # old bts)
xml_data += '\n <local_role_group_ids>' xml_data += '\n <local_role_group_ids>'
for local_role_group_id, local_roles_group_id_list in sorted(local_roles_group_id_dict.items()): for local_role_group_id, local_roles_group_id_list in sorted(six.iteritems(local_roles_group_id_dict)):
xml_data += "\n <local_role_group_id id='%s'>" % escape(local_role_group_id) xml_data += "\n <local_role_group_id id='%s'>" % escape(local_role_group_id)
for principal, role in sorted(local_roles_group_id_list): for principal, role in sorted(local_roles_group_id_list):
xml_data += "\n <principal id='%s'>%s</principal>" % \ xml_data += "\n <principal id='%s'>%s</principal>" % \
...@@ -4984,7 +4980,7 @@ class LocalRolesTemplateItem(BaseTemplateItem): ...@@ -4984,7 +4980,7 @@ class LocalRolesTemplateItem(BaseTemplateItem):
# We ignore the owner defined in local_roles_dict and set it to the user installing that business template. # We ignore the owner defined in local_roles_dict and set it to the user installing that business template.
local_roles_dict = deepcopy(local_roles_dict) local_roles_dict = deepcopy(local_roles_dict)
for user_id, group_list in list(local_roles_dict.items()): for user_id, group_list in ensure_list(local_roles_dict.items()):
if group_list == ["Owner"]: if group_list == ["Owner"]:
del local_roles_dict[user_id] del local_roles_dict[user_id]
current_user = getSecurityManager().getUser() current_user = getSecurityManager().getUser()
......
...@@ -2,6 +2,7 @@ ...@@ -2,6 +2,7 @@
Generic method called when submitting a form in dialog mode. Generic method called when submitting a form in dialog mode.
Responsible for validating form data and redirecting to the form action. Responsible for validating form data and redirecting to the form action.
""" """
import six
# XXX We should not use meta_type properly, # XXX We should not use meta_type properly,
# XXX We need to discuss this problem.(yusei) # XXX We need to discuss this problem.(yusei)
...@@ -131,9 +132,8 @@ if len(listbox_id_list): ...@@ -131,9 +132,8 @@ if len(listbox_id_list):
for listbox_id in listbox_id_list: for listbox_id in listbox_id_list:
listbox_line_list = [] listbox_line_list = []
listbox = kw[listbox_id] listbox = kw[listbox_id]
listbox_keys = listbox.keys() for key, value in sorted(six.iteritems(listbox)):
for key in sorted(listbox_keys): listbox_line = value
listbox_line = listbox[key]
listbox_line['listbox_key'] = key listbox_line['listbox_key'] = key
listbox_line_list.append(listbox_line) listbox_line_list.append(listbox_line)
listbox_line_list = tuple(listbox_line_list) listbox_line_list = tuple(listbox_line_list)
......
...@@ -35,16 +35,12 @@ if p.portal_templates.compareVersions(bt1.getVersion(), bt2.getVersion()) < 0: ...@@ -35,16 +35,12 @@ if p.portal_templates.compareVersions(bt1.getVersion(), bt2.getVersion()) < 0:
else: else:
modified_object_list = getModifiedObjectList(bt1, bt2) modified_object_list = getModifiedObjectList(bt1, bt2)
keys = modified_object_list.keys()
i = 0
object_list = [] object_list = []
for object_id in sorted(keys): for i, (object_id, value) in enumerate(sorted(six.iteritems(modified_object_list))):
object_state, object_class = modified_object_list[object_id] object_state, object_class = value
line = newTempBase(context, 'tmp_install_%s' %(str(i))) line = newTempBase(context, 'tmp_install_%s' %(str(i)))
line.edit(object_id=object_id, object_state=object_state, object_class=object_class, bt1=bt1.getId(), bt2=bt2.getId()) line.edit(object_id=object_id, object_state=object_state, object_class=object_class, bt1=bt1.getId(), bt2=bt2.getId())
line.setUid('new_%s' % object_id) line.setUid('new_%s' % object_id)
object_list.append(line) object_list.append(line)
i += 1
return object_list return object_list
from Products.ERP5Type.Document import newTempBase from Products.ERP5Type.Document import newTempBase
from Products.ERP5Type.Cache import CachingMethod from Products.ERP5Type.Cache import CachingMethod
from Products.ERP5Type.Utils import ensure_list from Products.ERP5Type.Utils import ensure_list
import six
Base_translateString = context.Base_translateString Base_translateString = context.Base_translateString
def getModifiedObjectList(context): def getModifiedObjectList(context):
...@@ -21,7 +22,6 @@ getModifiedObjectList = CachingMethod(getModifiedObjectList, ...@@ -21,7 +22,6 @@ getModifiedObjectList = CachingMethod(getModifiedObjectList,
cache_id_generator=cache_id_generator) cache_id_generator=cache_id_generator)
modified_object_list = getModifiedObjectList(context) modified_object_list = getModifiedObjectList(context)
keys = ensure_list(modified_object_list.keys())
no_backup_list = ['Action', 'SiteProperty', 'Module', 'Document', no_backup_list = ['Action', 'SiteProperty', 'Module', 'Document',
'PropertySheet', 'Extension', 'Test', 'Product', 'Role', 'PropertySheet', 'Extension', 'Test', 'Product', 'Role',
...@@ -40,10 +40,9 @@ backup_title = Base_translateString('Backup And Upgrade') ...@@ -40,10 +40,9 @@ backup_title = Base_translateString('Backup And Upgrade')
remove_title = Base_translateString('Remove') remove_title = Base_translateString('Remove')
save_and_remove_title = Base_translateString('Backup And Remove') save_and_remove_title = Base_translateString('Backup And Remove')
i = 0
object_list = [] object_list = []
for object_id in sorted(keys): for i, (object_id, value) in enumerate(sorted(six.iteritems(modified_object_list))):
object_state, object_class = modified_object_list[object_id] object_state, object_class = value
line = newTempBase(context, 'tmp_install_%s' %(str(i))) line = newTempBase(context, 'tmp_install_%s' %(str(i)))
if object_state == 'New': if object_state == 'New':
choice_item_list=[[install_title, 'install']] choice_item_list=[[install_title, 'install']]
...@@ -66,7 +65,6 @@ for object_id in sorted(keys): ...@@ -66,7 +65,6 @@ for object_id in sorted(keys):
choice_item_list=choice_item_list) choice_item_list=choice_item_list)
line.setUid('new_%s' % str(object_id)) line.setUid('new_%s' % str(object_id))
object_list.append(line) object_list.append(line)
i += 1
object_list.sort(key=lambda x:(x.object_class, x.object_state)) object_list.sort(key=lambda x:(x.object_class, x.object_state))
return object_list return object_list
...@@ -19,7 +19,7 @@ if hasattr(request, listbox_id): ...@@ -19,7 +19,7 @@ if hasattr(request, listbox_id):
# initialize the listbox # initialize the listbox
listbox=request[listbox_id] listbox=request[listbox_id]
keys_list = sorted(listbox.keys(), key=int) keys_list = sorted(listbox, key=int)
if keys_list != []: if keys_list != []:
first_empty_line_id = int(keys_list[-1])+1 first_empty_line_id = int(keys_list[-1])+1
......
import six
REQUEST = container.REQUEST REQUEST = container.REQUEST
Base_translateString = context.Base_translateString Base_translateString = context.Base_translateString
...@@ -45,8 +46,7 @@ save_and_remove_title = Base_translateString('Backup And Remove') ...@@ -45,8 +46,7 @@ save_and_remove_title = Base_translateString('Backup And Remove')
for bt in bt_id_list: for bt in bt_id_list:
bt_title, modified_object_list = bt_object_dict[bt] bt_title, modified_object_list = bt_object_dict[bt]
keys = modified_object_list.keys() for i, (object_id, value) in enumerate(sorted(six.iteritems(modified_object_list))):
for i, object_id in enumerate(sorted(keys)):
object_state, object_class = modified_object_list[object_id] object_state, object_class = modified_object_list[object_id]
object_id = bt+'|'+object_id object_id = bt+'|'+object_id
line = newTempBase(context, 'tmp_install_%s' % i) line = newTempBase(context, 'tmp_install_%s' % i)
......
...@@ -116,7 +116,7 @@ class URLOpener(FancyURLopener): ...@@ -116,7 +116,7 @@ class URLOpener(FancyURLopener):
if auth: h.putheader('Authorization', 'Basic %s' % auth) if auth: h.putheader('Authorization', 'Basic %s' % auth)
if realhost: h.putheader('Host', realhost) if realhost: h.putheader('Host', realhost)
for args in self.addheaders: apply(h.putheader, args) for args in self.addheaders: h.putheader(*args)
h.endheaders() h.endheaders()
if data is not None: if data is not None:
h.send(data + '\r\n') h.send(data + '\r\n')
......
...@@ -63,7 +63,7 @@ class ExtractMessageCatalog(TestXHTML): ...@@ -63,7 +63,7 @@ class ExtractMessageCatalog(TestXHTML):
messages = dict(getattr(self.portal.Localizer, i)._messages) messages = dict(getattr(self.portal.Localizer, i)._messages)
result[i].update(messages) result[i].update(messages)
f = file('%s.pot' % i, 'w') f = open('%s.pot' % i, 'w')
for msgid in result[i].keys(): for msgid in result[i].keys():
f.write('msgid "%s"\nmsgstr ""\n\n' % msgid) f.write('msgid "%s"\nmsgstr ""\n\n' % msgid)
......
...@@ -186,4 +186,4 @@ class BusinessTemplateInfoDir(BusinessTemplateInfoBase): ...@@ -186,4 +186,4 @@ class BusinessTemplateInfoDir(BusinessTemplateInfoBase):
return fileinfo return fileinfo
def readFileInfo(self, fileinfo): def readFileInfo(self, fileinfo):
return file(fileinfo).read() return open(fileinfo).read()
...@@ -143,26 +143,24 @@ def Base_asXML(object, root=None): ...@@ -143,26 +143,24 @@ def Base_asXML(object, root=None):
# We have to describe the workflow history # We have to describe the workflow history
if getattr(self, 'workflow_history', None) is not None: if getattr(self, 'workflow_history', None) is not None:
workflow_list = self.workflow_history workflow_list = self.workflow_history
workflow_list_keys = workflow_list.keys()
for workflow_id in sorted(workflow_list_keys): # Make sure it is sorted for workflow_id, workflow_action_list in sorted(six.iteritems(workflow_list)): # Make sure it is sorted
for workflow_action in workflow_list[workflow_id]: for workflow_action in workflow_action_list:
workflow_node = SubElement(object, 'workflow_action', workflow_node = SubElement(object, 'workflow_action',
attrib=dict(workflow_id=workflow_id)) attrib=dict(workflow_id=workflow_id))
workflow_variable_list = workflow_action.keys() workflow_variable_list = workflow_action.keys()
for workflow_variable in sorted(workflow_variable_list): for workflow_variable, variable_node_text in sorted(six.iteritems(workflow_action)):
variable_type = "string" # Somewhat bad, should find a better way variable_type = "string" # Somewhat bad, should find a better way
if workflow_variable.find('time') >= 0: if workflow_variable.find('time') >= 0:
variable_type = "date" variable_type = "date"
if workflow_variable.find('language_revs') >= 0: # XXX specific to cps if workflow_variable.find('language_revs') >= 0: # XXX specific to cps
variable_type = "dict" variable_type = "dict"
if workflow_action[workflow_variable] is None: if variable_node_text is None:
variable_type = 'None' variable_type = 'None'
variable_node = SubElement(workflow_node, workflow_variable, variable_node = SubElement(workflow_node, workflow_variable,
attrib=dict(type=variable_type)) attrib=dict(type=variable_type))
if variable_type != 'None': if variable_type != 'None':
variable_node_text = str(workflow_action[workflow_variable]) variable_node.text = six.text_type(str(variable_node_text), 'utf-8')
variable_node.text = six.text_type(variable_node_text, 'utf-8')
if workflow_variable == 'time': if workflow_variable == 'time':
time = variable_node.text time = variable_node.text
......
...@@ -35,7 +35,7 @@ def DA_fromFile(self, filename): ...@@ -35,7 +35,7 @@ def DA_fromFile(self, filename):
""" """
Read the file and update self Read the file and update self
""" """
f = file(filename) f = open(filename)
s = f.read() s = f.read()
f.close() f.close()
self.fromText(s) self.fromText(s)
......
...@@ -113,7 +113,7 @@ def Application_resolveConflict(self, old_state, saved_state, new_state): ...@@ -113,7 +113,7 @@ def Application_resolveConflict(self, old_state, saved_state, new_state):
new_state['test_distributing_node'] = test_distributing_node_set.pop() new_state['test_distributing_node'] = test_distributing_node_set.pop()
old, saved, new = [set(state.pop('test_processing_nodes', {}).items()) old, saved, new = [set(state.pop('test_processing_nodes', {}).items())
for state in old_state, saved_state, new_state] for state in (old_state, saved_state, new_state)]
# The value of these attributes don't have proper __eq__ implementation. # The value of these attributes don't have proper __eq__ implementation.
for attr in '__before_traverse__', '__before_publishing_traverse__': for attr in '__before_traverse__', '__before_publishing_traverse__':
del old_state[attr], saved_state[attr] del old_state[attr], saved_state[attr]
......
...@@ -75,18 +75,23 @@ class Python3StyleTest(ERP5TypeTestCase): ...@@ -75,18 +75,23 @@ class Python3StyleTest(ERP5TypeTestCase):
if error: if error:
self.fail(error) self.fail(error)
def test_raiseFixApplied(self): def test_applyFixApplied(self):
self._testFixer('raise') self._testFixer('apply')
def test_importFixApplied(self):
self._testFixer('import')
def test_hasKeyFixApplied(self): def test_hasKeyFixApplied(self):
self._testFixer('has_key') self._testFixer('has_key')
def test_importFixApplied(self):
self._testFixer('import')
def test_numliteralsFixApplied(self): def test_numliteralsFixApplied(self):
self._testFixer('numliterals') self._testFixer('numliterals')
def test_numliteralsFixApplied(self):
self._testFixer('paren')
def test_raiseFixApplied(self):
self._testFixer('raise')
def test_suite(): def test_suite():
suite = unittest.TestSuite() suite = unittest.TestSuite()
......
...@@ -27,7 +27,7 @@ class TestField: ...@@ -27,7 +27,7 @@ class TestField:
class ValidatorTestCase(unittest.TestCase): class ValidatorTestCase(unittest.TestCase):
def assertValidatorRaises(self, exception, error_key, f, *args, **kw): def assertValidatorRaises(self, exception, error_key, f, *args, **kw):
try: try:
apply(f, args, kw) f(*args, **kw)
except exception as e: except exception as e:
if hasattr(e, 'error_key') and e.error_key != error_key: if hasattr(e, 'error_key') and e.error_key != error_key:
self.fail('Got wrong error. Expected %s received %s' % self.fail('Got wrong error. Expected %s received %s' %
......
...@@ -646,10 +646,8 @@ class MessageCatalog(LanguageManager, ObjectManager, SimpleItem): ...@@ -646,10 +646,8 @@ class MessageCatalog(LanguageManager, ObjectManager, SimpleItem):
return x return x
# Generate sorted msgids to simplify diffs # Generate sorted msgids to simplify diffs
dkeys = d.keys() for k, v in sorted(six.iteritems(d)):
for k in sorted(dkeys):
r.append('msgid "%s"' % backslashescape(k)) r.append('msgid "%s"' % backslashescape(k))
v = d[k]
r.append('msgstr "%s"' % backslashescape(v)) r.append('msgstr "%s"' % backslashescape(v))
r.append('') r.append('')
......
...@@ -118,8 +118,7 @@ class BaseMailTemplate: ...@@ -118,8 +118,7 @@ class BaseMailTemplate:
# we want to have it stored in ERP5, for mail threading # we want to have it stored in ERP5, for mail threading
headers['Message-ID'] = make_msgid() headers['Message-ID'] = make_msgid()
# turn headers into an ordered list for predictable header order # turn headers into an ordered list for predictable header order
keys = headers.keys() return msg, values, [(key, value) for key, value in sorted(six.iteritems(headers))]
return msg,values,[(key,headers[key]) for key in sorted(keys)]
security.declarePrivate('_send') security.declarePrivate('_send')
def _send(self,mfrom,mto,msg): def _send(self,mfrom,mto,msg):
......
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