Allow pricing updates when PartPricing object does not yet exist (#4400)

- Previously if the Part did not have a referenced PartPricing object, the schedule_pricing_update method would fail
- Required a PartPricing object to actually exist (i.e. be manually created)
- This patch fixes a logic error which resulted in updating being skipped if a PartPricing instance did not already exist
This commit is contained in:
Oliver 2023-02-24 06:59:24 +11:00 committed by GitHub
parent efb55c720f
commit a28063a59c
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -1687,10 +1687,8 @@ class Part(InvenTreeBarcodeMixin, MetadataMixin, MPTTModel):
Ref: https://github.com/inventree/InvenTree/pull/3986 Ref: https://github.com/inventree/InvenTree/pull/3986
""" """
try: pricing = self.pricing
self.pricing.schedule_for_update() pricing.schedule_for_update()
except (PartPricing.DoesNotExist, IntegrityError):
pass
def get_price_info(self, quantity=1, buy=True, bom=True, internal=False): def get_price_info(self, quantity=1, buy=True, bom=True, internal=False):
"""Return a simplified pricing string for this part. """Return a simplified pricing string for this part.
@ -2264,9 +2262,11 @@ class PartPricing(common.models.MetaMixin):
"""Schedule this pricing to be updated""" """Schedule this pricing to be updated"""
try: try:
self.refresh_from_db() if self.pk:
self.refresh_from_db()
except (PartPricing.DoesNotExist, IntegrityError): except (PartPricing.DoesNotExist, IntegrityError):
# Error thrown if this PartPricing instance has already been removed # Error thrown if this PartPricing instance has already been removed
logger.warning(f"Error refreshing PartPricing instance for part '{self.part}'")
return return
# Ensure that the referenced part still exists in the database # Ensure that the referenced part still exists in the database
@ -2274,6 +2274,7 @@ class PartPricing(common.models.MetaMixin):
p = self.part p = self.part
p.refresh_from_db() p.refresh_from_db()
except IntegrityError: except IntegrityError:
logger.error(f"Could not update PartPricing as Part '{self.part}' does not exist")
return return
if self.scheduled_for_update: if self.scheduled_for_update:
@ -2291,6 +2292,7 @@ class PartPricing(common.models.MetaMixin):
self.save() self.save()
except IntegrityError: except IntegrityError:
# An IntegrityError here likely indicates that the referenced part has already been deleted # An IntegrityError here likely indicates that the referenced part has already been deleted
logger.error(f"Could not save PartPricing for part '{self.part}' to the database")
return return
import part.tasks as part_tasks import part.tasks as part_tasks