-
-
Notifications
You must be signed in to change notification settings - Fork 725
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
Ensure shipment gets updated when an order is updated #12954
Ensure shipment gets updated when an order is updated #12954
Conversation
d380a9d
to
58ef10f
Compare
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.
Nice followup!
I wonder if we can do it more efficiently? And I'm unsure about the spec.
|
||
subject.update_or_create(variant, { quantity: 2, max_quantity: 3 }) | ||
end | ||
|
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.
Looks like this tests creating mode, but not updating an existing line item (Which I think is what it should be testing)
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 updated the specs to test both in creating and updating scenario
`Spree::OrderContents#update_or_create` is used to update the cart when on the /shop page. If you start an order and proceed to the "Order summary" step, and then decide to update your order by using the shop link next to the cart, such update wouldn't update the shipment. This result in the order page in the backoffice displaying the wrong data, and more importantly, in the stock not being updated. So now we ensure shipment will be updated, which result in the checkout flow being restarted, thus making sure the shipment is updated.
58ef10f
to
cedf040
Compare
Hi @rioug, Nice catch! Thanks for your detailed steps on how to reproduce and test this PR. Before:
After this PR, and repeating the step, it was possible to observe that:
Looks great! Merging. |
What? Why?
I came across this while looking at #12907
Given an order up to "Order Summary" step, if a customer then update the cart by going back to the shop page via the link next to the cart, the order shipment won't be updated.
It results in :
To fix this, we make sure we delete existing shipment and restart the checkout flow.
Order confirmation started with 2 potatoes test , was updated to 4 potatoes test and 3 potatoes
Admin screen showing only the original items/quantity , 2 potatoes test
Potatoes test stock reduced from 50 to 48, and Potatoes stock stayed at 20
What should we test?
As an enterprise manager:
As a customer
--> the order should have the correct items and quantity
--> the order should have the correct items and quantity
For both scenario, As an enterprise manager
--> The items should all be there and have the correct quantity
--> verify that the stock of the products in the order have been decreased by the correct number
Release notes
Changelog Category (reviewers may add a label for the release notes):
The title of the pull request will be included in the release notes.