Skip to content

Commit

Permalink
dev/financial#40 add missing financial item when altering a radio amount
Browse files Browse the repository at this point in the history
  • Loading branch information
eileenmcnaughton committed Jul 27, 2019
1 parent 4172cca commit 7fb3b79
Show file tree
Hide file tree
Showing 2 changed files with 32 additions and 23 deletions.
38 changes: 19 additions & 19 deletions CRM/Price/BAO/LineItem.php
Original file line number Diff line number Diff line change
Expand Up @@ -769,21 +769,18 @@ public static function changeFeeSelections(
]);
unset($updateFinancialItemInfoValues['financialTrxn']);
}
elseif (!empty($updateFinancialItemInfoValues['link-financial-trxn']) && $newFinancialItem->amount != 0) {
elseif ($trxn && $newFinancialItem->amount != 0) {
civicrm_api3('EntityFinancialTrxn', 'create', [
'entity_id' => $newFinancialItem->id,
'entity_table' => 'civicrm_financial_item',
'financial_trxn_id' => $trxn->id,
'amount' => $newFinancialItem->amount,
]);
unset($updateFinancialItemInfoValues['link-financial-trxn']);
}
}
}

// @todo - it may be that trxn_id is always empty - flush out scenarios. Add tests.
$trxnId = !empty($trxn->id) ? ['id' => $trxn->id] : [];
$lineItemObj->addFinancialItemsOnLineItemsChange(array_merge($requiredChanges['line_items_to_add'], $requiredChanges['line_items_to_resurrect']), $entityID, $entityTable, $contributionId, $trxnId);
$lineItemObj->addFinancialItemsOnLineItemsChange(array_merge($requiredChanges['line_items_to_add'], $requiredChanges['line_items_to_resurrect']), $entityID, $entityTable, $contributionId, $trxn->id ?? NULL);

// update participant fee_amount column
$lineItemObj->updateEntityRecordOnChangeFeeSelection($params, $entityID, $entity);
Expand Down Expand Up @@ -842,8 +839,6 @@ protected function getAdjustedFinancialItemsToRecord($entityID, $entityTable, $c
if ($amountChangeOnTextLineItem !== (float) 0) {
// calculate the amount difference, considered as financial item amount
$updateFinancialItemInfoValues['amount'] = $amountChangeOnTextLineItem;
// add a flag, later used to link financial trxn and this new financial item
$updateFinancialItemInfoValues['link-financial-trxn'] = TRUE;
if ($previousLineItems[$updateFinancialItemInfoValues['entity_id']]['tax_amount']) {
$updateFinancialItemInfoValues['tax']['amount'] = $lineItemsToUpdate[$updateFinancialItemInfoValues['entity_id']]['tax_amount'] - $previousLineItems[$updateFinancialItemInfoValues['entity_id']]['tax_amount'];
$updateFinancialItemInfoValues['tax']['description'] = $this->getSalesTaxTerm();
Expand Down Expand Up @@ -1033,21 +1028,33 @@ protected function addLineItemOnChangeFeeSelection(
* @param int $entityID
* @param string $entityTable
* @param int $contributionID
* @param bool $isCreateAdditionalFinancialTrxn
* @param bool $trxnID
* Is there a change to the total balance requiring additional transactions to be created.
*/
protected function addFinancialItemsOnLineItemsChange($lineItemsToAdd, $entityID, $entityTable, $contributionID, $isCreateAdditionalFinancialTrxn) {
protected function addFinancialItemsOnLineItemsChange($lineItemsToAdd, $entityID, $entityTable, $contributionID, $trxnID) {
$updatedContribution = new CRM_Contribute_BAO_Contribution();
$updatedContribution->id = $contributionID;
$updatedContribution->find(TRUE);
$trxnArray = $trxnID ? ['id' => $trxnID] : NULL;

foreach ($lineItemsToAdd as $priceFieldValueID => $lineParams) {
$lineParams = array_merge($lineParams, [
'entity_table' => $entityTable,
'entity_id' => $entityID,
'contribution_id' => $contributionID,
]);
$this->addFinancialItemsOnLineItemChange($isCreateAdditionalFinancialTrxn, $lineParams, $updatedContribution);
$confusingTransactionID = $this->addFinancialItemsOnLineItemChange($trxnID, $lineParams, $updatedContribution);
if ($confusingTransactionID) {
$trxnArray['id'] = $confusingTransactionID;
CRM_Core_Error::deprecatedFunctionWarning('how did this happen?');
}
$lineObj = CRM_Price_BAO_LineItem::retrieve($lineParams);
// insert financial items
// ensure entity_financial_trxn table has a linking of it.
CRM_Financial_BAO_FinancialItem::add($lineObj, $updatedContribution, NULL, $trxnArray);
if (isset($lineObj->tax_amount)) {
CRM_Financial_BAO_FinancialItem::add($lineObj, $updatedContribution, TRUE, $trxnArray);
}
}
}

Expand Down Expand Up @@ -1253,7 +1260,7 @@ protected function addFinancialItemsOnLineItemChange($isCreateAdditionalFinancia
$tempFinancialTrxnID = NULL;
// don't add financial item for cancelled line item
if ($lineParams['qty'] == 0) {
return;
return NULL;
}
elseif ($isCreateAdditionalFinancialTrxn) {
// This routine & the return below is super uncomfortable.
Expand All @@ -1279,16 +1286,9 @@ protected function addFinancialItemsOnLineItemChange($isCreateAdditionalFinancia
'currency' => $updatedContribution->currency,
];
$adjustedTrxn = CRM_Core_BAO_FinancialTrxn::create($adjustedTrxnValues);
$tempFinancialTrxnID = ['id' => $adjustedTrxn->id];
return $adjustedTrxn->id;
}
}
$lineObj = CRM_Price_BAO_LineItem::retrieve($lineParams);
// insert financial items
// ensure entity_financial_trxn table has a linking of it.
CRM_Financial_BAO_FinancialItem::add($lineObj, $updatedContribution, NULL, $tempFinancialTrxnID);
if (isset($lineObj->tax_amount)) {
CRM_Financial_BAO_FinancialItem::add($lineObj, $updatedContribution, TRUE, $tempFinancialTrxnID);
}
}

/**
Expand Down
17 changes: 13 additions & 4 deletions tests/phpunit/CRM/Event/BAO/ChangeFeeSelectionTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -546,28 +546,36 @@ public function testPartialPaymentEntries() {
$priceSetParams['price_' . $this->priceSetFieldID] = $this->veryExpensiveFeeValueID;
$lineItem = CRM_Price_BAO_LineItem::getLineItems($this->participantID, 'participant');
CRM_Price_BAO_LineItem::changeFeeSelections($priceSetParams, $this->_participantId, 'participant', $this->_contributionId, $this->_feeBlock, $lineItem);
$actualResults = $this->callAPISuccess('EntityFinancialTrxn', 'get', ['sequential' => 1, 'entity_table' => 'civicrm_financial_item', 'return' => ['amount', 'entity_id']])['values'];
$actualResults = $this->callAPISuccess('EntityFinancialTrxn', 'get', ['sequential' => 1, 'entity_table' => 'civicrm_financial_item'])['values'];
$expectedResults = [
[
'id' => 2,
'amount' => 100.00,
'amount' => 100.0,
'entity_id' => 1,
'financial_trxn_id' => 1,
'entity_table' => 'civicrm_financial_item',
],
[
'id' => 4,
'amount' => -100.00, // ensure that reverse entry is entered in the EntityFinancialTrxn table on fee change to greater amount
// ensure that reverse entry is entered in the EntityFinancialTrxn table on fee change to greater amount
'amount' => -100.0,
'entity_id' => 2,
'financial_trxn_id' => 2,
'entity_table' => 'civicrm_financial_item',
],
[
'id' => 5,
'amount' => 120.00,
'entity_id' => 3,
'financial_trxn_id' => 2,
'entity_table' => 'civicrm_financial_item',
],
];
foreach ($expectedResults as $key => $expectedResult) {
$this->checkArrayEquals($expectedResult, $actualResults[$key]);
}
}

/**
* dev-financial-40: Test that refund payment entries in entity-financial-trxn table to ensure that reverse transaction is entered on fee change to lesser amount
*/
Expand All @@ -585,7 +593,8 @@ public function testRefundPaymentEntries() {
],
[
'id' => 4,
'amount' => -100.00, // ensure that reverse entry is entered in the EntityFinancialTrxn table
// ensure that reverse entry is entered in the EntityFinancialTrxn table
'amount' => -100.00,
'entity_id' => 2,
],
[
Expand Down

0 comments on commit 7fb3b79

Please sign in to comment.