diff --git a/product/ERP5/tests/testInvoice.py b/product/ERP5/tests/testInvoice.py index cfaa812b670972ab34a851249540b374944d30f0..fd404cbb5240697c6d87673527cd8f927560fdbd 100644 --- a/product/ERP5/tests/testInvoice.py +++ b/product/ERP5/tests/testInvoice.py @@ -669,6 +669,13 @@ class TestInvoice(TestPackingListMixin, portal_type=self.invoice_line_portal_type): invoice_line.edit(quantity=quantity) + def stepChangeInvoiceStartDate(self, sequence=None, sequence_list=None, **kw): + """ + Change the start_date of the invoice. + """ + invoice = sequence.get('invoice') + invoice.edit(start_date=self.datetime + 15) + def stepCheckInvoiceIsCalculating(self, sequence=None, sequence_list=None, **kw): """ @@ -719,6 +726,14 @@ class TestInvoice(TestPackingListMixin, wf_id='invoice_causality_workflow', start_date=self.datetime + 15, stop_date=self.datetime + 25) + def stepAcceptDecisionInvoice(self, sequence=None, sequence_list=None, + **kw): + """ + accept decision at the invoice level + """ + invoice = sequence.get('invoice') + invoice.portal_workflow.doActionFor(invoice,'accept_decision_action') + def stepCheckInvoiceSplitted(self, sequence=None, sequence_list=None, **kw): """ Test if invoice was splitted @@ -742,9 +757,21 @@ class TestInvoice(TestPackingListMixin, portal_type=self.invoice_line_portal_type): self.assertEquals(1,line.getQuantity()) - - - + def stepCheckInvoiceNotSplitted(self, sequence=None, sequence_list=None, **kw): + """ + Test if invoice was not splitted + """ + packing_list = sequence.get('packing_list') + invoice_list = packing_list.getCausalityRelatedValueList( + portal_type=self.invoice_portal_type) + self.assertEquals(1,len(invoice_list)) + invoice1 = None + for invoice in invoice_list: + if invoice.getUid() == sequence.get('invoice').getUid(): + invoice1 = invoice + for line in invoice1.objectValues( + portal_type=self.invoice_line_portal_type): + self.assertEquals(self.default_quantity, line.getQuantity()) # default sequence for one line of not varianted resource. PACKING_LIST_DEFAULT_SEQUENCE = """ @@ -986,8 +1013,7 @@ class TestInvoice(TestPackingListMixin, stepRebuildAndCheckNothingIsCreated """) - #def test_08_InvoiceDecreaseQuantity(self, quiet=0, run=RUN_ALL_TESTS): - def test_08_InvoiceDecreaseQuantity(self, quiet=0, run=1): + def test_08_InvoiceDecreaseQuantity(self, quiet=0, run=RUN_ALL_TESTS): """Change the quantity of a Invoice Line, check that the packing list is divergent, then split and differ""" @@ -1014,6 +1040,34 @@ class TestInvoice(TestPackingListMixin, """ self.playSequence(sequence) + def test_09_InvoiceChangeStartDate(self, quiet=0, run=RUN_ALL_TESTS): + """Change the start_date of a Invoice Line, + check that the packing list is divergent, + then acceptDecision""" + if not run: return + sequence = self.PACKING_LIST_DEFAULT_SEQUENCE + \ + """ + stepSetReadyPackingList + stepTic + stepStartPackingList + stepCheckInvoicingRule + stepTic + stepCheckInvoiceBuilding + + stepChangeInvoiceStartDate + stepCheckInvoiceIsCalculating + stepAcceptDecisionInvoice + stepTic + stepCheckInvoiceIsSolved + stepCheckInvoiceNotSplitted + stepCheckPackingListIsDivergent + stepCheckPackingListIsDiverged + stepCheckSimulationStartDateUpdated + + stepRebuildAndCheckNothingIsCreated + """ + self.playSequence(sequence) + if __name__ == '__main__': framework() else: