Merge pull request #4 from dsaub/copilot/fix-stock-availability-bug

Fix stale Redis cache causing buyers to see zero stock despite available inventory
This commit is contained in:
Daniel (elordenador)
2026-04-09 12:39:13 +02:00
committed by GitHub
+5
View File
@@ -442,6 +442,8 @@ def _create_stock_reservation_for_cart(request: HttpRequest, cart_items, payment
for item in cart_items for item in cart_items
]) ])
cache.delete_many([f"product_{product_id}" for product_id in product_ids])
return reservation, [] return reservation, []
@@ -592,6 +594,7 @@ def create_order_from_cart(request, payment_method, payment_reference="", shippi
product_row = product_map.get(item.product_id) product_row = product_map.get(item.product_id)
product_row.stock -= item.quantity product_row.stock -= item.quantity
product_row.save(update_fields=["stock"]) product_row.save(update_fields=["stock"])
cache.delete(f"product_{product_row.id}")
cart.items.all().delete() cart.items.all().delete()
@@ -967,6 +970,7 @@ def editar_producto(request: HttpRequest, id: int):
producto.primary_image = primary_image producto.primary_image = primary_image
producto.save() producto.save()
cache.delete(f"product_{producto.id}")
if secondary_images_files: if secondary_images_files:
producto.secondary_images.clear() producto.secondary_images.clear()
@@ -996,6 +1000,7 @@ def borrar_producto(request: HttpRequest, id: int):
producto = get_object_or_404(Product, id=id, creator=request.user) producto = get_object_or_404(Product, id=id, creator=request.user)
nombre = producto.name nombre = producto.name
cache.delete(f"product_{producto.id}")
producto.delete() producto.delete()
messages.success(request, f"Producto '{nombre}' eliminado correctamente.") messages.success(request, f"Producto '{nombre}' eliminado correctamente.")
return redirect("mis_productos") return redirect("mis_productos")