summaryrefslogtreecommitdiff
path: root/addons/purchase_requisition/tests
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/purchase_requisition/tests
parent0a15094050bfde69a06d6eff798e9a8ddf2b8c21 (diff)
initial commit 2
Diffstat (limited to 'addons/purchase_requisition/tests')
-rw-r--r--addons/purchase_requisition/tests/__init__.py5
-rw-r--r--addons/purchase_requisition/tests/common.py70
-rw-r--r--addons/purchase_requisition/tests/test_purchase_requisition.py115
3 files changed, 190 insertions, 0 deletions
diff --git a/addons/purchase_requisition/tests/__init__.py b/addons/purchase_requisition/tests/__init__.py
new file mode 100644
index 00000000..e3d51573
--- /dev/null
+++ b/addons/purchase_requisition/tests/__init__.py
@@ -0,0 +1,5 @@
+# -*- coding: utf-8 -*-
+# Part of Odoo. See LICENSE file for full copyright and licensing details.
+
+from . import common
+from . import test_purchase_requisition
diff --git a/addons/purchase_requisition/tests/common.py b/addons/purchase_requisition/tests/common.py
new file mode 100644
index 00000000..235208b8
--- /dev/null
+++ b/addons/purchase_requisition/tests/common.py
@@ -0,0 +1,70 @@
+# -*- coding: utf-8 -*-
+
+from odoo.tests import common
+
+
+class TestPurchaseRequisitionCommon(common.SavepointCase):
+
+ @classmethod
+ def setUpClass(cls):
+ super(TestPurchaseRequisitionCommon, cls).setUpClass()
+
+ # Fetch purchase related user groups
+ user_group_purchase_manager = cls.env.ref('purchase.group_purchase_manager')
+ user_group_purchase_user = cls.env.ref('purchase.group_purchase_user')
+
+ # User Data: purchase requisition Manager and User
+ Users = cls.env['res.users'].with_context({'tracking_disable': True})
+
+ cls.user_purchase_requisition_manager = Users.create({
+ 'name': 'Purchase requisition Manager',
+ 'login': 'prm',
+ 'email': 'requisition_manager@yourcompany.com',
+ 'notification_type': 'inbox',
+ 'groups_id': [(6, 0, [user_group_purchase_manager.id])]})
+
+ cls.user_purchase_requisition_user = Users.create({
+ 'name': 'Purchase requisition User',
+ 'login': 'pru',
+ 'email': 'requisition_user@yourcompany.com',
+ 'notification_type': 'inbox',
+ 'groups_id': [(6, 0, [user_group_purchase_user.id])]})
+
+ # Create Product
+ cls.product_uom_id = cls.env.ref('uom.product_uom_unit')
+
+ cls.product_09 = cls.env['product.product'].create({
+ 'name': 'Pedal Bin',
+ 'categ_id': cls.env.ref('product.product_category_all').id,
+ 'standard_price': 10.0,
+ 'list_price': 47.0,
+ 'type': 'consu',
+ 'uom_id': cls.product_uom_id.id,
+ 'uom_po_id': cls.product_uom_id.id,
+ 'default_code': 'E-COM10',
+ })
+
+ cls.product_13 = cls.env['product.product'].create({
+ 'name': 'Corner Desk Black',
+ 'categ_id': cls.env.ref('product.product_category_all').id,
+ 'standard_price': 78.0,
+ 'list_price': 85.0,
+ 'type': 'consu',
+ 'uom_id': cls.product_uom_id.id,
+ 'uom_po_id': cls.product_uom_id.id,
+ 'default_code': 'FURN_1118',
+ 'purchase_requisition': 'tenders',
+ })
+
+ # In order to test process of the purchase requisition ,create requisition
+ cls.requisition1 = cls.env['purchase.requisition'].create({
+ 'line_ids': [(0, 0, {
+ 'product_id': cls.product_09.id,
+ 'product_qty': 10.0,
+ 'product_uom_id': cls.product_uom_id.id})]
+ })
+
+ cls.res_partner_1 = cls.env['res.partner'].create({
+ 'name': 'Wood Corner',
+ })
+ cls.env.user.company_id.currency_id = cls.env.ref("base.USD").id
diff --git a/addons/purchase_requisition/tests/test_purchase_requisition.py b/addons/purchase_requisition/tests/test_purchase_requisition.py
new file mode 100644
index 00000000..adc86af9
--- /dev/null
+++ b/addons/purchase_requisition/tests/test_purchase_requisition.py
@@ -0,0 +1,115 @@
+# -*- coding: utf-8 -*-
+# Part of Odoo. See LICENSE file for full copyright and licensing details.
+
+from odoo.addons.purchase_requisition.tests.common import TestPurchaseRequisitionCommon
+
+
+class TestPurchaseRequisition(TestPurchaseRequisitionCommon):
+
+ def test_00_purchase_requisition_users(self):
+ self.assertTrue(self.user_purchase_requisition_manager, 'Manager Should be created')
+ self.assertTrue(self.user_purchase_requisition_user, 'User Should be created')
+
+ def test_01_cancel_purchase_requisition(self):
+ self.requisition1.with_user(self.user_purchase_requisition_user).action_cancel()
+ # Check requisition after cancelled.
+ self.assertEqual(self.requisition1.state, 'cancel', 'Requisition should be in cancelled state.')
+ # I reset requisition as "New".
+ self.requisition1.with_user(self.user_purchase_requisition_user).action_draft()
+ # I duplicate requisition.
+ self.requisition1.with_user(self.user_purchase_requisition_user).copy()
+
+
+ def test_02_purchase_requisition(self):
+ price_product09 = 34
+ price_product13 = 62
+ quantity = 26
+
+ # Create a pruchase requisition with type blanket order and two product
+ line1 = (0, 0, {'product_id': self.product_09.id, 'product_qty': quantity, 'product_uom_id': self.product_uom_id.id, 'price_unit': price_product09})
+ line2 = (0, 0, {'product_id': self.product_13.id, 'product_qty': quantity, 'product_uom_id': self.product_uom_id.id, 'price_unit': price_product13})
+
+ requisition_type = self.env['purchase.requisition.type'].create({
+ 'name': 'Blanket test',
+ 'quantity_copy': 'none'
+ })
+ requisition_blanket = self.env['purchase.requisition'].create({
+ 'line_ids': [line1, line2],
+ 'type_id': requisition_type.id,
+ 'vendor_id': self.res_partner_1.id,
+ })
+
+ # confirm the requisition
+ requisition_blanket.action_in_progress()
+
+ # Check for both product that the new supplier info(purchase.requisition.vendor_id) is added to the puchase tab
+ # and check the quantity
+ seller_partner1 = self.res_partner_1
+ supplierinfo09 = self.env['product.supplierinfo'].search([
+ ('name', '=', seller_partner1.id),
+ ('product_id', '=', self.product_09.id),
+ ('purchase_requisition_id', '=', requisition_blanket.id),
+ ])
+ self.assertEqual(supplierinfo09.name, seller_partner1, 'The supplierinfo is not the good one')
+ self.assertEqual(supplierinfo09.price, price_product09, 'The supplierinfo is not the good one')
+
+ supplierinfo13 = self.env['product.supplierinfo'].search([
+ ('name', '=', seller_partner1.id),
+ ('product_id', '=', self.product_13.id),
+ ('purchase_requisition_id', '=', requisition_blanket.id),
+ ])
+ self.assertEqual(supplierinfo13.name, seller_partner1, 'The supplierinfo is not the good one')
+ self.assertEqual(supplierinfo13.price, price_product13, 'The supplierinfo is not the good one')
+
+ # Put the requisition in done Status
+ requisition_blanket.action_in_progress()
+ requisition_blanket.action_done()
+
+ self.assertFalse(self.env['product.supplierinfo'].search([('id', '=', supplierinfo09.id)]), 'The supplier info should be removed')
+ self.assertFalse(self.env['product.supplierinfo'].search([('id', '=', supplierinfo13.id)]), 'The supplier info should be removed')
+
+ def test_06_purchase_requisition(self):
+ """ Create a blanquet order for a product and a vendor already linked via
+ a supplier info"""
+ product = self.env['product.product'].create({
+ 'name': 'test6',
+ })
+ product2 = self.env['product.product'].create({
+ 'name': 'test6',
+ })
+ vendor = self.env['res.partner'].create({
+ 'name': 'vendor6',
+ })
+ supplier_info = self.env['product.supplierinfo'].create({
+ 'product_id': product.id,
+ 'name': vendor.id,
+ })
+
+ # create a empty blanquet order
+ requisition_type = self.env['purchase.requisition.type'].create({
+ 'name': 'Blanket test',
+ 'quantity_copy': 'none'
+ })
+ line1 = (0, 0, {
+ 'product_id': product2.id,
+ 'product_uom_id': product2.uom_po_id.id,
+ 'price_unit': 41,
+ 'product_qty': 10,
+ })
+ requisition_blanket = self.env['purchase.requisition'].create({
+ 'line_ids': [line1],
+ 'type_id': requisition_type.id,
+ 'vendor_id': vendor.id,
+ })
+ requisition_blanket.action_in_progress()
+ self.env['purchase.requisition.line'].create({
+ 'product_id': product.id,
+ 'product_qty': 14.0,
+ 'requisition_id': requisition_blanket.id,
+ 'price_unit': 10,
+ })
+ new_si = self.env['product.supplierinfo'].search([
+ ('product_id', '=', product.id),
+ ('name', '=', vendor.id)
+ ]) - supplier_info
+ self.assertEqual(new_si.purchase_requisition_id, requisition_blanket, 'the blanket order is not linked to the supplier info')