-
-
Notifications
You must be signed in to change notification settings - Fork 824
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
dev/core#193: Ensure that tax amount is calculated when checking for order API line items #12584
Conversation
(Standard links)
|
@omarabuhussein code style CI failure |
…order API line items
Thanks for this very needed PR |
@JoeMurray @monishdeb Did you get a chance to review this? |
@@ -5008,6 +5011,10 @@ public static function checkLineItems(&$params) { | |||
$item['financial_type_id'] = $params['financial_type_id']; | |||
} | |||
$lineItemAmount += $item['line_total']; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Or 1 line change:
$lineItemAmount += ($item['line_total'] + CRM_Utils_Array::value('tax_amount', $item, 0.00));
@@ -5022,9 +5029,11 @@ public static function checkLineItems(&$params) { | |||
} | |||
|
|||
if (!CRM_Utils_Money::equals($totalAmount, $lineItemAmount, $currency)) { | |||
throw new CRM_Contribute_Exception_CheckLineItemsException(); | |||
return FALSE; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@omarabuhussein @mattwire earlier the intent might be to have native exception handler for line-item errors. But then if I go with the change it is doing the same thing but old code throw native exception instead of API exception although it is used only in order.create api. So I want to know more why do you think we should get rid of CRM_Contribute_Exception_CheckLineItemsException?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think there was an older PR where we discussed this. I didn't really like the return value of this function being changed but I could see why @omarabuhussein wanted to - it makes the function easier to test. But if there is a reason why we should keep the exception then it should stay.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Can't testing convenience be solved just by handling the exception in the test? Nuanced exceptions is a pattern we have been increasing not decreasing.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@eileenmcnaughton but that's does not solve how we can write 'positive' tests for this method : #12372 (comment)
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@omarabuhussein well if negative is an exception then positive is no exception
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
yeah I realize that, it is just I don't like testing for "no exception thrown", something feels wrong about it to me. But if everyone insist to keep the exception (as it seem the case here) then I guess I have no other option.
@omarabuhussein I think you need to retain the CRM_Contribute_Exception_CheckLineItemsException and instead of just calling the checkLineitems() you should use the order.create API in a new unit test (in tests//phpunit/api/v3/OrderTest.php) with paramaters which should trigger the exception error and assert the try-catch the error message. |
thanks @monishdeb for the review, really appreciate it.
But that means I will not test the method in isolation which means that this is a not a unit test anymore I left more notes about why I did this here : #12372 (comment) let me know what do u think when u have the chance. |
@omarabuhussein "But that means I will not test the method in isolation which means that this is a not a unit test anymore" This is true - what we refer to as unit tests are not unit tests from a purists point of view. However, we prioritise testing end to end api functions as those are out main integration points so it's kinda more useful to test Order api in e2e than to honour the concept of unit testing |
It's also worth noting we only support people interacting via the api - ie we don't support people calling checkLineitems from their own extension -that function could change over time |
I am aware of your view regarding testing @eileenmcnaughton , it is just when I see a chance to isolate a test then I will do it as I did here. But fine then I will bring the exception back and replace the tests with tests around the order API. |
To keep the conversation clean and avoid them being hidden from doing a rebase, I am closing this PR and opening this instead : #13091 the new PR keep the exception and test the Order API instead. |
The original PR can be found here : #12372
Overview
When creating an Order using Order API a check is done to compare Contribution's total_amount against the sum of line item's line_total's. If Contribution total amount and Line Items' total are not equal, Order creation will fail.
Before
As we know:
The line item line_total do not include any tax. Tax will be recorded separately in line item tax_amount field.
The contribution total_amount do include tax. A separate contribution tax_amount field also records the amount of tax.
Since the validation only compares the sum of line_totals with contribution total_amount, whenever there is tax, the validation will fail.
For illustration consider following data set that should create 1 contribution with 2 line items for memberships.
Currently Calling the Order API to create Order with the above data results with "Line item total doesn't match with total amount". This is because total_amount (22.0) <> sum of line_totals (18.33)
After
The Line Items check now consider tax_amounts of line_items and order API works fine with the parameters above.
Other Notes
The checkLineItems() method is changed to return True on the success of the validation or False on its failure instead of throwing an exception,