[IMP] delivery_purolator: add multi-rating for orders

H10820
This commit is contained in:
Cedric Collins
2022-08-31 23:44:33 -05:00
committed by Jared Kipe
parent d5cf40506e
commit b63d2b0436
4 changed files with 102 additions and 11 deletions

View File

@@ -3,9 +3,10 @@
<data noupdate="1">
<!-- Purolator Delivery Carriers -->
<record id="product_product_purolator_carrier" model="product.product">
<field name="name">Purolator Delivery</field>
<field name="default_code">Delivery_Puro</field>
<!-- Requires working api key for tests to function, not provided -->
<record id="product_product_purolator_express" model="product.product">
<field name="name">Purolator Express</field>
<field name="default_code">Delivery_PurolatorExpress</field>
<field name="type">service</field>
<field name="categ_id" ref="delivery.product_category_deliveries"/>
<field name="sale_ok" eval="False"/>
@@ -13,10 +14,30 @@
<field name="list_price">0.0</field>
<field name="invoice_policy">order</field>
</record>
<record id="purolator_carrier" model="delivery.carrier">
<field name="name">Purolator Test Carrier</field>
<record id="purolator_express" model="delivery.carrier">
<field name="name">Purolator Express Test</field>
<field name="product_id" ref="delivery_purolator.product_product_purolator_carrier"/>
<field name="delivery_type">purolator</field>
<field name="purolator_service_type">PurolatorExpress</field>
<field name="prod_environment" eval="False"/>
</record>
<record id="product_product_purolator_ground" model="product.product">
<field name="name">Purolator Ground</field>
<field name="default_code">Delivery_PurolatorGround</field>
<field name="type">service</field>
<field name="categ_id" ref="delivery.product_category_deliveries"/>
<field name="sale_ok" eval="False"/>
<field name="purchase_ok" eval="False"/>
<field name="list_price">0.0</field>
<field name="invoice_policy">order</field>
</record>
<record id="purolator_ground" model="delivery.carrier">
<field name="name">Purolator Ground Test</field>
<field name="product_id" ref="delivery_purolator.product_product_purolator_carrier"/>
<field name="delivery_type">purolator</field>
<field name="purolator_service_type">PurolatorGround</field>
<field name="prod_environment" eval="False"/>
</record>
</data>

View File

@@ -1,5 +1,7 @@
from odoo import fields, models, _
from .purolator_services import PurolatorClient
import logging
_logger = logging.getLogger(__name__)
PUROLATOR_SERVICES = [
@@ -99,6 +101,7 @@ class ProviderPurolator(models.Model):
self.prod_environment,
)
res = client.get_quick_estimate(sender.zip, receiver_address, 'CustomerPackaging', weight)
_logger.warning('get_quick_estimate: %s', res)
if res['error']:
return {
'success': False,
@@ -120,3 +123,65 @@ class ProviderPurolator(models.Model):
'error_message': False,
'warning_message': False,
}
def purolator_rate_shipment_multi(self, order=None, picking=None, packages=None):
sender = self.get_shipper_warehouse(order=order, picking=picking)
receiver = self.get_recipient(order=order, picking=picking)
receiver_address = {
'City': receiver.city,
'Province': receiver.state_id.code,
'Country': receiver.country_id.code,
'PostalCode': receiver.zip,
}
weight_uom_id = self.env['product.template']._get_weight_uom_id_from_ir_config_parameter()
date_planned = fields.Datetime.now()
if self.env.context.get('date_planned'):
date_planned = self.env.context.get('date_planned')
if order:
weight = weight_uom_id._compute_quantity(order._get_estimated_weight(), self.env.ref('uom.product_uom_lb'), round=False)
else:
raise NotImplementedError
client = PurolatorClient(
self.purolator_api_key,
self.purolator_password,
self.purolator_activation_key,
self.purolator_account_number,
self.prod_environment,
)
res = client.get_quick_estimate(sender.zip, receiver_address, 'CustomerPackaging', weight)
if res['error']:
return [{'carrier': self,
'success': False,
'price': 0.0,
'error_message': _('Error:\n%s') % res['error'],
'warning_message': False,
}]
rates = []
for shipment in res['shipments']:
carrier = self.purolator_find_delivery_carrier_for_service(shipment['ServiceID'])
if carrier:
price = shipment['TotalPrice']
rates.append({
'carrier': carrier,
# 'package': package or self.env['stock.quant.package'].browse(),
'success': True,
'price': price,
'error_message': False,
'warning_message': _('TotalCharge not found.') if price == 0.0 else False,
'date_planned': date_planned,
'date_delivered': fields.Date.to_date(shipment['ExpectedDeliveryDate']),
'transit_days': shipment['EstimatedTransitDays'],
'service_code': shipment['ServiceID'],
})
return rates
def purolator_find_delivery_carrier_for_service(self, service_code):
if self.purolator_service_type == service_code:
return self
carrier = self.search([('delivery_type', '=', 'purolator'),
('purolator_service_type', '=', service_code)
], limit=1)
return carrier

View File

@@ -4,8 +4,6 @@ from zeep import Client
from zeep.cache import SqliteCache
from zeep.transports import Transport
from odoo.exceptions import UserError
import logging
_logger = logging.getLogger(__name__)
class PurolatorClient(object):
@@ -33,7 +31,6 @@ class PurolatorClient(object):
RequestReference='RatingExample',
UserToken=self.activation_key,
)
# _logger.warning('*** header_value:\n%s' % header_value)
client.set_default_soapheaders([header_value])
return client
@@ -60,7 +57,6 @@ class PurolatorClient(object):
'WeightUnit': 'lb',
},
)
# _logger.warning('**** GetQuickEstimate response:\n%s', response)
errors = response['body']['ResponseInformation']['Errors']
if errors:
return {

View File

@@ -5,7 +5,7 @@ from odoo.tests.common import Form, TransactionCase
class TestPurolator(TransactionCase):
def setUp(self):
super().setUp()
self.carrier = self.env.ref('delivery_purolator.purolator_carrier', raise_if_not_found=False)
self.carrier = self.env.ref('delivery_purolator.purolator_ground', raise_if_not_found=False)
if not self.carrier or not self.carrier.purolator_api_key:
self.skipTest('Purolator Shipping not configured, skipping tests.')
if self.carrier.prod_environment:
@@ -41,10 +41,19 @@ class TestPurolator(TransactionCase):
})
def test_00_rate_order(self):
# Regular Update Shipping functionality
delivery_wizard = Form(self.env['choose.delivery.carrier'].with_context({
'default_order_id': self.sale_order.id,
'default_carrier_id': self.ref('delivery_purolator.purolator_carrier'),
'default_carrier_id': self.ref('delivery_purolator.purolator_ground'),
}))
choose_delivery_carrier = delivery_wizard.save()
choose_delivery_carrier.update_price()
self.assertGreater(choose_delivery_carrier.delivery_price, 0.0, "Purolator delivery cost for this SO has not been correctly estimated.")
# Multi-rating with sale order
rates = self.carrier.rate_shipment_multi(order=self.sale_order)
carrier_express = self.env.ref('delivery_purolator.purolator_ground')
rate_express = list(filter(lambda r: r['carrier'] == carrier_express, rates))
rate_express = rate_express and rate_express[0]
self.assertGreater(rate_express['price'], 0.0)
self.assertGreater(rate_express['transit_days'], 0)