summaryrefslogtreecommitdiff
path: root/addons/purchase/tests/test_access_rights.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/purchase/tests/test_access_rights.py
parent0a15094050bfde69a06d6eff798e9a8ddf2b8c21 (diff)
initial commit 2
Diffstat (limited to 'addons/purchase/tests/test_access_rights.py')
-rw-r--r--addons/purchase/tests/test_access_rights.py160
1 files changed, 160 insertions, 0 deletions
diff --git a/addons/purchase/tests/test_access_rights.py b/addons/purchase/tests/test_access_rights.py
new file mode 100644
index 00000000..855b0270
--- /dev/null
+++ b/addons/purchase/tests/test_access_rights.py
@@ -0,0 +1,160 @@
+# -*- coding: utf-8 -*-
+# Part of Odoo. See LICENSE file for full copyright and licensing details.
+from odoo.addons.account.tests.common import AccountTestInvoicingCommon
+from odoo.tests import Form, tagged
+from odoo.exceptions import AccessError
+
+
+@tagged('post_install', '-at_install')
+class TestPurchaseInvoice(AccountTestInvoicingCommon):
+
+ @classmethod
+ def setUpClass(cls, chart_template_ref=None):
+ super().setUpClass(chart_template_ref=chart_template_ref)
+
+ # Create a users
+ group_purchase_user = cls.env.ref('purchase.group_purchase_user')
+ group_employee = cls.env.ref('base.group_user')
+ group_partner_manager = cls.env.ref('base.group_partner_manager')
+
+ cls.purchase_user = cls.env['res.users'].with_context(
+ no_reset_password=True
+ ).create({
+ 'name': 'Purchase user',
+ 'login': 'purchaseUser',
+ 'email': 'pu@odoo.com',
+ 'groups_id': [(6, 0, [group_purchase_user.id, group_employee.id, group_partner_manager.id])],
+ })
+
+ cls.vendor = cls.env['res.partner'].create({
+ 'name': 'Supplier',
+ 'email': 'supplier.serv@supercompany.com',
+ })
+
+ user_type_expense = cls.env.ref('account.data_account_type_expenses')
+ cls.account_expense_product = cls.env['account.account'].create({
+ 'code': 'EXPENSE_PROD111',
+ 'name': 'Expense - Test Account',
+ 'user_type_id': user_type_expense.id,
+ })
+ # Create category
+ cls.product_category = cls.env['product.category'].create({
+ 'name': 'Product Category with Expense account',
+ 'property_account_expense_categ_id': cls.account_expense_product.id
+ })
+ cls.product = cls.env['product.product'].create({
+ 'name': "Product",
+ 'standard_price': 200.0,
+ 'list_price': 180.0,
+ 'type': 'service',
+ })
+
+ def test_create_purchase_order(self):
+ """Check a purchase user can create a vendor bill from a purchase order but not post it"""
+ purchase_order_form = Form(self.env['purchase.order'].with_user(self.purchase_user))
+ purchase_order_form.partner_id = self.vendor
+ with purchase_order_form.order_line.new() as line:
+ line.name = self.product.name
+ line.product_id = self.product
+ line.product_qty = 4
+ line.price_unit = 5
+
+ purchase_order = purchase_order_form.save()
+ purchase_order.button_confirm()
+
+ purchase_order.order_line.qty_received = 4
+ purchase_order.action_create_invoice()
+ invoice = purchase_order.invoice_ids
+ with self.assertRaises(AccessError):
+ invoice.action_post()
+
+ def test_read_purchase_order(self):
+ """ Check that a purchase user can read all purchase order and 'in' invoices"""
+ purchase_user_2 = self.purchase_user.copy({
+ 'name': 'Purchase user 2',
+ 'login': 'purchaseUser2',
+ 'email': 'pu2@odoo.com',
+ })
+
+ purchase_order_form = Form(self.env['purchase.order'].with_user(purchase_user_2))
+ purchase_order_form.partner_id = self.vendor
+ with purchase_order_form.order_line.new() as line:
+ line.name = self.product.name
+ line.product_id = self.product
+ line.product_qty = 4
+ line.price_unit = 5
+
+ purchase_order_user2 = purchase_order_form.save()
+ purchase_order_user2.button_confirm()
+
+ purchase_order_user2.order_line.qty_received = 4
+ purchase_order_user2.action_create_invoice()
+ vendor_bill_user2 = purchase_order_user2.invoice_ids
+
+ # open purchase_order_user2 and vendor_bill_user2 with `self.purchase_user`
+ purchase_order_user1 = Form(purchase_order_user2.with_user(self.purchase_user))
+ purchase_order_user1 = purchase_order_user1.save()
+ vendor_bill_user1 = Form(vendor_bill_user2.with_user(self.purchase_user))
+ vendor_bill_user1 = vendor_bill_user1.save()
+
+ def test_read_purchase_order_2(self):
+ """ Check that a 2 purchase users with open the vendor bill the same
+ way even with a 'own documents only' record rule. """
+
+ # edit the account.move record rule for purchase user in order to ensure
+ # a user can only see his own invoices
+ rule = self.env.ref('purchase.purchase_user_account_move_rule')
+ rule.domain_force = "['&', ('move_type', 'in', ('in_invoice', 'in_refund', 'in_receipt')), ('invoice_user_id', '=', user.id)]"
+
+ # create a purchase and make a vendor bill from it as purchase user 2
+ purchase_user_2 = self.purchase_user.copy({
+ 'name': 'Purchase user 2',
+ 'login': 'purchaseUser2',
+ 'email': 'pu2@odoo.com',
+ })
+
+ purchase_order_form = Form(self.env['purchase.order'].with_user(purchase_user_2))
+ purchase_order_form.partner_id = self.vendor
+ with purchase_order_form.order_line.new() as line:
+ line.name = self.product.name
+ line.product_id = self.product
+ line.product_qty = 4
+ line.price_unit = 5
+
+ purchase_order_user2 = purchase_order_form.save()
+ purchase_order_user2.button_confirm()
+
+ purchase_order_user2.order_line.qty_received = 4
+ purchase_order_user2.action_create_invoice()
+ vendor_bill_user2 = purchase_order_user2.invoice_ids
+
+ # check user 1 cannot read the invoice
+ with self.assertRaises(AccessError):
+ Form(vendor_bill_user2.with_user(self.purchase_user))
+
+ # Check that calling 'action_view_invoice' return the same action despite the record rule
+ action_user_1 = purchase_order_user2.with_user(self.purchase_user).action_view_invoice()
+ purchase_order_user2.invalidate_cache()
+ action_user_2 = purchase_order_user2.with_user(purchase_user_2).action_view_invoice()
+ self.assertEqual(action_user_1, action_user_2)
+
+ def test_double_validation(self):
+ """Only purchase managers can approve a purchase order when double
+ validation is enabled"""
+ group_purchase_manager = self.env.ref('purchase.group_purchase_manager')
+ order = self.env.ref("purchase.purchase_order_1")
+ company = order.sudo().company_id
+ company.po_double_validation = 'two_step'
+ company.po_double_validation_amount = 0
+ self.purchase_user.write({
+ 'company_ids': [(4, company.id)],
+ 'company_id': company.id,
+ 'groups_id': [(3, group_purchase_manager.id)],
+ })
+ order.with_user(self.purchase_user).button_confirm()
+ self.assertEqual(order.state, 'to approve')
+ order.with_user(self.purchase_user).button_approve()
+ self.assertEqual(order.state, 'to approve')
+ self.purchase_user.groups_id += group_purchase_manager
+ order.with_user(self.purchase_user).button_approve()
+ self.assertEqual(order.state, 'purchase')