diff options
| author | stephanchrst <stephanchrst@gmail.com> | 2022-05-10 21:51:50 +0700 |
|---|---|---|
| committer | stephanchrst <stephanchrst@gmail.com> | 2022-05-10 21:51:50 +0700 |
| commit | 3751379f1e9a4c215fb6eb898b4ccc67659b9ace (patch) | |
| tree | a44932296ef4a9b71d5f010906253d8c53727726 /addons/sale/tests/test_sale_flow.py | |
| parent | 0a15094050bfde69a06d6eff798e9a8ddf2b8c21 (diff) | |
initial commit 2
Diffstat (limited to 'addons/sale/tests/test_sale_flow.py')
| -rw-r--r-- | addons/sale/tests/test_sale_flow.py | 82 |
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}, + ]) |
