Posting doesn't create costing records for lines, when 1 product has error

Description

Costing. Average PO
Use case - create - document with 3 products. post it (eg. shipment) - document includes 2 products with proper m_costdetail 1 product with issues.
P1. OK - cost calc has no error
P2. OK - cost calc has no error
P3. ERROR in costing calculation << this line prevent to create costing records for P1, P2 well.

SUMMARY: When document has multiple lines-products and one of them has costing error in posting transaction, then transaction is rolled back and no costing records are created.
This error cause products costing calculation sequence has gaps and prevent to calculate properly. This cause eg. error logs in case of shipments in SEVERE LEVEL: org.adempiere.exceptions.AverageCostingNegativeQtyException

SOLUTION/IDEA:
new posting status - costing error. when above scenario happening, then costing records MUST BE created for P1, P2 and not for P3. in this case this new status can be set, and accounting consequence can be created.

REMARK: additionally we recognise the following happens. WHEN posting submitted then new transaction created and start costing methods. when costing cant be calculated then POSTING rolled Back for ALL Products included in transaction. ONLY one solution is we can imagine here - after lot experimenting - SPLIT posting and Costing resp. call 2 methods when costing fall then return back to continue to next costing record product.

Environment

None

Activity

Show:

Heng Sin Low May 9, 2020 at 1:28 AM

To implement this, probably will have to add costing status for each line. The split of posting and costing is very problematic as if there's costing error, you can't be sure that the posting will be correct.

Details

Assignee

Reporter

Components

Affects versions

Priority

Created May 4, 2017 at 10:39 AM
Updated May 9, 2020 at 1:28 AM