-
-
Notifications
You must be signed in to change notification settings - Fork 35
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
[17.0][MIG] repair_picking_after_done: Migration to 17.0 #65
[17.0][MIG] repair_picking_after_done: Migration to 17.0 #65
Conversation
7c9e0f5
to
804879f
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.
LGTM, tested in runboat
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.
LGTM, code review
…ocation directly from repaire order
… to be able to create transfers if a repair is duplicated
804879f
to
3672843
Compare
Hi @LoisRForgeFlow, sorry to ping directly. Could you please review this module and the dependency (#63) when you have a moment? Thank you! |
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.
LGTM
/ocabot migration repair_picking_after_done |
@ppyczko Dependency merged, you can remove the requirements commit |
3672843
to
d2d752d
Compare
Done! Thank you @LoisRForgeFlow |
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.
Overall looks good! One detail that I realized while testing (probably hapening in previous versions) is that when creating a backorder of one of these repair after done transfers, the backorder is not linked to the reapair order and you cannot find it navigating with the smart button.
This PR has the |
Thank you for taking the time to review this module and for your feedback @LoisRForgeFlow! While reviewing your input, I found out that these backorders are not only not linked to the repair order, but they actually aren’t created at all. This is due to this piece of code in core of Odoo:
This behavior seems intentional and aligns with the idea that, once a repair is marked as done, the items are fully ready and available, not partially available. In my view, this makes sense -- backorders after a completed repair could cause confusion. In my opinion, when a repair is completed, it implies that all items in that order are ready to be returned to the customer. A backorder might imply partial availability, which doesn’t seem to fit with the concept of a finished repair. That said, I may be missing some use case or context here, so I’d really appreciate any thoughts or perspectives you might have on this. If there’s a scenario where backorders after a repair could add value, I’d love to understand it better. After all, if you think we do need backorders, it would be as easy as overriding this _split method, and we could make that adjustment quickly. |
d2d752d
to
9a3d37e
Compare
@ppyczko Thanks for investigating and for the detailed feedback. For me, Odoo has decided that they do not want to handle backorders of repairs, I am not against that as long as the code is consistent with that idea and it seems so, as you pointed out in the code. That part is fine, but here we are talking about an additional operation/transfer that takes places just after the repair is done, this operation is not anything else than an internal operation or a delivery like any other, it is just linked to the repair order for traceability purposes. Therefore from my perspective, this post-repair operation should allow backorders as any other, whatever the reason, I don't see why we should not allow that. In short, I would keep restriction to split stock moves of the repair order and I would allow split in this related post-repair operations. Does this make sense to you? |
069ae37
to
6bc2c3b
Compare
Thank you for the detailed explanation @LoisRForgeFlow. I hadn't considered it from that angle, and I agree with your resolution. I’ve implemented the change, and backorders can now be created once a repair order is completed. Due to the dependency chain, I wasn't able to use super() to call the split() method, which would have been the cleanest approach. This is because, when calling super() from the repair_picking_after_done module, the split() method in the core Repair module is triggered (instead of the one in the core Stock module), preventing any stock moves related to a repair order from being split, regardless of whether the repair is completed. As a result, I had to override the split() method in the Stock module directly and add the repair validation at the start of the method. I’ve documented this in the method for future reference. If you have any suggestions for improvement, I’d greatly appreciate your advice. Otherwise, the module is ready for testing again. Thank you! |
…ing remaining quantities in repair orders
6bc2c3b
to
d2023e3
Compare
It's ready to merge @LoisRForgeFlow ? When it merge we will do an IMP to this module |
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.
Thanks for the proposal, I think we can do it a bit cleaner, see below my proposals:
…ked to completed repair orders
d2023e3
to
c5f40d9
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.
@ppyczko I looks good now!
Thanks for attending all the comments 👍
/ocabot merge nobump |
Hey, thanks for contributing! Proceeding to merge this for you. |
This PR has the |
Congratulations, your PR was merged at cd8301a. Thanks a lot for contributing to OCA. ❤️ |
Module migrated to version 17.0
cc https://github.com/APSL 162593
@miquelalzanillas @lbarry-apsl @mpascuall @peluko00 @javierobcn @BernatObrador please review
Depends on:
An [IMP] has been added to prevent the creation of transfers exceeding remaining quantities in repair orders.