From b3ee2ba4d5916f032e33ba34abff48050971b225 Mon Sep 17 00:00:00 2001
From: Kazuhiko Shiozaki <kazuhiko@nexedi.com>
Date: Mon, 15 Feb 2010 06:39:04 +0000
Subject: [PATCH] add tests that checks legacy behaviour (i.e. using 'order'
 category in top level simulation movements.)

git-svn-id: https://svn.erp5.org/repos/public/erp5/trunk@32533 20353a03-c40f-0410-a6d1-a30d3c3de9de
---
 .../ERP5/tests/testLegacyProductionOrder.py   | 1846 +++++++++++++++++
 .../tests/testLegacyProductionPackingList.py  |  781 +++++++
 2 files changed, 2627 insertions(+)
 create mode 100644 product/ERP5/tests/testLegacyProductionOrder.py
 create mode 100644 product/ERP5/tests/testLegacyProductionPackingList.py

diff --git a/product/ERP5/tests/testLegacyProductionOrder.py b/product/ERP5/tests/testLegacyProductionOrder.py
new file mode 100644
index 0000000000..8ffea6525f
--- /dev/null
+++ b/product/ERP5/tests/testLegacyProductionOrder.py
@@ -0,0 +1,1846 @@
+##############################################################################
+#
+# Copyright (c) 2005-2008 Nexedi SARL and Contributors. All Rights Reserved.
+#          Sebastien Robin <seb@nexedi.com>
+#          Romain Courteaud <romain@nexedi.com>
+#          Lukasz Nowak <lukasz.nowak@ventis.com.pl>
+#
+# WARNING: This program as such is intended to be used by professional
+# programmers who take the whole responsability of assessing all potential
+# consequences resulting from its eventual inadequacies and bugs
+# End users who are looking for a ready-to-use solution with commercial
+# garantees and support are strongly adviced to contract a Free Software
+# Service Company
+#
+# This program is Free Software; you can redistribute it and/or
+# modify it under the terms of the GNU General Public License
+# as published by the Free Software Foundation; either version 2
+# of the License, or (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program; if not, write to the Free Software
+# Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
+#
+##############################################################################
+
+import unittest
+
+import transaction
+
+from Products.ERP5Type.tests.ERP5TypeTestCase import ERP5TypeTestCase
+from zLOG import LOG
+from Products.ERP5Type.tests.Sequence import SequenceList
+from Products.CMFCore.utils import getToolByName
+from testLegacyOrder import TestOrderMixin
+
+class TestProductionOrderMixin(TestOrderMixin):
+
+  run_all_test = 1
+  resource_portal_type = 'Product'
+  order_portal_type = 'Production Order'
+  order_line_portal_type = 'Production Order Line'
+  order_cell_portal_type = 'Production Order Cell'
+  supply_chain_portal_type = 'Supply Chain'
+  supply_node_portal_type = 'Supply Node'
+  supply_link_portal_type = 'Supply Link'
+  component_portal_type = 'Component'
+  transformation_portal_type = 'Transformation'
+  transformed_resource_portal_type = \
+                        'Transformation Transformed Resource'
+  operation_line_portal_type = 'Transformation Operation'
+
+  operation_category_list = ['operation1', 'operation2']
+  colour_variation_portal_type = 'Product Individual Variation'
+  morphology_variation_portal_type = 'Product Individual Variation'
+
+  colour_list = ['green','blue']
+  mrp_size_list = ['Man','Woman']
+
+
+  def getBusinessTemplateList(self):
+    """
+    """
+    return ('erp5_base','erp5_pdm', 'erp5_trade', 'erp5_mrp',)
+
+  def setUpPreferences(self):
+    portal = self.getPortal()
+    preferences = getToolByName(portal,'portal_preferences')
+
+    system_preference = preferences.newContent(
+      portal_type = 'System Preference'
+    )
+
+    system_preference.edit(
+      preferred_product_individual_variation_base_category = ('variation',),
+      preferred_component_individual_variation_base_category = ('variation',),
+      preferred_product_variation_base_category = ('industrial_phase', 'colour', 'size'),
+      preferred_component_variation_base_category = ('colour', 'size'),
+      priority = 1,
+    )
+
+    system_preference.enable()
+    transaction.commit()
+    self.tic()
+
+  def afterSetUp(self):
+    TestOrderMixin.afterSetUp(self)
+    self.setUpPreferences()
+
+  def createCategories(self):
+    """ 
+      Light install create only base categories, so we create 
+      some categories for testing them
+    """
+    TestOrderMixin.createCategories(self)
+    operation_category_list = ['operation1', 'operation2']
+    if len(self.category_tool.operation.contentValues()) == 0:
+      for category_id in operation_category_list:
+        o = self.category_tool.operation.newContent(
+                                               portal_type='Category',
+                                               id=category_id)
+
+  def stepCreateColourSizeVariatedComponent1(self,sequence=None, sequence_list=None, \
+                                    **kw):
+    """
+      Create a resource with colour and size variation
+    """
+    portal = self.getPortal()
+    resource_module = portal.getDefaultModule(self.component_portal_type)
+    resource = resource_module.newContent(
+                                  portal_type=self.component_portal_type)
+    resource.edit(
+      title = "ColourSizeVariatedComponent1",
+      variation_base_category_list = ['colour','size'],
+    )
+    resource.setVariationCategoryList(['size/'+q for q in self.mrp_size_list] + ['colour/'+q for q in self.colour_list])
+    sequence.edit(component1=resource)
+
+  def stepCreateColourSizeVariatedResource(self, sequence=None, sequence_list=None, \
+                                 **kw):
+    """
+      Create a resource with colour and size variation
+    """
+    portal = self.getPortal()
+    resource_module = portal.getDefaultModule(self.resource_portal_type)
+    resource = resource_module.newContent(portal_type=self.resource_portal_type)
+    resource.edit(
+      title = "ColourSizeVariatedResource",
+      industrial_phase_list=["phase1", "phase2"],
+      variation_base_category_list = ['size','colour'],
+    )
+    resource.setVariationCategoryList(['size/'+q for q in self.mrp_size_list] + ['colour/'+q for q in self.colour_list])
+
+    sequence.edit( resource = resource )
+    resource_list = sequence.get('resource_list',default=[])
+    resource_list.append(resource)
+    sequence.edit( resource_list = resource_list )
+
+  def stepCreateVariatedResource(self, sequence=None, sequence_list=None, \
+                                 **kw):
+    """
+      Create a resource with variation
+    """
+    portal = self.getPortal()
+    resource_module = portal.getDefaultModule(self.resource_portal_type)
+    resource = resource_module.newContent(portal_type=self.resource_portal_type)
+    resource.edit(
+      title = "VariatedResource",
+      industrial_phase_list=["phase1", "phase2"],
+      product_line = 'apparel'
+    )
+#    resource.setSizeList(self.size_list)
+    # Add colour variation
+    
+    colour_variation_count = 3
+    for i in range(colour_variation_count):
+      variation = resource.newContent(portal_type = self.colour_variation_portal_type)
+      variation.edit(
+        title = 'ColourVariation%s' % str(i),
+        variation_base_category_list = ('variation',)
+      )
+    # Add morphology variation
+    morphology_variation_count = 2
+    for i in range(morphology_variation_count) :
+      variation = resource.newContent(portal_type=self.morphology_variation_portal_type)
+      variation.edit(
+        title = 'MorphologyVariation%s' % str(i),
+        variation_base_category_list = ('variation',)
+      )
+
+    sequence.edit( resource = resource )
+    resource_list = sequence.get('resource_list',default=[])
+    resource_list.append(resource)
+    sequence.edit( resource_list = resource_list )
+
+  def stepClearActivities(self, sequence=None, sequence_list=None, 
+                          **kw):
+    """
+    Clear activity tables
+    """
+    activity_tool = self.getPortal().portal_activities
+    activity_tool.manageClearActivities(keep=0)
+
+  def stepCreateProductionOrganisation1(self, sequence=None, sequence_list=None, 
+                                        **kw):
+    """
+      Create a organisation for supply
+    """
+    self.stepCreateOrganisation(sequence=sequence, sequence_list=sequence_list,
+                                title='production_organisation1', **kw)
+
+  # Note: SC means Supply Chain
+  def stepCreateGenericSC(self, sequence=None, sequence_list=None, **kw):
+    """
+      Create a empty Supply Chain
+    """
+    portal = self.getPortal()
+    supply_chain_module = portal.getDefaultModule( \
+                                   portal_type=self.supply_chain_portal_type)
+    supply_chain = supply_chain_module.newContent( \
+                                   portal_type=self.supply_chain_portal_type)
+    supply_chain.edit(
+      title = "Supply Chain Generic",
+    )
+    sequence.edit(supply_chain=supply_chain)
+
+  def stepCreateProductionSC(self, sequence=None, sequence_list=None, 
+                             **kw):
+    """
+      Create a empty organisation
+    """
+    # Create supply chain
+    self.stepCreateGenericSC(sequence=sequence, sequence_list=sequence_list,
+                             **kw)
+    supply_chain = sequence.get('supply_chain')
+    supply_chain.edit(
+      title = 'Supply Chain Production'
+    )
+    # Create production node
+    production_organisation  = sequence.get('production_organisation1')
+    production_node = supply_chain.newContent(
+                         portal_type=self.supply_node_portal_type)
+    production_node.edit(
+      destination_value=production_organisation
+    )
+    sequence.edit(production_node1=production_node)
+    # Create production link
+    production_link = supply_chain.newContent(
+                         portal_type=self.supply_link_portal_type)
+    production_link.edit(
+      destination_value=production_node,
+      destination_section_value=production_organisation,
+      min_delay=5,
+      max_delay=6,
+      deliverable=1,
+      industrial_phase_list=["phase1"]
+    )
+
+  def stepCreateComponent1(self,sequence=None, sequence_list=None, \
+                                    **kw):
+    """
+      Create a resource with no variation
+    """
+    portal = self.getPortal()
+    resource_module = portal.getDefaultModule(self.component_portal_type)
+    resource = resource_module.newContent(
+                                  portal_type=self.component_portal_type)
+    resource.edit(
+      title = "Component1"
+    )
+    sequence.edit(component1=resource)
+
+  def stepCreateComponent2(self,sequence=None, sequence_list=None, \
+                                    **kw):
+    """
+      Create a resource with no variation
+    """
+    portal = self.getPortal()
+    resource_module = portal.getDefaultModule(self.component_portal_type)
+    resource = resource_module.newContent(
+                                  portal_type=self.component_portal_type)
+    resource.edit(
+      title = "Component2"
+    )
+    sequence.edit(component2=resource)
+
+  def stepInvalidateTransformation(self, sequence=None, sequence_list=None,
+                               **kw):
+    transformation = sequence.get('transformation')
+
+    workflow_tool = self.getPortal().portal_workflow
+
+    workflow_tool.doActionFor(
+        transformation,
+        'invalidate_action'
+    )
+
+    self.assertEquals('invalidated',transformation.getValidationState())
+
+  def stepValidateTransformation(self, sequence=None, sequence_list=None,
+                               **kw):
+    transformation = sequence.get('transformation')
+
+    workflow_tool = self.getPortal().portal_workflow
+
+    workflow_tool.doActionFor(
+        transformation,
+        'validate_action'
+    )
+
+    self.assertEquals('validated',transformation.getValidationState())
+
+  def stepCreateEmptyTransformation(self, sequence=None, sequence_list=None,
+                               **kw):
+    portal = self.getPortal()
+    transformation_module = portal.getDefaultModule(
+                                     self.transformation_portal_type)
+    transformation = transformation_module.newContent(
+                                   portal_type=self.transformation_portal_type)
+    sequence.edit(transformation=transformation)
+
+
+  def stepSetTransformationTransformedResourceQuantityMatrix(self, sequence=None, sequence_list=None,
+                               **kw):
+    """
+      Fills variation based quantity matrix
+    """
+
+    transformation_transformed_resource = sequence.get('transformation_transformed_resource')
+    colour_count = size_count = 0
+
+    for colour in self.colour_list:
+      for size in self.mrp_size_list:
+        id = 'quantity_%s_%s'%(colour_count,size_count)
+        transformation_transformed_resource.newContent(
+          portal_type = 'Mapped Value',
+          id = id,
+          mapped_value_property_list = ('quantity',),
+          membership_criterion_base_category = ('colour', 'size'),
+          membership_criterion_category = ('colour/%s'%(colour,), 'size/%s'%(size,)),
+          quantity = self.colour_size_quantity_dict[colour][size],
+        )
+        size_count +=1
+      size_count = 0
+      colour_count +=1
+
+  def stepSetTransformationTransformedResourceVariationMatrix(self, sequence=None, sequence_list=None,
+                               **kw):
+    """
+      Fills variation matrix
+    """
+
+    transformation_transformed_resource = sequence.get('transformation_transformed_resource')
+    colour_count = size_count = 0
+
+    for colour in self.colour_list:
+      for size in self.mrp_size_list:
+        id = 'variation_%s_%s'%(colour_count,size_count)
+        transformation_transformed_resource.newContent(
+          portal_type = 'Mapped Value',
+          id = id,
+          mapped_value_property_list = (),
+          membership_criterion_base_category = ('colour', 'size'),
+          membership_criterion_category = ('colour/%s'%(colour,), 'size/%s'%(size,)),
+          categories = self.colour_size_variation_dict[colour][size],
+        )
+        size_count +=1
+      size_count = 0
+      colour_count +=1
+
+  def stepSetOrderLineQuantityMatrix(self, sequence=None, sequence_list=None,
+                               **kw):
+    """
+      Fills variation based quantity matrix
+    """
+    order_line = sequence.get('order_line')
+    colour_count = size_count = 0
+
+    for colour in self.colour_list:
+      for size in self.mrp_size_list:
+        id = 'movement_%s_%s'%(colour_count,size_count)
+        order_line.newContent(
+          portal_type = self.order_cell_portal_type,
+          id = id,
+          mapped_value_property_list = ('quantity', 'price'),
+          membership_criterion_base_category = ('colour', 'size'),
+          membership_criterion_category = ('colour/%s'%(colour,), 'size/%s'%(size,)),
+          categories_list = ('colour/%s'%(colour,), 'size/%s'%(size,)),
+          quantity = self.order_line_colour_size_quantity_dict[colour][size]
+        )
+        size_count +=1
+      size_count = 0
+      colour_count +=1
+
+  def stepSetOrderLineVariationCategories(self, sequence=None, sequence_list=None,
+                               **kw):
+    order_line = sequence.get('order_line')
+
+    order_line.setVariationCategoryList(
+      value = self.order_line_variation_category_list
+    )
+
+  def stepSetTransformationTransformedResourceVariation(self, sequence=None, sequence_list=None,
+                               **kw):
+    """
+      Fills categories of variation
+    """
+
+    transformation_transformed_resource = sequence.get('transformation_transformed_resource')
+
+    transformation_transformed_resource.edit(
+        v_variation_base_category_list = self.variation_category_list,
+        q_variation_base_category_list = self.variation_category_list,
+    )
+
+  def stepSetTransformationVariation(self, sequence=None, sequence_list=None,
+                               **kw):
+    """
+      Fills categories of variation
+    """
+
+    transformation = sequence.get('transformation')
+
+    transformation.edit(
+        variation_base_category_list = self.variation_category_list
+    )
+    
+  def stepFillTransformationWithResource(self, sequence=None, sequence_list=None,
+                               **kw):
+
+    transformation = sequence.get('transformation')
+
+    resource = sequence.get('resource')
+
+    self.assertNotEquals(None, resource)
+
+    transformation.edit(
+      resource_value = resource
+    )
+
+  def stepSetOrderLineQuantity(self, sequence=None, sequence_list=None,
+                               **kw):
+    order_line = sequence.get('order_line')
+    order_line.edit(
+        quantity = self.production_order_line_quantity
+    )
+
+  def stepSetTransformationTransformedResourceQuantity(self, sequence=None, sequence_list=None,
+                               **kw):
+    transformation_transformed_resource = sequence.get('transformation_transformed_resource')
+    transformation_transformed_resource.edit(
+      quantity = self.transformation_transformed_resource_quantity
+    )
+
+  def stepSetTransformationTransformedResourceEfficiency(self, sequence=None, sequence_list=None,
+                               **kw):
+    transformation_transformed_resource = sequence.get('transformation_transformed_resource')
+    transformation_transformed_resource.edit(
+      efficiency = self.transformation_transformed_resource_efficiency
+    )
+
+  def stepSetTransformationTransformedResourceIndustrialPhaseList(self, sequence=None, sequence_list=None,
+                               **kw):
+    transformation_transformed_resource = sequence.get('transformation_transformed_resource')
+    transformation_transformed_resource.edit(
+      industrial_phase_list = self.transformation_transformed_resource_industrial_phase_list
+    )
+
+  def stepFillTransformationTransformedResourceWithComponent1(self, sequence=None, sequence_list=None,
+                               **kw):
+    transformation_transformed_resource = sequence.get('transformation_transformed_resource')
+    component1 = sequence.get('component1')
+
+    self.assertNotEquals(None, component1)
+
+    transformation_transformed_resource.edit(
+      resource_value = component1,
+    )
+
+  def stepCreateTransformationTransformedResource(self, sequence=None, sequence_list=None,
+                               **kw):
+
+    transformation = sequence.get('transformation')
+    transformation_transformed_resource = transformation.newContent(
+      portal_type = self.transformed_resource_portal_type,
+        )
+
+    sequence.edit(transformation_transformed_resource = transformation_transformed_resource)
+
+  def stepCreateTransformation(self, sequence=None, sequence_list=None,
+                               **kw):
+    """
+      Create a transformation
+    """
+    # Create transformation
+    portal = self.getPortal()
+    transformation_module = portal.getDefaultModule(
+                                     self.transformation_portal_type)
+    transformation = transformation_module.newContent(
+                                   portal_type=self.transformation_portal_type)
+    sequence.edit(transformation=transformation)
+    # Set resource
+    resource = sequence.get('resource')
+    transformation.setResourceValue(resource)
+    # Create operation line 1
+    operation_line = transformation.newContent(
+        portal_type=self.operation_line_portal_type)
+    operation_line.edit(
+        # FIXME hardcoded
+        quantity=2,
+        resource_value=portal.portal_categories.resolveCategory(
+                                     'operation/operation1'),
+        industrial_phase_list=['phase1']
+    )
+
+    # Create operation line 2
+    operation_line = transformation.newContent(
+        portal_type=self.operation_line_portal_type)
+    operation_line.edit(
+        # FIXME hardcoded
+        quantity=3,
+        resource_value=portal.portal_categories.resolveCategory(
+                                     'operation/operation2'),
+        industrial_phase_list=['phase2']
+    )
+    # Create transformed resource line 1
+    line = transformation.newContent(
+        portal_type=self.transformed_resource_portal_type)
+    line.edit(
+        # FIXME hardcoded
+        quantity=6,
+        resource_value=sequence.get('component1'),
+        industrial_phase_list=['supply_phase1']
+    )
+    # Create transformed resource line 2
+    line = transformation.newContent(
+        portal_type=self.transformed_resource_portal_type)
+    line.edit(
+        # FIXME hardcoded
+        quantity=7,
+        resource_value=sequence.get('component2'),
+        industrial_phase_list=['supply_phase2']
+    )
+
+  def stepCreateOrder(self, sequence=None, sequence_list=None, **kw):
+    """
+      Create a filled order
+    """
+    portal = self.getPortal()
+    order_module = portal.getDefaultModule(portal_type=self.order_portal_type)
+    order = order_module.newContent(portal_type=self.order_portal_type)
+    organisation = sequence.get('organisation')
+    supply_chain = sequence.get('supply_chain')
+    order.edit(
+      start_date = self.datetime + 10,
+      stop_date = self.datetime + 20,
+      destination_value=organisation,
+      destination_section_value=organisation,
+      specialise_value=supply_chain
+    )
+    sequence.edit(order=order)
+
+  def stepCreateOrderLine(self, sequence=None, sequence_list=None, **kw):
+    """
+      Create a filled order line
+    """
+    order = sequence.get('order')
+    order_line = order.newContent(portal_type=self.order_line_portal_type)
+    resource = sequence.get('resource')
+    transformation = sequence.get('transformation')
+    order_line.edit(
+      resource_value=resource,
+      specialise_value=transformation,
+      quantity=5
+    )
+    sequence.edit(order_line=order_line)
+
+  def stepCreateOrderLineWithoutTransformation(self, sequence=None, sequence_list=None, **kw):
+    """
+      Create a empty order line
+    """
+    order = sequence.get('order')
+    order_line = order.newContent(portal_type=self.order_line_portal_type)
+    resource = sequence.get('resource')
+    order_line.edit(
+      resource_value=resource,
+      quantity=5
+    )
+    sequence.edit(order_line=order_line)
+
+  def stepCheckVariationSimulation(self, sequence=None, sequence_list=None, **kw):
+    # XXX: This check is not testing too much, beside for variation system
+    #      used in production simulations.
+    order = sequence.get('order')
+
+    for order_movement in order.getMovementList():
+      size = order_movement.getSize()
+      colour = order_movement.getColour()
+
+      want_produced_quantity = self.order_line_colour_size_quantity_dict[colour][size]
+      want_consume_quantity = self.colour_size_quantity_dict[colour][size]
+      want_consume_for_production = want_produced_quantity * want_consume_quantity
+      
+      produced_movement = order_movement.getOrderRelatedValue(\
+          portal_type='Simulation Movement')
+
+      self.assertEquals(
+        want_produced_quantity,
+        produced_movement.getQuantity()
+      )
+
+      transformation_rule = produced_movement.contentValues()[0]
+
+      consumption_movement = [q for q in transformation_rule.contentValues() \
+          if q.getId().startswith('cr')][0]
+      production_delivery_movement = [q for q in transformation_rule.contentValues() \
+          if q.getId().startswith('pr')][0]
+
+      self.assertEquals(
+          want_consume_for_production,
+          consumption_movement.getQuantity()
+      )
+
+      self.assertEquals(
+        want_produced_quantity,
+        production_delivery_movement.getQuantity()
+      )
+
+      transformation_sourcing_rule = consumption_movement.contentValues()[0]
+
+      consume_delivery_movement = transformation_sourcing_rule.contentValues()[0]
+
+      self.assertEquals(
+        want_consume_for_production,
+        consume_delivery_movement.getQuantity()
+      )
+
+  def stepCheckEfficiencySimulation(self, sequence=None, sequence_list=None, **kw):
+    """Check that efficiency is applied where is it needed"""
+
+    # XXX: This check is not testing too much, beside for efficiency related quantity
+    #      in just two places.
+    order = sequence.get('order')
+
+    applied_rule = order.getCausalityRelatedValue(portal_type = self.applied_rule_portal_type)
+
+    production_movement_list = applied_rule.contentValues()
+
+    # XXX: hardcode
+    self.assertEquals(
+        1,
+        len(production_movement_list)
+    )
+
+    production_movement = production_movement_list[0]
+
+    transformation_applied_rule = production_movement.contentValues()[0]
+
+    consumed_movement = [q for q in transformation_applied_rule.contentValues() \
+        if q.getId().startswith('cr')][0]
+
+    self.assertEquals(
+        consumed_movement.getQuantity(),
+        self.quantity_after_efficiency_calculation
+    )
+
+    transformation_sourcing_rule = consumed_movement.contentValues()[0]
+
+    consumption_delivery_movement = [q for q in transformation_sourcing_rule.contentValues() \
+        if q.getId().startswith('ts')][0]
+    
+    self.assertEquals(
+        consumption_delivery_movement.getQuantity(),
+        self.quantity_after_efficiency_calculation
+    )
+
+  def stepCheckOrderLineTransformationIsSet(self, sequence=None, sequence_list=None, **kw):
+    order_line = sequence.get('order_line')
+    transformation = sequence.get('transformation')
+
+    self.assertNotEquals(None, transformation)
+
+    self.assertEquals(order_line.getSpecialiseValue(), transformation)
+
+  def stepCheckOrderLineTransformationIsNotSet(self, sequence=None, sequence_list=None, **kw):
+    order_line = sequence.get('order_line')
+
+    self.assertEquals(order_line.getSpecialiseValue(), None)
+
+  def stepRemoveResourceFromOrderLine(self, sequence=None, sequence_list=None, **kw):
+    order_line = sequence.get('order_line')
+
+    order_line.edit(
+        resource = None
+    )
+
+  def stepCheckOrderSimulation(self, sequence=None, sequence_list=None, **kw):
+    """
+      Test if simulation is matching order
+    """
+    order = sequence.get('order')
+    related_applied_rule_list = order.getCausalityRelatedValueList( \
+                                   portal_type=self.applied_rule_portal_type)
+    no_applied_rule_state = ('draft', 'auto_planned')
+    order_state = order.getSimulationState()
+    if order_state in no_applied_rule_state:
+      self.assertEquals(0, len(related_applied_rule_list))
+    else:
+      self.assertEquals(1, len(related_applied_rule_list))
+      applied_rule = related_applied_rule_list[0].getObject()
+      sequence.edit(applied_rule=applied_rule)
+      self.failUnless(applied_rule is not None)
+      self.failUnless(order_state, \
+                      applied_rule.getLastExpandSimulationState())
+      # Test if applied rule has a specialise value with default_order_rule
+      portal_rules = getToolByName(order, 'portal_rules')
+      # XXX hardcoded value
+      self.assertEquals('default_production_order_rule', \
+                        applied_rule.getSpecialiseReference())
+      
+      simulation_movement_list = applied_rule.objectValues()
+      sequence.edit(simulation_movement_list=simulation_movement_list)
+
+  def checkObjectAttributes(self, object, attribute_list):
+    LOG('checkObjectAttributes object.getPath',0,object.getPath())
+    for value, attribute in attribute_list:
+      try:
+        self.assertEquals(value,
+                          getattr(object, attribute)())
+      except AssertionError:
+        LOG('Raise Assertion error',0,'')
+        LOG('object.getQuantity()',0,object.getQuantity())
+        LOG('object.__dict__',0,object.__dict__)
+        LOG('object.getOrderValue().getQuantity()',0,object.getOrderValue().getQuantity())
+        raise AssertionError, "Attribute: %s, Value: %s, Result: %s" %\
+                    (attribute, value, getattr(object, attribute)())
+
+  def stepCheckProductionSimulation(self, sequence=None, sequence_list=None,
+                                    **kw):
+    """
+      Hardcoded check
+    """
+    self.stepCheckOrderSimulation(sequence=sequence,
+                                  sequence_list=sequence_list, **kw)
+    # Test simulation movement generated related to order line
+    simulation_movement_list = sequence.get('simulation_movement_list')
+    self.assertEquals(1, len(simulation_movement_list))
+    order_line = sequence.get('order_line')
+    related_simulation_movement_list = order_line.getOrderRelatedValueList()
+    self.assertEquals(1, len(related_simulation_movement_list))
+    related_simulation_movement = related_simulation_movement_list[0]
+    self.assertEquals(related_simulation_movement,
+                      simulation_movement_list[0])
+    production_organisation1 = sequence.get('production_organisation1')
+    # XXX FIXME test date
+    self.checkObjectAttributes(
+           related_simulation_movement, (
+             (order_line.getQuantity(), 'getQuantity'),
+             (order_line.getResourceValue(), 'getResourceValue'),
+             (order_line.getVariationCategoryList(), 
+              'getVariationCategoryList'),
+             (order_line.getDestinationValue(), 'getDestinationValue'),
+             (order_line.getDestinationSectionValue(), 
+              'getDestinationSectionValue'),
+             (production_organisation1, 'getSourceValue'),
+             (production_organisation1, 'getSourceSectionValue')))
+    # Test next applied rule
+    applied_rule_list = related_simulation_movement.objectValues()
+    self.assertEquals(1, len(applied_rule_list))
+    applied_rule = applied_rule_list[0]
+    self.assertEquals("Applied Rule", applied_rule.getPortalType())
+    portal_rules = getToolByName(applied_rule, 'portal_rules')
+    self.assertEquals('default_transformation_rule', \
+                      applied_rule.getSpecialiseReference())
+    # Test deeper simulation 
+    simulation_movement_list = applied_rule.objectValues()
+    self.assertEquals(2, len(simulation_movement_list))
+    # Test consumed movement
+    transformation = sequence.get('transformation')
+    consumed_movement_id = 'cr_%s_1' % transformation.getId()
+    consumed_movement = applied_rule[consumed_movement_id]
+    operation_resource = consumed_movement.portal_categories.resolveCategory(
+                                              'operation/operation1')
+    # FIXME
+    self.checkObjectAttributes(
+           consumed_movement, (
+             (10, 'getQuantity'),
+             (operation_resource, 'getResourceValue'),
+             ([], 'getVariationCategoryList'),
+             (None, 'getDestinationValue'),
+             (None, 'getDestinationSectionValue'),
+             (production_organisation1, 'getSourceValue'),
+             (production_organisation1, 'getSourceSectionValue')))
+    # Test produced resource
+    produced_movement = applied_rule.pr
+    resource = sequence.get('resource')
+    production_organisation1 = sequence.get('production_organisation1')
+    self.checkObjectAttributes(
+           produced_movement, (
+             (5, 'getQuantity'),
+             (resource, 'getResourceValue'),
+             ([], 'getVariationCategoryList'),
+             (production_organisation1, 'getDestinationValue'),
+             (production_organisation1, 'getDestinationSectionValue'),
+             (None, 'getSourceValue'),
+             (None, 'getSourceSectionValue')))
+
+  def stepCreateSupplyOrganisation1(self, sequence=None, sequence_list=None, 
+                                        **kw):
+    """
+      Create a organisation for supply
+    """
+    self.stepCreateOrganisation(sequence=sequence, sequence_list=sequence_list,
+                                title='supply_organisation1', **kw)
+
+  def stepCreateSourcingSC(self, sequence=None, sequence_list=None, 
+                             **kw):
+    """
+      Create a empty organisation
+    """
+    # Create supply chain
+    self.stepCreateProductionSC(sequence=sequence, sequence_list=sequence_list,
+                                **kw)
+    supply_chain = sequence.get('supply_chain')
+    supply_chain.edit(
+      title = 'Supply Chain Sourcing',
+    )
+    # Create supply node
+    supply_organisation  = sequence.get('supply_organisation1')
+    supply_node = supply_chain.newContent(
+                         portal_type=self.supply_node_portal_type)
+    supply_node.edit(
+      destination_value=supply_organisation
+    )
+    # Create sourcing link
+    supply_link = supply_chain.newContent(
+                         portal_type=self.supply_link_portal_type)
+    production_node1 = sequence.get('production_node1')
+    production_organisation1 = sequence.get('production_organisation1')
+    supply_link.edit(
+      source_value=supply_node,
+      source_section_value=supply_organisation,
+      destination_value=production_node1,
+      destination_section_value=production_organisation1,
+      min_delay=5,
+      max_delay=6,
+      deliverable=0,
+      industrial_phase_list=["supply_phase1"]
+    )
+
+  def stepCheckSourcingSimulation(self, sequence=None, sequence_list=None,
+                                  **kw):
+    """
+      Hardcoded check
+    """
+    self.stepCheckOrderSimulation(sequence=sequence,
+                                  sequence_list=sequence_list, **kw)
+    # Test simulation movement generated related to order line
+    simulation_movement_list = sequence.get('simulation_movement_list')
+    self.assertEquals(1, len(simulation_movement_list))
+    order_line = sequence.get('order_line')
+    related_simulation_movement_list = order_line.getOrderRelatedValueList()
+    self.assertEquals(1, len(related_simulation_movement_list))
+    related_simulation_movement = related_simulation_movement_list[0]
+    self.assertEquals(related_simulation_movement,
+                      simulation_movement_list[0])
+    production_organisation1 = sequence.get('production_organisation1')
+    # XXX FIXME test date
+    self.checkObjectAttributes(
+           related_simulation_movement, (
+             (order_line.getQuantity(), 'getQuantity'),
+             (order_line.getResourceValue(), 'getResourceValue'),
+             (order_line.getVariationCategoryList(), 
+              'getVariationCategoryList'),
+             (order_line.getDestinationValue(), 'getDestinationValue'),
+             (order_line.getDestinationSectionValue(), 
+              'getDestinationSectionValue'),
+             (production_organisation1, 'getSourceValue'),
+             (production_organisation1, 'getSourceSectionValue')))
+    # Test next applied rule
+    applied_rule_list = related_simulation_movement.objectValues()
+    self.assertEquals(1, len(applied_rule_list))
+    applied_rule = applied_rule_list[0]
+    self.assertEquals("Applied Rule", applied_rule.getPortalType())
+    portal_rules = getToolByName(applied_rule, 'portal_rules')
+    self.assertEquals('default_transformation_rule', \
+                      applied_rule.getSpecialiseReference())
+    # Test deeper simulation 
+    simulation_movement_list = list(applied_rule.objectValues())
+    # FIXME
+    self.assertEquals(3, len(simulation_movement_list))
+    # Test produced resource
+    produced_movement = applied_rule.pr
+    resource = sequence.get('resource')
+    production_organisation1 = sequence.get('production_organisation1')
+    self.checkObjectAttributes(
+           produced_movement, (
+             (5, 'getQuantity'),
+             (resource, 'getResourceValue'),
+             ([], 'getVariationCategoryList'),
+             (production_organisation1, 'getDestinationValue'),
+             (production_organisation1, 'getDestinationSectionValue'),
+             (None, 'getSourceValue'),
+             (None, 'getSourceSectionValue')))
+    self.assertEquals(0, len(produced_movement.objectValues()))
+
+    simulation_movement_list.remove(produced_movement)
+    # All code before is a stupid copy (except movement count)
+    # Test consumed movement
+    operation_resource = resource.portal_categories.resolveCategory(
+                                              'operation/operation1')
+    component_resource = sequence.get('component1')
+#     for consumed_movement in (applied_rule.cr_1, applied_rule.cr_2):
+    for consumed_movement in simulation_movement_list:
+      if consumed_movement.getResourceValue() == operation_resource:
+        operation_movement = consumed_movement
+      else:
+        component_movement = consumed_movement
+    # Check operation movement
+    self.checkObjectAttributes(
+           operation_movement, (
+             (10, 'getQuantity'),
+             (operation_resource, 'getResourceValue'),
+             ([], 'getVariationCategoryList'),
+             (None, 'getDestinationValue'),
+             (None, 'getDestinationSectionValue'),
+             (production_organisation1, 'getSourceValue'),
+             (production_organisation1, 'getSourceSectionValue')))
+    self.assertEquals(0, len(operation_movement.objectValues()))
+    # Check component movement
+    self.checkObjectAttributes(
+           component_movement, (
+             (30, 'getQuantity'),
+             (component_resource, 'getResourceValue'),
+             ([], 'getVariationCategoryList'),
+             (None, 'getDestinationValue'),
+             (None, 'getDestinationSectionValue'),
+             (production_organisation1, 'getSourceValue'),
+             (production_organisation1, 'getSourceSectionValue')))
+    self.assertEquals(1, len(component_movement.objectValues()))
+    # Test supply applied rule
+    applied_rule = component_movement.objectValues()[0]
+    self.assertEquals("Applied Rule", applied_rule.getPortalType())
+    portal_rules = getToolByName(applied_rule, 'portal_rules')
+    self.assertEquals('default_transformation_sourcing_rule', \
+                      applied_rule.getSpecialiseReference())
+    # Test supply movement
+    simulation_movement_list = applied_rule.objectValues()
+    # FIXME
+    self.assertEquals(1, len(simulation_movement_list))
+    # Test supply resource
+    supply_movement = applied_rule.ts
+    supply_organisation1 = sequence.get('supply_organisation1')
+    self.checkObjectAttributes(
+           supply_movement, (
+             (30, 'getQuantity'),
+             (component_resource, 'getResourceValue'),
+             ([], 'getVariationCategoryList'),
+             (production_organisation1, 'getDestinationValue'),
+             (production_organisation1, 'getDestinationSectionValue'),
+             (supply_organisation1, 'getSourceValue'),
+             (supply_organisation1, 'getSourceSectionValue')))
+    self.assertEquals(0, len(supply_movement.objectValues()))
+    
+    sequence.edit(
+      produced_movement = produced_movement,
+      operation_movement = operation_movement,
+      component_movement = component_movement,
+      supply_movement = supply_movement,
+      produced_delivery_movement = related_simulation_movement,
+    )
+
+  def stepCreateProductionOrganisation2(self, sequence=None, 
+                                        sequence_list=None, **kw):
+    """
+      Create a organisation for supply
+    """
+    self.stepCreateOrganisation(sequence=sequence, sequence_list=sequence_list,
+                                title='production_organisation2', **kw)
+
+  def stepCreateSupplyOrganisation2(self, sequence=None, sequence_list=None, 
+                                        **kw):
+    """
+      Create a organisation for supply
+    """
+    self.stepCreateOrganisation(sequence=sequence, sequence_list=sequence_list,
+                                title='supply_organisation2', **kw)
+
+  def stepCreateTwoPhasesSC(self, sequence=None, sequence_list=None, 
+                             **kw):
+    """
+      Create a empty organisation
+    """
+    # Create supply chain
+    self.stepCreateSourcingSC(sequence=sequence, sequence_list=sequence_list,
+                              **kw)
+    supply_chain = sequence.get('supply_chain')
+    supply_chain.edit(
+      title = 'Supply Chain Two Phases',
+    )
+    # Create production node
+    production_organisation2  = sequence.get('production_organisation2')
+    production_node2 = supply_chain.newContent(
+                         portal_type=self.supply_node_portal_type)
+    production_node2.edit(
+      destination_value=production_organisation2
+    )
+    sequence.edit(production_node2=production_node2)
+    # Create production link
+    production_link2 = supply_chain.newContent(
+                         portal_type=self.supply_link_portal_type)
+    production_link2.edit(
+      destination_value=production_node2,
+      min_delay=5,
+      max_delay=6,
+      deliverable=0,
+      industrial_phase_list=["phase2"]
+    )
+    # Link production_node2 and production_node1
+    supply_link = supply_chain.newContent(
+                         portal_type=self.supply_link_portal_type)
+    production_node1 = sequence.get('production_node1')
+    supply_link.edit(
+      source_value=production_node2,
+      destination_value=production_node1,
+      min_delay=5,
+      max_delay=6,
+      deliverable=0,
+      industrial_phase_list=[]
+    )
+    # Create supply node
+    supply_organisation2  = sequence.get('supply_organisation2')
+    supply_node2 = supply_chain.newContent(
+                         portal_type=self.supply_node_portal_type)
+    supply_node2.edit(
+      destination_value=supply_organisation2
+    )
+    # Create sourcing link
+    supply_link2 = supply_chain.newContent(
+                         portal_type=self.supply_link_portal_type)
+    supply_link2.edit(
+      source_value=supply_node2,
+      destination_value=production_node2,
+      min_delay=5,
+      max_delay=6,
+      deliverable=0,
+      industrial_phase_list=["supply_phase2"]
+    )
+
+  def stepCheckTwoPhasesSimulation(self, sequence=None, sequence_list=None,
+                                   **kw):
+    """
+      Hardcoded check
+    """
+#     self.stepCheckSourcingSimulation(sequence=sequence,
+#                                      sequence_list=sequence_list, **kw)
+    self.stepCheckOrderSimulation(sequence=sequence,
+                                  sequence_list=sequence_list, **kw)
+    # Test simulation movement generated related to order line
+    simulation_movement_list = sequence.get('simulation_movement_list')
+    self.assertEquals(1, len(simulation_movement_list))
+    order_line = sequence.get('order_line')
+    related_simulation_movement_list = order_line.getOrderRelatedValueList()
+    self.assertEquals(1, len(related_simulation_movement_list))
+    related_simulation_movement = related_simulation_movement_list[0]
+    self.assertEquals(related_simulation_movement,
+                      simulation_movement_list[0])
+    production_organisation1 = sequence.get('production_organisation1')
+    # XXX FIXME test date
+    self.checkObjectAttributes(
+           related_simulation_movement, (
+             (order_line.getQuantity(), 'getQuantity'),
+             (order_line.getResourceValue(), 'getResourceValue'),
+             (order_line.getVariationCategoryList(), 
+              'getVariationCategoryList'),
+             (order_line.getDestinationValue(), 'getDestinationValue'),
+             (order_line.getDestinationSectionValue(), 
+              'getDestinationSectionValue'),
+             (production_organisation1, 'getSourceValue'),
+             (production_organisation1, 'getSourceSectionValue')))
+    # Test next applied rule
+    applied_rule_list = related_simulation_movement.objectValues()
+    self.assertEquals(1, len(applied_rule_list))
+    applied_rule = applied_rule_list[0]
+    self.assertEquals("Applied Rule", applied_rule.getPortalType())
+    portal_rules = getToolByName(applied_rule, 'portal_rules')
+    self.assertEquals('default_transformation_rule', \
+                      applied_rule.getSpecialiseReference())
+    # Test deeper simulation 
+    simulation_movement_list = list(applied_rule.objectValues())
+    # FIXME
+    self.assertEquals(4, len(simulation_movement_list))
+    # Test produced resource
+    produced_movement = applied_rule.pr
+    resource = sequence.get('resource')
+    production_organisation1 = sequence.get('production_organisation1')
+    self.checkObjectAttributes(
+           produced_movement, (
+             (5, 'getQuantity'),
+             (resource, 'getResourceValue'),
+             ([], 'getVariationCategoryList'),
+             (production_organisation1, 'getDestinationValue'),
+             (production_organisation1, 'getDestinationSectionValue'),
+             (None, 'getSourceValue'),
+             (None, 'getSourceSectionValue')))
+    self.assertEquals(0, len(produced_movement.objectValues()))
+
+    # Get modified resource (test later)
+    modified_movement = applied_rule.mr_1
+    simulation_movement_list.remove(produced_movement)
+    simulation_movement_list.remove(modified_movement)
+    # All code before is a stupid copy (except movement count)
+    # Test consumed movement
+    operation_resource = resource.portal_categories.resolveCategory(
+                                              'operation/operation1')
+    component_resource = sequence.get('component1')
+#     for consumed_movement in (applied_rule.cr_1, applied_rule.cr_2):
+    for consumed_movement in simulation_movement_list:
+      if consumed_movement.getResourceValue() == operation_resource:
+        operation_movement = consumed_movement
+      else:
+        component_movement = consumed_movement
+    # Check operation movement
+    self.checkObjectAttributes(
+           operation_movement, (
+             (10, 'getQuantity'),
+             (operation_resource, 'getResourceValue'),
+             ([], 'getVariationCategoryList'),
+             (None, 'getDestinationValue'),
+             (None, 'getDestinationSectionValue'),
+             (production_organisation1, 'getSourceValue'),
+             (production_organisation1, 'getSourceSectionValue')))
+    self.assertEquals(0, len(operation_movement.objectValues()))
+    # Check component movement
+    self.checkObjectAttributes(
+           component_movement, (
+             (30, 'getQuantity'),
+             (component_resource, 'getResourceValue'),
+             ([], 'getVariationCategoryList'),
+             (None, 'getDestinationValue'),
+             (None, 'getDestinationSectionValue'),
+             (production_organisation1, 'getSourceValue'),
+             (production_organisation1, 'getSourceSectionValue')))
+    self.assertEquals(1, len(component_movement.objectValues()))
+    # Test supply applied rule
+    applied_rule = component_movement.objectValues()[0]
+    self.assertEquals("Applied Rule", applied_rule.getPortalType())
+    portal_rules = getToolByName(applied_rule, 'portal_rules')
+    self.assertEquals('default_transformation_sourcing_rule', \
+                      applied_rule.getSpecialiseReference())
+    # Test supply movement
+    simulation_movement_list = applied_rule.objectValues()
+    # FIXME
+    self.assertEquals(1, len(simulation_movement_list))
+    # Test supply resource
+    supply_movement = applied_rule.ts
+    supply_organisation1 = sequence.get('supply_organisation1')
+    self.checkObjectAttributes(
+           supply_movement, (
+             (30, 'getQuantity'),
+             (component_resource, 'getResourceValue'),
+             ([], 'getVariationCategoryList'),
+             (production_organisation1, 'getDestinationValue'),
+             (production_organisation1, 'getDestinationSectionValue'),
+             (supply_organisation1, 'getSourceValue'),
+             (supply_organisation1, 'getSourceSectionValue')))
+    self.assertEquals(0, len(supply_movement.objectValues()))
+
+    # Test modified movement
+    resource = sequence.get('resource')
+    production_organisation1 = sequence.get('production_organisation1')
+    self.checkObjectAttributes(
+           modified_movement, (
+             (5, 'getQuantity'),
+             (resource, 'getResourceValue'),
+             (['industrial_phase/phase2'], 'getVariationCategoryList'),
+             (production_organisation1, 'getSourceValue'),
+             (production_organisation1, 'getSourceSectionValue'),
+             (None, 'getDestinationValue'),
+             (None, 'getDestinationSectionValue')))
+    self.assertEquals(1, len(modified_movement.objectValues()))
+    # Test next applied rule
+    applied_rule_list = modified_movement.objectValues()
+    applied_rule = applied_rule_list[0]
+    self.assertEquals("Applied Rule", applied_rule.getPortalType())
+    portal_rules = getToolByName(applied_rule, 'portal_rules')
+    self.assertEquals('default_transformation_sourcing_rule', \
+                      applied_rule.getSpecialiseReference())
+    # Test deeper simulation 
+    simulation_movement_list = list(applied_rule.objectValues())
+    self.assertEquals(1, len(simulation_movement_list))
+    # Test produced resource
+    sourcing_movement = simulation_movement_list[0]
+    resource = sequence.get('resource')
+    production_organisation1 = sequence.get('production_organisation1')
+    production_organisation2 = sequence.get('production_organisation2')
+    self.checkObjectAttributes(
+           sourcing_movement, (
+             (5, 'getQuantity'),
+             (resource, 'getResourceValue'),
+             (['industrial_phase/phase2'], 'getVariationCategoryList'),
+             (production_organisation1, 'getDestinationValue'),
+# XXX             (production_organisation1, 'getDestinationSectionValue'),
+             (production_organisation2, 'getSourceValue'),
+# XXX             (production_organisation2, 'getSourceSectionValue')))
+           ))
+    self.assertEquals(1, len(sourcing_movement.objectValues()))
+    # Test next applied rule
+    applied_rule_list = sourcing_movement.objectValues()
+    self.assertEquals(1, len(applied_rule_list))
+    applied_rule = applied_rule_list[0]
+    self.assertEquals("Applied Rule", applied_rule.getPortalType())
+    portal_rules = getToolByName(applied_rule, 'portal_rules')
+    self.assertEquals('default_transformation_rule', \
+                      applied_rule.getSpecialiseReference())
+    # Test deeper simulation 
+    simulation_movement_list = list(applied_rule.objectValues())
+    # FIXME
+    self.assertEquals(3, len(simulation_movement_list))
+    # Test produced resource
+    produced_movement = applied_rule.pr
+    resource = sequence.get('resource')
+    production_organisation2 = sequence.get('production_organisation2')
+    self.checkObjectAttributes(
+           produced_movement, (
+             (5, 'getQuantity'),
+             (resource, 'getResourceValue'),
+             (['industrial_phase/phase2'], 'getVariationCategoryList'),
+             (production_organisation2, 'getDestinationValue'),
+# XXX             (production_organisation2, 'getDestinationSectionValue'),
+             (None, 'getSourceValue'),
+             (None, 'getSourceSectionValue')))
+    self.assertEquals(0, len(produced_movement.objectValues()))
+
+    simulation_movement_list.remove(produced_movement)
+    # All code before is a stupid copy (except movement count)
+    # Test consumed movement
+    operation_resource = resource.portal_categories.resolveCategory(
+                                              'operation/operation2')
+    component_resource = sequence.get('component2')
+    for consumed_movement in simulation_movement_list:
+      if consumed_movement.getResourceValue() == operation_resource:
+        operation_movement = consumed_movement
+      else:
+        component_movement = consumed_movement
+    # Check operation movement
+    self.checkObjectAttributes(
+           operation_movement, (
+             (15, 'getQuantity'),
+             (operation_resource, 'getResourceValue'),
+             ([], 'getVariationCategoryList'),
+             (None, 'getDestinationValue'),
+             (None, 'getDestinationSectionValue'),
+             (production_organisation2, 'getSourceValue'),
+# XXX              (production_organisation2, 'getSourceSectionValue')))
+           ))
+    self.assertEquals(0, len(operation_movement.objectValues()))
+    # Check component movement
+    self.checkObjectAttributes(
+           component_movement, (
+             (35, 'getQuantity'),
+             (component_resource, 'getResourceValue'),
+             ([], 'getVariationCategoryList'),
+             (None, 'getDestinationValue'),
+             (None, 'getDestinationSectionValue'),
+             (production_organisation2, 'getSourceValue'),
+# XXX              (production_organisation2, 'getSourceSectionValue')))
+           ))
+    self.assertEquals(1, len(component_movement.objectValues()))
+    # Test supply applied rule
+    applied_rule = component_movement.objectValues()[0]
+    self.assertEquals("Applied Rule", applied_rule.getPortalType())
+    portal_rules = getToolByName(applied_rule, 'portal_rules')
+    self.assertEquals('default_transformation_sourcing_rule', \
+                      applied_rule.getSpecialiseReference())
+    # Test supply movement
+    simulation_movement_list = applied_rule.objectValues()
+    # FIXME
+    self.assertEquals(1, len(simulation_movement_list))
+    # Test supply resource
+    supply_movement = applied_rule.ts
+    supply_organisation2  = sequence.get('supply_organisation2')
+    self.checkObjectAttributes(
+           supply_movement, (
+             (35, 'getQuantity'),
+             (component_resource, 'getResourceValue'),
+             ([], 'getVariationCategoryList'),
+             (production_organisation2, 'getDestinationValue'),
+# XXX              (production_organisation2, 'getDestinationSectionValue'),
+             (supply_organisation2, 'getSourceValue'),
+# XXX              (supply_organisation2, 'getSourceSectionValue')))
+           ))
+    self.assertEquals(0, len(supply_movement.objectValues()))
+
+  SOURCING_ORDER_SEQUENCE = '\
+                      ClearActivities \
+                      CreateProductionOrganisation1 \
+                      CreateSupplyOrganisation1 \
+                      CreateSourcingSC \
+                      CreateNotVariatedResource \
+                      CreateComponent1 \
+                      CreateTransformation \
+                      CreateOrganisation \
+                      CreateOrder \
+                      CreateOrderLine \
+                      Tic \
+                      OrderOrder \
+                      Tic \
+                      CheckSourcingSimulation \
+                      ConfirmOrder \
+                      Tic \
+                      CheckSourcingSimulation \
+                      '
+    
+class TestProductionOrder(TestProductionOrderMixin, ERP5TypeTestCase):
+  """
+    Test business template erp5_mrp
+  """
+  run_all_test = 1
+
+  def getTitle(self):
+    return "Production Order"
+
+  def test_01_testProductionSimulationExpand(self, quiet=0, run=run_all_test):
+    """
+      Test generation and update of order applied rule.
+    """
+    if not run: return
+    sequence_list = SequenceList()
+    # Test when order is 
+    sequence_string = '\
+                      ClearActivities \
+                      CreateProductionOrganisation1 \
+                      CreateProductionSC \
+                      CreateNotVariatedResource \
+                      CreateComponent1 \
+                      CreateTransformation \
+                      CreateOrganisation \
+                      CreateOrder \
+                      CreateOrderLine \
+                      Tic \
+                      OrderOrder \
+                      Tic \
+                      CheckProductionSimulation \
+                      '
+    sequence_list.addSequenceString(sequence_string)
+    sequence_list.play(self)
+
+  def test_02_testSourcingSimulationExpand(self, quiet=0, 
+                                                     run=run_all_test):
+    """
+      Test generation and update of order applied rule.
+    """
+    if not run: return
+    sequence_list = SequenceList()
+    # Test when order is 
+    sequence_string = '\
+                      ClearActivities \
+                      CreateProductionOrganisation1 \
+                      CreateSupplyOrganisation1 \
+                      CreateSourcingSC \
+                      CreateNotVariatedResource \
+                      CreateComponent1 \
+                      CreateTransformation \
+                      CreateOrganisation \
+                      CreateOrder \
+                      CreateOrderLine \
+                      Tic \
+                      OrderOrder \
+                      Tic \
+                      CheckSourcingSimulation \
+                      '
+    sequence_list.addSequenceString(sequence_string)
+    sequence_list.play(self)
+
+  def test_03_testIndustrialPhase(self, quiet=0, run=run_all_test):
+    """
+    """
+    if not run: return
+    sequence_list = SequenceList()
+    # Test when order is 
+    sequence_string = '\
+                      ClearActivities \
+                      CreateProductionOrganisation1 \
+                      CreateProductionOrganisation2 \
+                      CreateSupplyOrganisation1 \
+                      CreateSupplyOrganisation2 \
+                      CreateTwoPhasesSC \
+                      CreateNotVariatedResource \
+                      CreateComponent1 \
+                      CreateComponent2 \
+                      CreateTransformation \
+                      CreateOrganisation \
+                      CreateOrder \
+                      CreateOrderLine \
+                      Tic \
+                      OrderOrder \
+                      Tic \
+                      CheckTwoPhasesSimulation \
+                      '
+    sequence_list.addSequenceString(sequence_string)
+    sequence_list.play(self)
+
+  def test_04_testProductionSimulationBuild(self, quiet=0, run=run_all_test):
+    """
+    Test delivery building.
+    XXX Test method still required
+    """
+    if not run: return
+    sequence_list = SequenceList()
+    # Test when order is 
+    sequence_string = '\
+                      ClearActivities \
+                      CreateProductionOrganisation1 \
+                      CreateProductionSC \
+                      CreateNotVariatedResource \
+                      CreateComponent1 \
+                      CreateTransformation \
+                      CreateOrganisation \
+                      CreateOrder \
+                      CreateOrderLine \
+                      Tic \
+                      OrderOrder \
+                      Tic \
+                      ConfirmOrder \
+                      Tic \
+                      '
+    sequence_list.addSequenceString(sequence_string)
+    sequence_list.play(self)
+
+  def test_05_testSourcingSimulationBuild(self, quiet=0, 
+                                          run=run_all_test):
+    """
+    Test delivery building.
+    XXX Test method still required
+    """
+    if not run: return
+    sequence_list = SequenceList()
+    # Test when order is 
+    sequence_list.addSequenceString(self.SOURCING_ORDER_SEQUENCE)
+    sequence_list.play(self)
+
+  def test_06_testIndustrialPhase(self, quiet=0, run=run_all_test):
+    """
+    Test delivery building.
+    XXX Test method still required
+    """
+    if not run: return
+    sequence_list = SequenceList()
+    # Test when order is 
+    sequence_string = '\
+                      ClearActivities \
+                      CreateProductionOrganisation1 \
+                      CreateProductionOrganisation2 \
+                      CreateSupplyOrganisation1 \
+                      CreateSupplyOrganisation2 \
+                      CreateTwoPhasesSC \
+                      CreateNotVariatedResource \
+                      CreateComponent1 \
+                      CreateComponent2 \
+                      CreateTransformation \
+                      CreateOrganisation \
+                      CreateOrder \
+                      CreateOrderLine \
+                      Tic \
+                      OrderOrder \
+                      Tic \
+                      ConfirmOrder \
+                      Tic \
+                      '
+    sequence_list.addSequenceString(sequence_string)
+    sequence_list.play(self)
+
+  def stepCopyPasteSupplyChain(self, sequence=None, sequence_list=None, 
+                               **kw):
+    """
+    Copy/Paste the supply chain
+    """
+    portal = self.getPortal()
+    supply_chain_module = portal.getDefaultModule( \
+                                   portal_type=self.supply_chain_portal_type)
+    supply_chain = sequence.get('supply_chain')
+
+    cb_data = supply_chain_module.manage_copyObjects([supply_chain.getId()])
+    copied, = supply_chain_module.manage_pasteObjects(cb_data)
+    pasted_sc = supply_chain_module[copied['new_id']]
+    sequence.edit(pasted_sc=pasted_sc)
+
+  def stepCheckPastedSupplyChain(self, sequence=None, sequence_list=None, 
+                                 **kw):
+    """
+    Check pasted supply chain
+    """
+    pasted_sc = sequence.get('pasted_sc')
+    pasted_supply_node = pasted_sc.contentValues(portal_type='Supply Node')[0]
+    pasted_supply_link = pasted_sc.contentValues(portal_type='Supply Link')[0]
+    self.assertEquals(pasted_supply_node.getRelativeUrl(),
+                      pasted_supply_link.getDestination())
+
+  def test_07_testTransformationInteractionProductionOrderLine(self, quiet=0, run=run_all_test):
+    """
+    Test for setting/resetting Transformation on Production Order Line
+    """
+    if not run: return
+
+    bootstrap_sequence_string = '\
+                      ClearActivities \
+                      CreateNotVariatedResource \
+                      CreateOrder \
+                      '
+    sequence_list = SequenceList()
+
+    # normal case
+    sequence_string = bootstrap_sequence_string + '\
+                      CreateTransformation \
+                      Tic \
+                      CreateOrderLineWithoutTransformation \
+                      Tic \
+                      CheckOrderLineTransformationIsSet \
+                      '
+    sequence_list.addSequenceString(sequence_string)
+
+    # no transformation
+    sequence_string = bootstrap_sequence_string + '\
+                      CreateOrderLineWithoutTransformation \
+                      Tic \
+                      CheckOrderLineTransformationIsNotSet \
+                      '
+    sequence_list.addSequenceString(sequence_string)
+
+    # transformation set, then unset
+    sequence_string = bootstrap_sequence_string + '\
+                      CreateTransformation \
+                      Tic \
+                      CreateOrderLineWithoutTransformation \
+                      Tic \
+                      CheckOrderLineTransformationIsSet \
+                      RemoveResourceFromOrderLine \
+                      Tic \
+                      CheckOrderLineTransformationIsNotSet \
+                      '
+    sequence_list.addSequenceString(sequence_string)
+
+    # more than one transformation
+    sequence_string = bootstrap_sequence_string + '\
+                      CreateTransformation \
+                      CreateTransformation \
+                      Tic \
+                      CreateOrderLineWithoutTransformation \
+                      Tic \
+                      CheckOrderLineTransformationIsNotSet \
+                      '
+    sequence_list.addSequenceString(sequence_string)
+
+    # case of invalidated Transformation
+    sequence_string = bootstrap_sequence_string + '\
+                      CreateTransformation \
+                      Tic \
+                      ValidateTransformation \
+                      InvalidateTransformation \
+                      Tic \
+                      CreateOrderLineWithoutTransformation \
+                      Tic \
+                      CheckOrderLineTransformationIsNotSet \
+                      '
+    sequence_list.addSequenceString(sequence_string)
+
+    # case of invalidated Transformation and other
+    sequence_string = bootstrap_sequence_string + '\
+                      CreateTransformation \
+                      Tic \
+                      ValidateTransformation \
+                      InvalidateTransformation \
+                      Tic \
+                      CreateTransformation \
+                      Tic \
+                      CreateOrderLineWithoutTransformation \
+                      Tic \
+                      CheckOrderLineTransformationIsSet \
+                      '
+    sequence_list.addSequenceString(sequence_string)
+
+    sequence_list.play(self)
+    
+  def test_08_testTransformationWithEfficiency(self, quiet=0, run=run_all_test):
+    """
+    Test, that efficiency from transformation applies correctly
+    """
+    if not run: return
+
+    sequence_string = '\
+                      ClearActivities \
+                      CreateProductionOrganisation1 \
+                      CreateSupplyOrganisation1 \
+                      CreateSourcingSC \
+                      Tic \
+                      CreateNotVariatedResource \
+                      CreateComponent1 \
+                      CreateEmptyTransformation \
+                      FillTransformationWithResource \
+                      Tic \
+                      CreateTransformationTransformedResource \
+                      FillTransformationTransformedResourceWithComponent1 \
+                      SetTransformationTransformedResourceQuantity \
+                      SetTransformationTransformedResourceEfficiency \
+                      SetTransformationTransformedResourceIndustrialPhaseList \
+                      Tic \
+                      CreateOrganisation \
+                      CreateOrder \
+                      CreateOrderLine \
+                      SetOrderLineQuantity \
+                      Tic \
+                      OrderOrder \
+                      Tic \
+                      CheckEfficiencySimulation \
+                      '
+    sequence_list = SequenceList()
+    sequence_list.addSequenceString(sequence_string)
+
+    # case - we need Q:10.0, efficiency is 80% (we need more), producing 1.0
+    self.transformation_transformed_resource_quantity = 10.0
+    self.transformation_transformed_resource_efficiency = 0.8 # 80%
+    self.transformation_transformed_resource_industrial_phase_list = ['supply_phase1',]
+
+    self.production_order_line_quantity = 1.0
+    self.quantity_after_efficiency_calculation = 12.5 # (1.0 * 10.0) / 0.8
+
+    sequence_list.play(self)
+
+    # case - we need Q:10.0, efficiency is None (normal, nothing set), producing 1.0
+    self.transformation_transformed_resource_quantity = 10.0
+    self.transformation_transformed_resource_efficiency = None
+    self.transformation_transformed_resource_industrial_phase_list = ['supply_phase1',]
+
+    self.production_order_line_quantity = 1.0
+    self.quantity_after_efficiency_calculation = 10.0 # (1.0 * 10.0) / 1.0
+
+    sequence_list.play(self)
+
+    # case - we need Q:10.0, efficiency is 100% (normal), producing 1.0
+    self.transformation_transformed_resource_quantity = 10.0
+    self.transformation_transformed_resource_efficiency = 1.0
+    self.transformation_transformed_resource_industrial_phase_list = ['supply_phase1',]
+
+    self.production_order_line_quantity = 1.0
+    self.quantity_after_efficiency_calculation = 10.0 # (1.0 * 10.0) / 1.0
+
+    sequence_list.play(self)
+
+    # case - we need Q:10.0, efficiency is 125% (miracle?), producing 1.0
+    self.transformation_transformed_resource_quantity = 10.0
+    self.transformation_transformed_resource_efficiency = 1.25
+    self.transformation_transformed_resource_industrial_phase_list = ['supply_phase1',]
+
+    self.production_order_line_quantity = 1.0
+    self.quantity_after_efficiency_calculation = 8.0 # (1.0 * 10.0) / 1.25
+
+    sequence_list.play(self)
+
+    # case - we need Q:10.0, efficiency is -80% (nonsense?), producing 1.0
+    self.transformation_transformed_resource_quantity = 10.0
+    self.transformation_transformed_resource_efficiency = -0.8
+    self.transformation_transformed_resource_industrial_phase_list = ['supply_phase1',]
+
+    self.production_order_line_quantity = 1.0
+    self.quantity_after_efficiency_calculation = -12.5 # (1.0 * 10.0) / -0.8
+
+    sequence_list.play(self)
+
+  def test_09_testTransformationWithVariation(self, quiet=0, run=run_all_test):
+    """
+    Test, that variation from transformation works correctly on order
+
+    Note: Read below variables to know, what and how was defined
+    """
+    if not run: return
+
+    self.transformation_transformed_resource_quantity = 0.0
+    self.transformation_transformed_resource_industrial_phase_list = ['supply_phase1',]
+    self.production_order_line_quantity = 0.0
+    self.variation_category_list = ['colour','size']
+
+    self.colour_size_quantity_dict = {
+      'green' : {
+        'Man' : 1.0,
+        'Woman' : 2.0
+      },
+      'blue' : {
+        'Man' : 3.0,
+        'Woman' : 4.0
+      },
+    }
+
+    self.colour_size_variation_dict = {
+      'green' : {
+        'Man' : ('colour/green','size/Man'),
+        'Woman' : ('colour/green','size/Woman')
+      },
+      'blue' : {
+        'Man' : ('colour/blue','size/Man'),
+        'Woman' : ('colour/blue','size/Woman')
+      },
+    }
+
+    self.order_line_variation_category_list = [
+      'size/Man',
+      'size/Woman',
+      'colour/green',
+      'colour/blue',
+    ]
+
+    self.order_line_colour_size_quantity_dict = {
+      'green' : {
+        'Man' : 9.0,
+        'Woman' : 8.0
+      },
+      'blue' : {
+        'Man' : 7.0,
+        'Woman' : 6.0
+      },
+    }
+
+    sequence_string = '\
+                      ClearActivities \
+                      CreateProductionOrganisation1 \
+                      CreateSupplyOrganisation1 \
+                      CreateSourcingSC \
+                      Tic \
+                      CreateColourSizeVariatedResource \
+                      CreateColourSizeVariatedComponent1 \
+                      Tic \
+                      CreateEmptyTransformation \
+                      FillTransformationWithResource \
+                      SetTransformationVariation \
+                      Tic \
+                      CreateTransformationTransformedResource \
+                      FillTransformationTransformedResourceWithComponent1 \
+                      SetTransformationTransformedResourceVariation \
+                      SetTransformationTransformedResourceIndustrialPhaseList \
+                      Tic \
+                      SetTransformationTransformedResourceQuantityMatrix \
+                      SetTransformationTransformedResourceVariationMatrix \
+                      Tic \
+                      CreateOrganisation \
+                      CreateOrder \
+                      CreateOrderLine \
+                      SetOrderLineVariationCategories \
+                      SetOrderLineQuantityMatrix \
+                      Tic \
+                      OrderOrder \
+                      Tic \
+                      CheckVariationSimulation \
+                      ConfirmOrder \
+                      Tic \
+                      '
+    sequence_list = SequenceList()
+    sequence_list.addSequenceString(sequence_string)
+
+    sequence_list.play(self)
+
+  def test_50_testCopyPaste(self, quiet=0, run=run_all_test):
+    """
+    Check that relation are changed when doing a copy/paste,
+    on supply chain
+    """
+    if not run: return
+    sequence_list = SequenceList()
+    sequence_string = '\
+            ClearActivities \
+            CreateProductionOrganisation1 \
+            CreateProductionSC \
+            CopyPasteSupplyChain \
+            Tic \
+            CheckPastedSupplyChain \
+                      '
+    sequence_list.addSequenceString(sequence_string)
+    sequence_list.play(self)
+
+  def stepCreateEmptySC(self, sequence=None, sequence_list=None, **kw):
+    """
+      Create a empty Supply Chain
+    """
+    portal = self.getPortal()
+    supply_chain_module = portal.getDefaultModule( \
+                                   portal_type=self.supply_chain_portal_type)
+    supply_chain = supply_chain_module.newContent( \
+                                   portal_type=self.supply_chain_portal_type)
+    supply_chain.edit(
+      title = "Supply Chain Empty",
+    )
+    sequence.edit(empty_supply_chain=supply_chain)
+
+  def stepCutPasteSupplyNodeInAnotherContainer(self, sequence=None, 
+                                               sequence_list=None, **kw):
+    """
+    Cut/Paste a supply node in another container
+    """
+    supply_chain = sequence.get('supply_chain')
+    empty_supply_chain = sequence.get('empty_supply_chain')
+
+    supply_node = supply_chain.contentValues(portal_type='Supply Node')[0]
+    cb_data = supply_chain.manage_cutObjects([supply_node.getId()])
+    copied, = empty_supply_chain.manage_pasteObjects(cb_data)
+
+  def stepCheckPastedSupplyNode(self, sequence=None, sequence_list=None, 
+                                 **kw):
+    """
+    Check pasted supply node
+    """
+    supply_chain = sequence.get('supply_chain')
+    empty_supply_chain = sequence.get('empty_supply_chain')
+
+    supply_node = empty_supply_chain.contentValues(portal_type='Supply Node')[0]
+    supply_link = supply_chain.contentValues(portal_type='Supply Link')[0]
+    self.assertEquals(supply_node.getRelativeUrl(),
+                      supply_link.getDestination())
+
+  def test_51_testCutPasteInAnotherContainer(self, quiet=0, run=run_all_test):
+    """
+    Check that relations are changed when doing a copy/paste,
+    on a supply chain.
+
+    The point in this test is that internal relations should be updated
+    when copying an object. Suppose that a document D1 contains sub-objects
+    S1_1 and S1_2, and S1_1 is related to S1_2. When copying D1 to D2,
+    S2_1 and S2_2 are also copied from S1_1 and S1_2. Now S2_1 should be
+    related to S2_2, instead of S1_2.
+
+    Good:
+
+    D1 -+- S1_1          D1 -+- S1_1   D2 -+- S2_1
+        |    |      =>       |    |        |    |
+        |    v               |    v        |    v
+        +- S1_2              +- S1_2       +- S2_2
+
+    Bad:
+
+    D1 -+- S1_1          D1 -+- S1_1   D2 -+- S2_1
+        |    |      =>       |    |      __|_/    
+        |    v               |    v     /  |     
+        +- S1_2              +- S1_2<--/   +- S2_2
+
+    """
+    if not run: return
+    sequence_list = SequenceList()
+    sequence_string = '\
+            ClearActivities \
+            CreateProductionOrganisation1 \
+            CreateProductionSC \
+            CreateEmptySC \
+            Tic \
+            CutPasteSupplyNodeInAnotherContainer \
+            Tic \
+            CheckPastedSupplyNode \
+                      '
+    sequence_list.addSequenceString(sequence_string)
+    sequence_list.play(self)
+
+def test_suite():
+  suite = unittest.TestSuite()
+  suite.addTest(unittest.makeSuite(TestProductionOrder))
+  return suite
diff --git a/product/ERP5/tests/testLegacyProductionPackingList.py b/product/ERP5/tests/testLegacyProductionPackingList.py
new file mode 100644
index 0000000000..307456fc65
--- /dev/null
+++ b/product/ERP5/tests/testLegacyProductionPackingList.py
@@ -0,0 +1,781 @@
+# -*- coding: utf-8 -*-
+##############################################################################
+#
+# Copyright (c) 2008 Nexedi SA and Contributors. All Rights Reserved.
+#          艁ukasz Nowak <lukasz.nowak@ventis.com.pl>
+#
+# WARNING: This program as such is intended to be used by professional
+# programmers who take the whole responsibility of assessing all potential
+# consequences resulting from its eventual inadequacies and bugs
+# End users who are looking for a ready-to-use solution with commercial
+# guarantees and support are strongly adviced to contract a Free Software
+# Service Company
+#
+# This program is Free Software; you can redistribute it and/or
+# modify it under the terms of the GNU General Public License
+# as published by the Free Software Foundation; either version 2
+# of the License, or (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program; if not, write to the Free Software
+# Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
+#
+##############################################################################
+
+import unittest
+
+from Products.ERP5Type.tests.ERP5TypeTestCase import ERP5TypeTestCase
+from Products.ERP5Type.tests.Sequence import SequenceList
+from testLegacyProductionOrder import TestProductionOrderMixin
+from testLegacyPackingList import TestPackingListMixin
+
+class TestProductionPackingReportListMixin(TestProductionOrderMixin, TestPackingListMixin, \
+                          ERP5TypeTestCase):
+  """Mixin for testing Production Packing Lists and Production Reports"""
+
+  def modifyPackingListState(self, transition_name,
+                             sequence,packing_list=None):
+    """ calls the workflow for the packing list """
+    if packing_list is None:
+      packing_list = sequence.get('packing_list')
+    packing_list.portal_workflow.doActionFor(packing_list, transition_name)
+
+  def stepAcceptDecisionSupplyDeliveryPackingList(self, sequence=None, sequence_list=None, **kw):
+    packing_list = sequence.get('supply_delivery_packing_list')
+    self._solveDivergence(packing_list, 'quantity', 'accept')
+
+  def stepAcceptDecisionProducedDeliveryPackingList(self, sequence=None, sequence_list=None, **kw):
+    packing_list = sequence.get('produced_delivery_packing_list')
+    self._solveDivergence(packing_list, 'quantity', 'accept')
+
+  def stepAdoptPrevisionSupplyDeliveryPackingList(self, sequence=None, sequence_list=None, **kw):
+    packing_list = sequence.get('supply_delivery_packing_list')
+    self._solveDivergence(packing_list, 'quantity', 'adopt')
+
+  def stepAdoptPrevisionProducedDeliveryPackingList(self, sequence=None, sequence_list=None, **kw):
+    packing_list = sequence.get('produced_delivery_packing_list')
+    self._solveDivergence(packing_list, 'quantity', 'adopt')
+
+  def stepAdoptPrevisionProducedReport(self, sequence=None, sequence_list=None, **kw):
+    packing_list = sequence.get('produced_report')
+    self._solveDivergence(packing_list, 'quantity', 'adopt')
+
+  def stepAdoptPrevisionConsumedReport(self, sequence=None, sequence_list=None, **kw):
+    packing_list = sequence.get('consumed_report')
+    self._solveDivergence(packing_list, 'quantity', 'adopt')
+
+  def stepSetReadyProducedDeliveryPackingList(self, sequence=None, sequence_list=None, **kw):
+    packing_list = sequence.get('produced_delivery_packing_list')
+    self.modifyPackingListState('set_ready_action', sequence=sequence, packing_list=packing_list)
+    self.assertEquals(packing_list.getSimulationState(), 'ready')
+
+  def stepStartProducedDeliveryPackingList(self, sequence=None, sequence_list=None, **kw):
+    packing_list = sequence.get('produced_delivery_packing_list')
+    self.modifyPackingListState('start_action', sequence=sequence, packing_list=packing_list)
+    self.assertEquals(packing_list.getSimulationState(), 'started')
+
+  def stepStopProducedDeliveryPackingList(self, sequence=None, sequence_list=None, **kw):
+    packing_list = sequence.get('produced_delivery_packing_list')
+    self.modifyPackingListState('stop_action', sequence=sequence, packing_list=packing_list)
+    self.assertEquals(packing_list.getSimulationState(), 'stopped')
+
+  def stepDeliverProducedDeliveryPackingList(self, sequence=None, sequence_list=None, **kw):
+    packing_list = sequence.get('produced_delivery_packing_list')
+    self.modifyPackingListState('deliver_action', sequence=sequence, packing_list=packing_list)
+    self.assertEquals(packing_list.getSimulationState(), 'delivered')
+
+  def stepSetReadySupplyDeliveryPackingList(self, sequence=None, sequence_list=None, **kw):
+    packing_list = sequence.get('supply_delivery_packing_list')
+    self.modifyPackingListState('set_ready_action', sequence=sequence, packing_list=packing_list)
+    self.assertEquals(packing_list.getSimulationState(), 'ready')
+
+  def stepStartSupplyDeliveryPackingList(self, sequence=None, sequence_list=None, **kw):
+    packing_list = sequence.get('supply_delivery_packing_list')
+    self.modifyPackingListState('start_action', sequence=sequence, packing_list=packing_list)
+    self.assertEquals(packing_list.getSimulationState(), 'started')
+
+  def stepStopSupplyDeliveryPackingList(self, sequence=None, sequence_list=None, **kw):
+    packing_list = sequence.get('supply_delivery_packing_list')
+    self.modifyPackingListState('stop_action', sequence=sequence, packing_list=packing_list)
+    self.assertEquals(packing_list.getSimulationState(), 'stopped')
+
+  def stepDeliverSupplyDeliveryPackingList(self, sequence=None, sequence_list=None, **kw):
+    packing_list = sequence.get('supply_delivery_packing_list')
+    self.modifyPackingListState('deliver_action', sequence=sequence, packing_list=packing_list)
+    self.assertEquals(packing_list.getSimulationState(), 'delivered')
+
+  def stepSetReadyProducedReport(self, sequence=None, sequence_list=None, **kw):
+    packing_list = sequence.get('produced_report')
+    self.modifyPackingListState('set_ready_action', sequence=sequence, packing_list=packing_list)
+    self.assertEquals(packing_list.getSimulationState(), 'ready')
+
+  def stepStartProducedReport(self, sequence=None, sequence_list=None, **kw):
+    packing_list = sequence.get('produced_report')
+    self.modifyPackingListState('start_action', sequence=sequence, packing_list=packing_list)
+    self.assertEquals(packing_list.getSimulationState(), 'started')
+
+  def stepStopProducedReport(self, sequence=None, sequence_list=None, **kw):
+    packing_list = sequence.get('produced_report')
+    self.modifyPackingListState('stop_action', sequence=sequence, packing_list=packing_list)
+    self.assertEquals(packing_list.getSimulationState(), 'stopped')
+
+  def stepDeliverProducedReport(self, sequence=None, sequence_list=None, **kw):
+    packing_list = sequence.get('produced_report')
+    self.modifyPackingListState('deliver_action', sequence=sequence, packing_list=packing_list)
+    self.assertEquals(packing_list.getSimulationState(), 'delivered')
+
+  def stepSetReadyConsumedReport(self, sequence=None, sequence_list=None, **kw):
+    packing_list = sequence.get('consumed_report')
+    self.modifyPackingListState('set_ready_action', sequence=sequence, packing_list=packing_list)
+    self.assertEquals(packing_list.getSimulationState(), 'ready')
+
+  def stepStartConsumedReport(self, sequence=None, sequence_list=None, **kw):
+    packing_list = sequence.get('consumed_report')
+    self.modifyPackingListState('start_action', sequence=sequence, packing_list=packing_list)
+    self.assertEquals(packing_list.getSimulationState(), 'started')
+
+  def stepStopConsumedReport(self, sequence=None, sequence_list=None, **kw):
+    packing_list = sequence.get('consumed_report')
+    self.modifyPackingListState('stop_action', sequence=sequence, packing_list=packing_list)
+    self.assertEquals(packing_list.getSimulationState(), 'stopped')
+
+  def stepDeliverConsumedReport(self, sequence=None, sequence_list=None, **kw):
+    packing_list = sequence.get('consumed_report')
+    self.modifyPackingListState('deliver_action', sequence=sequence, packing_list=packing_list)
+    self.assertEquals(packing_list.getSimulationState(), 'delivered')
+
+  def stepDecreaseProducedDeliveryPackingListQuantity(self, sequence=None, sequence_list=None, **kw):
+    packing_list = sequence.get('produced_delivery_packing_list')
+
+    for line in packing_list.getMovementList():
+      line.edit(
+        quantity = line.getQuantity() - 1.0
+      )
+
+  def stepDecreaseSupplyDeliveryPackingListQuantity(self, sequence=None, sequence_list=None, **kw):
+    packing_list = sequence.get('supply_delivery_packing_list')
+
+    for line in packing_list.getMovementList():
+      line.edit(
+        quantity = line.getQuantity() - 1.0
+      )
+
+  def stepCheckSourcingDeliverySimulationDecreasedQuantity(self, sequence=None, \
+                                    sequence_list=None, **kw):
+    """
+    TODO
+    """
+    self.logMessage('TODO')
+
+  def stepCheckSourcingDeliverySimulation(self, sequence=None, \
+                                    sequence_list=None, **kw):
+    """
+      Hardcoded delivery checks
+    """
+    self.stepCheckSourcingSimulation(sequence,sequence_list,**kw)
+
+    produced_movement = sequence.get('produced_movement')
+    operation_movement = sequence.get('operation_movement')
+    component_movement = sequence.get('component_movement')
+    supply_movement = sequence.get('supply_movement')
+    produced_delivery_movement = sequence.get('produced_delivery_movement')
+
+    produced_delivery_packing_list = produced_delivery_movement.getDeliveryValue().getParentValue()
+    supply_delivery_packing_list = supply_movement.getDeliveryValue().getParentValue()
+
+    produced_report = produced_movement.getDeliveryValue().getParentValue()
+
+    operation_report = operation_movement.getDeliveryValue().getParentValue()
+    component_report = component_movement.getDeliveryValue().getParentValue()
+    self.assertEquals(operation_report, component_report)
+    consumed_report = operation_report
+
+    # checks that simulations are same
+    # TODO: resources, quantities, dates, ...
+    self.assertEquals(
+      produced_delivery_movement.getSimulationState(),
+      produced_delivery_packing_list.getSimulationState()
+    )
+
+    self.assertEquals(
+      supply_movement.getSimulationState(),
+      supply_delivery_packing_list.getSimulationState()
+    )
+
+    self.assertEquals(
+      produced_movement.getSimulationState(),
+      produced_report.getSimulationState()
+    )
+
+    self.assertEquals(
+      component_movement.getSimulationState(),
+      consumed_report.getSimulationState()
+    )
+
+    self.assertEquals(
+      operation_movement.getSimulationState(),
+      consumed_report.getSimulationState()
+    )
+
+    sequence.edit(
+      produced_delivery_packing_list = produced_delivery_packing_list,
+      supply_delivery_packing_list = supply_delivery_packing_list,
+      produced_report = produced_report,
+      consumed_report = consumed_report,
+    )
+
+  def stepCheckProducedDeliveryPackingListIsConfirmed(self, sequence=None, \
+                                    sequence_list=None, **kw):
+    packing_list = sequence.get('produced_delivery_packing_list')
+
+    self.assertEquals(
+      'confirmed',
+      packing_list.getSimulationState()
+    )
+
+  def stepCheckProducedDeliveryPackingListIsDelivered(self, sequence=None, \
+                                    sequence_list=None, **kw):
+    packing_list = sequence.get('produced_delivery_packing_list')
+
+    self.assertEquals(
+      'delivered',
+      packing_list.getSimulationState()
+    )
+
+  def stepCheckSupplyDeliveryPackingListIsDelivered(self, sequence=None, \
+                                    sequence_list=None, **kw):
+    packing_list = sequence.get('supply_delivery_packing_list')
+
+    self.assertEquals(
+      'delivered',
+      packing_list.getSimulationState()
+    )
+
+  def stepCheckProducedReportIsDelivered(self, sequence=None, \
+                                    sequence_list=None, **kw):
+    packing_list = sequence.get('produced_report')
+
+    self.assertEquals(
+      'delivered',
+      packing_list.getSimulationState()
+    )
+
+  def stepCheckConsumedReportIsDelivered(self, sequence=None, \
+                                    sequence_list=None, **kw):
+    packing_list = sequence.get('consumed_report')
+
+    self.assertEquals(
+      'delivered',
+      packing_list.getSimulationState()
+    )
+
+  def stepCheckProducedDeliveryPackingListIsSolved(self, sequence=None, \
+                                    sequence_list=None, **kw):
+    packing_list = sequence.get('produced_delivery_packing_list')
+
+    self.assertEquals(
+      'solved',
+      packing_list.getCausalityState()
+    )
+
+  def stepCheckProducedDeliveryPackingListIsDiverged(self, sequence=None, \
+                                    sequence_list=None, **kw):
+    packing_list = sequence.get('produced_delivery_packing_list')
+
+    self.assertEquals(
+      'diverged',
+      packing_list.getCausalityState()
+    )
+
+  def stepCheckProducedDeliveryPackingListIsCalculating(self, sequence=None, \
+                                    sequence_list=None, **kw):
+    packing_list = sequence.get('produced_delivery_packing_list')
+
+    self.assertEquals(
+      'calculating',
+      packing_list.getCausalityState()
+    )
+
+  def stepCheckSupplyDeliveryPackingListIsCalculating(self, sequence=None, \
+                                    sequence_list=None, **kw):
+    packing_list = sequence.get('supply_delivery_packing_list')
+
+    self.assertEquals(
+      'calculating',
+      packing_list.getCausalityState()
+    )
+
+  def stepCheckSupplyDeliveryPackingListIsConfirmed(self, sequence=None, \
+                                    sequence_list=None, **kw):
+    packing_list = sequence.get('supply_delivery_packing_list')
+
+    self.assertEquals(
+      'confirmed',
+      packing_list.getSimulationState()
+    )
+
+  def stepCheckSupplyDeliveryPackingListIsSolved(self, sequence=None, \
+                                    sequence_list=None, **kw):
+    packing_list = sequence.get('supply_delivery_packing_list')
+
+    self.assertEquals(
+      'solved',
+      packing_list.getCausalityState()
+    )
+
+  def stepCheckSupplyDeliveryPackingListIsDiverged(self, sequence=None, \
+                                    sequence_list=None, **kw):
+    packing_list = sequence.get('supply_delivery_packing_list')
+
+    self.assertEquals(
+      'diverged',
+      packing_list.getCausalityState()
+    )
+
+  def stepCheckProducedReportIsConfirmed(self, sequence=None, \
+                                    sequence_list=None, **kw):
+    packing_list = sequence.get('produced_report')
+
+    self.assertEquals(
+      'confirmed',
+      packing_list.getSimulationState()
+    )
+
+  def stepCheckProducedReportIsSolved(self, sequence=None, \
+                                    sequence_list=None, **kw):
+    packing_list = sequence.get('produced_report')
+
+    self.assertEquals(
+      'solved',
+      packing_list.getCausalityState()
+    )
+
+  def stepCheckProducedReportIsDiverged(self, sequence=None, \
+                                    sequence_list=None, **kw):
+    packing_list = sequence.get('produced_report')
+
+    self.assertEquals(
+      'diverged',
+      packing_list.getCausalityState()
+    )
+
+  def stepCheckConsumedReportIsConfirmed(self, sequence=None, \
+                                    sequence_list=None, **kw):
+    packing_list = sequence.get('consumed_report')
+
+    self.assertEquals(
+      'confirmed',
+      packing_list.getSimulationState()
+    )
+
+  def stepCheckConsumedReportIsSolved(self, sequence=None, \
+                                    sequence_list=None, **kw):
+    packing_list = sequence.get('consumed_report')
+
+    self.assertEquals(
+      'solved',
+      packing_list.getCausalityState()
+    )
+
+  def stepCheckConsumedReportIsDiverged(self, sequence=None, \
+                                    sequence_list=None, **kw):
+    packing_list = sequence.get('consumed_report')
+
+    self.assertEquals(
+      'diverged',
+      packing_list.getCausalityState()
+    )
+
+class TestProductionDelivery(TestProductionPackingReportListMixin):
+  """Test Production Packing Lists and Reports, mostly based on Production Orders"""
+
+  run_all_test = 1
+
+  def getTitle(self):
+    return "Production Delivery: transformation type %s, resource type %s"%(
+        self.transformation_portal_type,
+        self.resource_portal_type,)
+
+  def test_01_sourcingDelivery(self, quiet=0,
+                                          run=run_all_test):
+    """
+    Test for sourcing type of delivery (Production Report and Production Packing Lists).
+    """
+    # XXX: Need to split to separate test (Luke)
+    if not run: return
+
+    delivery_check_sequence_string = self.SOURCING_ORDER_SEQUENCE + '\
+                      CheckSourcingDeliverySimulation \
+                      \
+                      CheckProducedDeliveryPackingListIsConfirmed \
+                      CheckProducedDeliveryPackingListIsSolved\
+                      \
+                      CheckSupplyDeliveryPackingListIsConfirmed \
+                      CheckSupplyDeliveryPackingListIsSolved\
+                      \
+                      CheckProducedReportIsConfirmed \
+                      CheckProducedReportIsSolved\
+                      \
+                      CheckConsumedReportIsConfirmed \
+                      CheckConsumedReportIsSolved\
+                      \
+                      '
+
+    sequence_list = SequenceList()
+    # Check states of deliveries, just after order confirmation
+    sequence_string = delivery_check_sequence_string
+    sequence_list.addSequenceString(sequence_string)
+
+    # Test when packing list are delivered one by one
+    # Note: I (Luke) know, that below sequence is long
+    #       but I wanted to be sure, that full production
+    #       process is doable.
+    sequence_string = delivery_check_sequence_string + '\
+                      SetReadyProducedDeliveryPackingList \
+                      StartProducedDeliveryPackingList \
+                      StopProducedDeliveryPackingList \
+                      DeliverProducedDeliveryPackingList \
+                      Tic \
+                      \
+                      CheckSourcingDeliverySimulation \
+                      \
+                      CheckProducedDeliveryPackingListIsDelivered \
+                      CheckProducedDeliveryPackingListIsSolved\
+                      \
+                      CheckSupplyDeliveryPackingListIsConfirmed \
+                      CheckSupplyDeliveryPackingListIsSolved\
+                      \
+                      CheckProducedReportIsConfirmed \
+                      CheckProducedReportIsSolved\
+                      \
+                      CheckConsumedReportIsConfirmed \
+                      CheckConsumedReportIsSolved\
+                      \
+                      SetReadySupplyDeliveryPackingList \
+                      StartSupplyDeliveryPackingList \
+                      StopSupplyDeliveryPackingList \
+                      DeliverSupplyDeliveryPackingList \
+                      Tic \
+                      \
+                      CheckSourcingDeliverySimulation \
+                      \
+                      CheckProducedDeliveryPackingListIsDelivered \
+                      CheckProducedDeliveryPackingListIsSolved\
+                      \
+                      CheckSupplyDeliveryPackingListIsDelivered \
+                      CheckSupplyDeliveryPackingListIsSolved\
+                      \
+                      CheckProducedReportIsConfirmed \
+                      CheckProducedReportIsSolved\
+                      \
+                      CheckConsumedReportIsConfirmed \
+                      CheckConsumedReportIsSolved\
+                      \
+                      SetReadyProducedReport \
+                      StartProducedReport \
+                      StopProducedReport \
+                      DeliverProducedReport \
+                      Tic \
+                      \
+                      CheckSourcingDeliverySimulation \
+                      \
+                      CheckProducedDeliveryPackingListIsDelivered \
+                      CheckProducedDeliveryPackingListIsSolved\
+                      \
+                      CheckSupplyDeliveryPackingListIsDelivered \
+                      CheckSupplyDeliveryPackingListIsSolved\
+                      \
+                      CheckProducedReportIsDelivered \
+                      CheckProducedReportIsSolved\
+                      \
+                      CheckConsumedReportIsConfirmed \
+                      CheckConsumedReportIsSolved\
+                      \
+                      SetReadyConsumedReport \
+                      StartConsumedReport \
+                      StopConsumedReport \
+                      DeliverConsumedReport \
+                      Tic \
+                      \
+                      CheckSourcingDeliverySimulation \
+                      \
+                      CheckProducedDeliveryPackingListIsDelivered \
+                      CheckProducedDeliveryPackingListIsSolved\
+                      \
+                      CheckSupplyDeliveryPackingListIsDelivered \
+                      CheckSupplyDeliveryPackingListIsSolved\
+                      \
+                      CheckProducedReportIsDelivered \
+                      CheckProducedReportIsSolved\
+                      \
+                      CheckConsumedReportIsDelivered \
+                      CheckConsumedReportIsSolved\
+                      \
+                      '
+    sequence_list.addSequenceString(sequence_string)
+
+    # Check a case, when Produced Delivery Packing List is diverged
+    # then accept this decision, next deliver it, then adopt prevision
+    # on rest of documents and deliver them - do it one by one
+    sequence_string = delivery_check_sequence_string + '\
+                      DecreaseProducedDeliveryPackingListQuantity \
+                      \
+                      CheckProducedDeliveryPackingListIsCalculating \
+                      Tic \
+                      CheckProducedDeliveryPackingListIsDiverged \
+                      AcceptDecisionProducedDeliveryPackingList \
+                      Tic \
+                      CheckProducedDeliveryPackingListIsSolved \
+                      CheckSourcingDeliverySimulationDecreasedQuantity \
+                      \
+                      CheckSupplyDeliveryPackingListIsConfirmed \
+                      CheckSupplyDeliveryPackingListIsDiverged\
+                      \
+                      CheckProducedReportIsConfirmed \
+                      CheckProducedReportIsDiverged\
+                      \
+                      CheckConsumedReportIsConfirmed \
+                      CheckConsumedReportIsDiverged\
+                      \
+                      SetReadyProducedDeliveryPackingList \
+                      StartProducedDeliveryPackingList \
+                      StopProducedDeliveryPackingList \
+                      DeliverProducedDeliveryPackingList \
+                      Tic \
+                      \
+                      CheckSourcingDeliverySimulationDecreasedQuantity \
+                      \
+                      CheckProducedDeliveryPackingListIsDelivered \
+                      CheckProducedDeliveryPackingListIsSolved\
+                      \
+                      CheckSupplyDeliveryPackingListIsConfirmed \
+                      CheckSupplyDeliveryPackingListIsDiverged\
+                      \
+                      CheckProducedReportIsConfirmed \
+                      CheckProducedReportIsDiverged\
+                      \
+                      CheckConsumedReportIsConfirmed \
+                      CheckConsumedReportIsDiverged\
+                      \
+                      AdoptPrevisionSupplyDeliveryPackingList \
+                      Tic \
+                      CheckSupplyDeliveryPackingListIsSolved \
+                      \
+                      CheckProducedReportIsConfirmed \
+                      CheckProducedReportIsDiverged\
+                      \
+                      CheckConsumedReportIsConfirmed \
+                      CheckConsumedReportIsDiverged\
+                      \
+                      SetReadySupplyDeliveryPackingList \
+                      StartSupplyDeliveryPackingList \
+                      StopSupplyDeliveryPackingList \
+                      DeliverSupplyDeliveryPackingList \
+                      Tic \
+                      \
+                      CheckSourcingDeliverySimulationDecreasedQuantity \
+                      \
+                      CheckProducedDeliveryPackingListIsDelivered \
+                      CheckProducedDeliveryPackingListIsSolved\
+                      \
+                      CheckSupplyDeliveryPackingListIsDelivered \
+                      CheckSupplyDeliveryPackingListIsSolved\
+                      \
+                      CheckProducedReportIsConfirmed \
+                      CheckProducedReportIsDiverged\
+                      \
+                      CheckConsumedReportIsConfirmed \
+                      CheckConsumedReportIsDiverged\
+                      \
+                      AdoptPrevisionProducedReport \
+                      Tic \
+                      CheckProducedReportIsSolved \
+                      \
+                      CheckConsumedReportIsConfirmed \
+                      CheckConsumedReportIsDiverged\
+                      \
+                      SetReadyProducedReport \
+                      StartProducedReport \
+                      StopProducedReport \
+                      DeliverProducedReport \
+                      Tic \
+                      \
+                      CheckSourcingDeliverySimulationDecreasedQuantity \
+                      \
+                      CheckProducedDeliveryPackingListIsDelivered \
+                      CheckProducedDeliveryPackingListIsSolved\
+                      \
+                      CheckSupplyDeliveryPackingListIsDelivered \
+                      CheckSupplyDeliveryPackingListIsSolved \
+                      \
+                      CheckProducedReportIsDelivered \
+                      CheckProducedReportIsSolved\
+                      \
+                      CheckConsumedReportIsConfirmed \
+                      CheckConsumedReportIsDiverged\
+                      \
+                      AdoptPrevisionConsumedReport \
+                      Tic \
+                      CheckProducedReportIsSolved \
+                      \
+                      SetReadyConsumedReport \
+                      StartConsumedReport \
+                      StopConsumedReport \
+                      DeliverConsumedReport \
+                      Tic \
+                      \
+                      CheckSourcingDeliverySimulationDecreasedQuantity \
+                      \
+                      CheckProducedDeliveryPackingListIsDelivered \
+                      CheckProducedDeliveryPackingListIsSolved\
+                      \
+                      CheckSupplyDeliveryPackingListIsDelivered \
+                      CheckSupplyDeliveryPackingListIsSolved\
+                      \
+                      CheckProducedReportIsDelivered \
+                      CheckProducedReportIsSolved\
+                      \
+                      CheckConsumedReportIsDelivered \
+                      CheckConsumedReportIsSolved\
+                      \
+                      '
+    sequence_list.addSequenceString(sequence_string)
+
+    # Check a case, when Consumed Delivery Packing List is diverged
+    # then accept this decision, next deliver it, then adopt prevision
+    # on rest of documents and deliver them - do it one by one
+    sequence_string = delivery_check_sequence_string + '\
+                      DecreaseSupplyDeliveryPackingListQuantity \
+                      \
+                      CheckSupplyDeliveryPackingListIsCalculating \
+                      Tic \
+                      CheckSupplyDeliveryPackingListIsDiverged \
+                      AcceptDecisionSupplyDeliveryPackingList \
+                      Tic \
+                      CheckSupplyDeliveryPackingListIsSolved \
+                      CheckSourcingDeliverySimulationDecreasedQuantity \
+                      \
+                      CheckProducedDeliveryPackingListIsConfirmed \
+                      CheckProducedDeliveryPackingListIsDiverged\
+                      \
+                      CheckProducedReportIsConfirmed \
+                      CheckProducedReportIsSolved \
+                      \
+                      CheckConsumedReportIsConfirmed \
+                      CheckConsumedReportIsDiverged\
+                      \
+                      SetReadySupplyDeliveryPackingList \
+                      StartSupplyDeliveryPackingList \
+                      StopSupplyDeliveryPackingList \
+                      DeliverSupplyDeliveryPackingList \
+                      Tic \
+                      \
+                      CheckSourcingDeliverySimulationDecreasedQuantity \
+                      \
+                      CheckSupplyDeliveryPackingListIsDelivered \
+                      CheckSupplyDeliveryPackingListIsSolved\
+                      \
+                      CheckProducedDeliveryPackingListIsConfirmed \
+                      CheckProducedDeliveryPackingListIsDiverged\
+                      \
+                      CheckProducedReportIsConfirmed \
+                      CheckProducedReportIsSolved\
+                      \
+                      CheckConsumedReportIsConfirmed \
+                      CheckConsumedReportIsDiverged\
+                      \
+                      AdoptPrevisionProducedDeliveryPackingList \
+                      Tic \
+                      CheckProducedDeliveryPackingListIsSolved \
+                      \
+                      CheckProducedReportIsConfirmed \
+                      CheckProducedReportIsDiverged\
+                      \
+                      CheckConsumedReportIsConfirmed \
+                      CheckConsumedReportIsDiverged\
+                      \
+                      SetReadyProducedDeliveryPackingList \
+                      StartProducedDeliveryPackingList \
+                      StopProducedDeliveryPackingList \
+                      DeliverProducedDeliveryPackingList \
+                      Tic \
+                      \
+                      CheckSourcingDeliverySimulationDecreasedQuantity \
+                      \
+                      CheckProducedDeliveryPackingListIsDelivered \
+                      CheckProducedDeliveryPackingListIsSolved\
+                      \
+                      CheckSupplyDeliveryPackingListIsDelivered \
+                      CheckSupplyDeliveryPackingListIsSolved\
+                      \
+                      CheckProducedReportIsConfirmed \
+                      CheckProducedReportIsDiverged\
+                      \
+                      CheckConsumedReportIsConfirmed \
+                      CheckConsumedReportIsDiverged\
+                      \
+                      AdoptPrevisionProducedReport \
+                      Tic \
+                      CheckProducedReportIsSolved \
+                      \
+                      CheckConsumedReportIsConfirmed \
+                      CheckConsumedReportIsDiverged\
+                      \
+                      SetReadyProducedReport \
+                      StartProducedReport \
+                      StopProducedReport \
+                      DeliverProducedReport \
+                      Tic \
+                      \
+                      CheckSourcingDeliverySimulationDecreasedQuantity \
+                      \
+                      CheckProducedDeliveryPackingListIsDelivered \
+                      CheckProducedDeliveryPackingListIsSolved\
+                      \
+                      CheckSupplyDeliveryPackingListIsDelivered \
+                      CheckSupplyDeliveryPackingListIsSolved \
+                      \
+                      CheckProducedReportIsDelivered \
+                      CheckProducedReportIsSolved\
+                      \
+                      CheckConsumedReportIsConfirmed \
+                      CheckConsumedReportIsDiverged\
+                      \
+                      AdoptPrevisionConsumedReport \
+                      Tic \
+                      CheckProducedReportIsSolved \
+                      \
+                      SetReadyConsumedReport \
+                      StartConsumedReport \
+                      StopConsumedReport \
+                      DeliverConsumedReport \
+                      Tic \
+                      \
+                      CheckSourcingDeliverySimulationDecreasedQuantity \
+                      \
+                      CheckProducedDeliveryPackingListIsDelivered \
+                      CheckProducedDeliveryPackingListIsSolved\
+                      \
+                      CheckSupplyDeliveryPackingListIsDelivered \
+                      CheckSupplyDeliveryPackingListIsSolved\
+                      \
+                      CheckProducedReportIsDelivered \
+                      CheckProducedReportIsSolved\
+                      \
+                      CheckConsumedReportIsDelivered \
+                      CheckConsumedReportIsSolved\
+                      \
+                      '
+    sequence_list.addSequenceString(sequence_string)
+
+    sequence_list.play(self)
+
+def test_suite():
+  suite = unittest.TestSuite()
+  suite.addTest(unittest.makeSuite(TestProductionDelivery))
+  return suite
-- 
2.30.9