Skip to main content
Solved

Data Corruption Error Related to SOOrder.openLineCntr During PO Receipt Processing in Customization

  • 2 September 2024
  • 5 replies
  • 117 views

Forum|alt.badge.img+1

 

I declared a method in the SOOrderEntry graph as follows.

public void UpdateSalesOrder(PXCache cache, PXFieldUpdatedEventArgs e, string blanketOrderNumber = null)
{
    PXTrace.WriteError("Field_updated");

    // Tenant selection
    if (PX.Data.Update.PXInstanceHelper.CurrentCompany == 3)
    {
        // Determine the appropriate SOOrder row
        SOOrder row = null;

        if (!string.IsNullOrEmpty(blanketOrderNumber))
        {
            // Fetch the specific SOOrder record matching the blanketOrderNumber
            row = PXSelect<SOOrder,
                           Where<SOOrder.orderType, Equal<Required<SOOrder.orderType>>,
                                 And<SOOrder.orderNbr, Equal<Required<SOOrder.orderNbr>>>>>
                           .Select(cache.Graph, "BL", blanketOrderNumber);

            if (row == null)
            {
                PXTrace.WriteError($"No SOOrder found with OrderNbr: {blanketOrderNumber} and OrderType: BL.");
                return;
            }
            else
           {
                PXTrace.WriteInformation(row.OrderNbr);

                SOLine line = SOLines.SelectSingle(row.OrderNbr);  
                 if (line == null)
                {
                    PXTrace.WriteError("SOLine is null.");
                }
                else
                {
                    PXTrace.WriteInformation($"SOLine is not null. Open Qty: {line.OpenQty}, Shipped Qty: {line.ShippedQty}");
                }                                                          
            }                                                              
        }
        else
        {
            // If no blanket order number is provided, use the row from the event args
            row = (SOOrder)e.Row;
            if (row == null)
            {
                PXTrace.WriteError("SOOrder row is null.");
                return;
            }

            // Ensure we're working with a blanket order
            if (row.OrderType != "BL")
            {
                PXTrace.WriteError("OrderType is not 'BL'. Exiting method.");
                return;
            }
        }

     }

 } 

Then, I attempted to call this method from the POReceiptEntry graph as shown below, when the POReceipt's status changed to 'Released'.

 protected void POReceipt_Status_FieldUpdated(PXCache cache, PXFieldUpdatedEventArgs e)
{
    PXTrace.WriteInformation("Entering POReceipt_Status_FieldUpdated");

    try
    {
        var row = (POReceipt)e.Row;
        if (row == null)
        {
            PXTrace.WriteError("POReceipt row is null.");
            return;
        }

        PXTrace.WriteInformation($"POReceipt.Status: {row.Status}");
        if (row.Status != "R")
        {
            PXTrace.WriteInformation("POReceipt.Status is not 'R'. Exiting method.");
            return;
        }

        // Log key variable values
        PXTrace.WriteInformation($"Fetching POReceiptLine for ReceiptNbr: {row.ReceiptNbr}");
        POReceiptLine poReceiptLine = POReceiptLineView.SelectSingle("RT", row.ReceiptNbr);
        if (poReceiptLine == null)
        {
            PXTrace.WriteError("No matching POReceiptLine found.");
        }
        else
        {
            PXTrace.WriteInformation($"Found POReceiptLine: ReceiptType={poReceiptLine.ReceiptType}, LineNbr={poReceiptLine.LineNbr}");
        }

        PXTrace.WriteInformation($"Fetching POOrder for POType: {poReceiptLine?.POType}, PONbr: {poReceiptLine?.PONbr}");
        POOrder poOrder = POOrder.PK.Find(Base, poReceiptLine?.POType, poReceiptLine?.PONbr);
        if (poOrder == null)
        {
            PXTrace.WriteError("No matching POOrder found.");
        }
        else
        {
            PXTrace.WriteInformation($"Found POOrder: OrderType={poOrder.OrderType}, OrderNbr={poOrder.OrderNbr}");
        }

        PXTrace.WriteInformation($"Fetching SOLine for SOOrderNbr: {poOrder?.SOOrderNbr}");
        SOLine soLine = SOLineView.SelectSingle("SO", poOrder?.SOOrderNbr);
        if (soLine != null && !string.IsNullOrEmpty(soLine.BlanketNbr))
        {
            PXTrace.WriteInformation($"Found SOLine with BlanketNbr: {soLine.BlanketNbr}");

            // Log the transition to the next method
            PXTrace.WriteInformation("Calling UpdateSalesOrder");
            var soOrderEntryGraph = PXGraph.CreateInstance<SOOrderEntry>();
            var soOrderEntryExt = soOrderEntryGraph.GetExtension<SOOrderEntry_Extension>();
            soOrderEntryExt.UpdateSalesOrder(Base.Caches[typeof(SOOrder)], null, soLine?.BlanketNbr);
            PXTrace.WriteInformation("UpdateSalesOrder completed");
        }
        else
        {
            PXTrace.WriteError("No SOLine found or no BlanketNbr present to update.");
        }
    }
    catch (Exception ex)
    {
        PXTrace.WriteError($"Error in POReceipt_Status_FieldUpdated: {ex.Message}");
        PXTrace.WriteError($"StackTrace: {ex.StackTrace}");
        throw; // Re-throw the exception after logging
    }
    finally
    {
        PXTrace.WriteInformation("Exiting POReceipt_Status_FieldUpdated");
    }
}

However, after inserting this custom logic, the POReceipt is not getting released and is showing the following error.”A data corruption state has been detected. You cannot save the changes. Copy the data you have entered and reload the page. Date and Time: 2024-09-02T08:59:44; IncidentID: 7b75179c-407e-4b5c-8987-4356b86ef67e; Name: Aggregate Validation: PX.Objects.SO.SOOrder+openLineCntr. You can view detailed information about the issue on the System Events tab of the System Monitor (SM201530) form.”

Please check the below screenshot of the trace also.

The Trace after clicking the Release button in the POReceipt screen

Could I get any suggestions on how to resolve this issue?

Best answer by malinthawarnakulasooriya08

Hi, sorry for the late reply. All credit goes to Zoltan Febert. Here is the full feedback.”

It looks like you try to share PXCache object between graphs, and I think this cause the issue.

soOrderEntryExt.UpdateSalesOrder(Base.Caches[typeof(SOOrder)], null, soLine?.BlanketNbr);

Base here is POReceiptEntry, you need to use soOrderEntryGraph instead.

soOrderEntryExt.UpdateSalesOrder(soOrderEntryGraph.Caches[typeof(SOOrder)], null, soLine?.BlanketNbr);

” 

 

View original
Did this topic help you find an answer to your question?

5 replies

darylbowman
Captain II
Forum|alt.badge.img+13

Did you miss providing some code or something? Your UpdateSalesOrder method isn’t doing anything.


Forum|alt.badge.img+1

Hi @darylbowman , For testing purposes, I am trying to retrieve the relevant Open and Shipped Quantity values from the associated Blanket Order and print them in the trace for the selected Receipt during the Release process.If this data retrieval is successful, I'm planning to trigger an Update API call within the UpdateSalesOrder method.However, the Receipt is currently not being released with this customization, even though I have used the FieldUpdated event handler.


darylbowman
Captain II
Forum|alt.badge.img+13

I would suggest overriding the Release() action instead of trying to put all of this into a Status field updated event. I think you’re probably fighting with what’s taking place there, although it’s not clear what it’s having a problem with. You aren’t even trying to save anything that I can see.


Forum|alt.badge.img+1

Yes, it's still uncertain. Anyway, I'll try your suggestion and update you here. Thanks.


Forum|alt.badge.img+1

Hi, sorry for the late reply. All credit goes to Zoltan Febert. Here is the full feedback.”

It looks like you try to share PXCache object between graphs, and I think this cause the issue.

soOrderEntryExt.UpdateSalesOrder(Base.Caches[typeof(SOOrder)], null, soLine?.BlanketNbr);

Base here is POReceiptEntry, you need to use soOrderEntryGraph instead.

soOrderEntryExt.UpdateSalesOrder(soOrderEntryGraph.Caches[typeof(SOOrder)], null, soLine?.BlanketNbr);

” 

 


Reply


Cookie policy

We use cookies to enhance and personalize your experience. If you accept you agree to our full cookie policy. Learn more about our cookies.

 
Cookie settings