Commit 3b1e230c authored by Jérome Perrin's avatar Jérome Perrin

Don't call a useless getPrice on edit(price=x)

Base.edit has this feature of not actually modifying the properties when
the new property value is same as the current one, so when we do
`movement.edit(price=x)`, this will cause an implicit getPrice.

As price lookup is a bit slow, do not lookup price in this case.

/cc @vpelletier @kazuhiko @romain 

/reviewed-on !259
parents bc3b5a25 a78c0126
...@@ -230,8 +230,6 @@ class Movement(XMLObject, Amount, CompositionMixin, AmountGeneratorMixin): ...@@ -230,8 +230,6 @@ class Movement(XMLObject, Amount, CompositionMixin, AmountGeneratorMixin):
if self.isMovingItem(item)] if self.isMovingItem(item)]
# Pricing methods # Pricing methods
# _getPrice is defined in the order / delivery
# Pricing mehod
def _getPrice(self, context): def _getPrice(self, context):
context = self.asContext(context=context, context = self.asContext(context=context,
quantity=self.getConvertedQuantity()) quantity=self.getConvertedQuantity())
...@@ -327,7 +325,7 @@ class Movement(XMLObject, Amount, CompositionMixin, AmountGeneratorMixin): ...@@ -327,7 +325,7 @@ class Movement(XMLObject, Amount, CompositionMixin, AmountGeneratorMixin):
DeprecationWarning) DeprecationWarning)
local_price = self._baseGetPrice() local_price = self._baseGetPrice()
if local_price is None: if local_price is None and evaluate:
# We must find a price for this movement # We must find a price for this movement
local_price = self._getPrice(context=self) local_price = self._getPrice(context=self)
return local_price return local_price
......
...@@ -588,6 +588,19 @@ class TestSaleSupply(TestSupplyMixin, SubcontentReindexingWrapper, ...@@ -588,6 +588,19 @@ class TestSaleSupply(TestSupplyMixin, SubcontentReindexingWrapper,
preference.setPreferredPricingOptimise(False) preference.setPreferredPricingOptimise(False)
self._clearCache() self._clearCache()
def test_getPriceDoesNotLookupPriceDuringEdit(self):
"""Test getPrice does not lookup price during edit.
"""
movement = self._makeRealMovement()
def methodThatShouldNotBeCalled(*args, **kw):
self.fail("price lookup should not happen")
movement.getPriceCalculationOperandDict = methodThatShouldNotBeCalled
movement._getPrice = methodThatShouldNotBeCalled
movement.edit(price=10)
self.assertEqual(10, movement.getPrice())
self.abort()
def _createTwoHundredSupplyLineInASupply(self): def _createTwoHundredSupplyLineInASupply(self):
supply = self._makeSupply( supply = self._makeSupply(
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment