summaryrefslogtreecommitdiff
path: root/addons/sale/tests/test_sale_flow.py
diff options
context:
space:
mode:
authorstephanchrst <stephanchrst@gmail.com>2022-05-10 21:51:50 +0700
committerstephanchrst <stephanchrst@gmail.com>2022-05-10 21:51:50 +0700
commit3751379f1e9a4c215fb6eb898b4ccc67659b9ace (patch)
treea44932296ef4a9b71d5f010906253d8c53727726 /addons/sale/tests/test_sale_flow.py
parent0a15094050bfde69a06d6eff798e9a8ddf2b8c21 (diff)
initial commit 2
Diffstat (limited to 'addons/sale/tests/test_sale_flow.py')
-rw-r--r--addons/sale/tests/test_sale_flow.py82
1 files changed, 82 insertions, 0 deletions
diff --git a/addons/sale/tests/test_sale_flow.py b/addons/sale/tests/test_sale_flow.py
new file mode 100644
index 00000000..c18d645f
--- /dev/null
+++ b/addons/sale/tests/test_sale_flow.py
@@ -0,0 +1,82 @@
+# -*- coding: utf-8 -*-
+from odoo.addons.sale.tests.common import TestSaleCommonBase
+
+
+class TestSaleFlow(TestSaleCommonBase):
+ ''' Test running at-install to test flows independently to other modules, e.g. 'sale_stock'. '''
+
+ @classmethod
+ def setUpClass(cls):
+ super().setUpClass()
+
+ user = cls.env['res.users'].create({
+ 'name': 'Because I am saleman!',
+ 'login': 'saleman',
+ 'groups_id': [(6, 0, cls.env.user.groups_id.ids), (4, cls.env.ref('account.group_account_user').id)],
+ })
+ user.partner_id.email = 'saleman@test.com'
+
+ # Shadow the current environment/cursor with the newly created user.
+ cls.env = cls.env(user=user)
+ cls.cr = cls.env.cr
+
+ cls.company = cls.env['res.company'].create({
+ 'name': 'Test Company',
+ 'currency_id': cls.env.ref('base.USD').id,
+ })
+ cls.company_data = cls.setup_sale_configuration_for_company(cls.company)
+
+ cls.partner_a = cls.env['res.partner'].create({
+ 'name': 'partner_a',
+ 'company_id': False,
+ })
+
+ cls.analytic_account = cls.env['account.analytic.account'].create({
+ 'name': 'Test analytic_account',
+ 'code': 'analytic_account',
+ 'company_id': cls.company.id,
+ 'partner_id': cls.partner_a.id
+ })
+
+ user.company_ids |= cls.company
+ user.company_id = cls.company
+
+ def test_qty_delivered(self):
+ ''' Test 'qty_delivered' at-install to avoid a change in the behavior when 'sale_stock' is installed. '''
+
+ sale_order = self.env['sale.order'].with_context(mail_notrack=True, mail_create_nolog=True).create({
+ 'partner_id': self.partner_a.id,
+ 'partner_invoice_id': self.partner_a.id,
+ 'partner_shipping_id': self.partner_a.id,
+ 'analytic_account_id': self.analytic_account.id,
+ 'pricelist_id': self.company_data['default_pricelist'].id,
+ 'order_line': [
+ (0, 0, {
+ 'name': self.company_data['product_order_cost'].name,
+ 'product_id': self.company_data['product_order_cost'].id,
+ 'product_uom_qty': 2,
+ 'qty_delivered': 1,
+ 'product_uom': self.company_data['product_order_cost'].uom_id.id,
+ 'price_unit': self.company_data['product_order_cost'].list_price,
+ }),
+ (0, 0, {
+ 'name': self.company_data['product_delivery_cost'].name,
+ 'product_id': self.company_data['product_delivery_cost'].id,
+ 'product_uom_qty': 4,
+ 'qty_delivered': 1,
+ 'product_uom': self.company_data['product_delivery_cost'].uom_id.id,
+ 'price_unit': self.company_data['product_delivery_cost'].list_price,
+ }),
+ ],
+ })
+ for line in sale_order.order_line:
+ line.product_id_change()
+
+ sale_order.onchange_partner_id()
+ sale_order._compute_tax_id()
+ sale_order.action_confirm()
+
+ self.assertRecordValues(sale_order.order_line, [
+ {'qty_delivered': 1.0},
+ {'qty_delivered': 1.0},
+ ])