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_purchase/tests/test_access_rights.py | |
| parent | 0a15094050bfde69a06d6eff798e9a8ddf2b8c21 (diff) | |
initial commit 2
Diffstat (limited to 'addons/sale_purchase/tests/test_access_rights.py')
| -rw-r--r-- | addons/sale_purchase/tests/test_access_rights.py | 70 |
1 files changed, 70 insertions, 0 deletions
diff --git a/addons/sale_purchase/tests/test_access_rights.py b/addons/sale_purchase/tests/test_access_rights.py new file mode 100644 index 00000000..5240bc0e --- /dev/null +++ b/addons/sale_purchase/tests/test_access_rights.py @@ -0,0 +1,70 @@ +# -*- coding: utf-8 -*- +# Part of Odoo. See LICENSE file for full copyright and licensing details. + +from odoo.exceptions import AccessError +from odoo.addons.sale_purchase.tests.common import TestCommonSalePurchaseNoChart +from odoo.tests import tagged + + +@tagged('-at_install', 'post_install') +class TestAccessRights(TestCommonSalePurchaseNoChart): + + @classmethod + def setUpClass(cls, chart_template_ref=None): + super().setUpClass(chart_template_ref=chart_template_ref) + + # Create a users + group_sale_user = cls.env.ref('sales_team.group_sale_salesman') + group_purchase_user = cls.env.ref('purchase.group_purchase_user') + cls.user_salesperson = cls.env['res.users'].with_context(no_reset_password=True).create({ + 'name': 'Le Grand Jojo User', + 'login': 'grand.jojo', + 'email': 'grand.jojo@chansonbelge.com', + 'groups_id': [(6, 0, [group_sale_user.id])] + }) + cls.user_purchaseperson = cls.env['res.users'].with_context(no_reset_password=True).create({ + 'name': 'Jean-Luc Fonck', + 'login': 'jl.fonck', + 'email': 'jl.fonck@chansonbelge.com', + 'groups_id': [(6, 0, [group_purchase_user.id])] + }) + + def test_access_saleperson(self): + """ Check a saleperson (only) can generate a PO and a PO user can not confirm a SO """ + SaleOrder = self.env['sale.order'].with_context(tracking_disable=True) + + sale_order = SaleOrder.with_user(self.user_salesperson).create({ + 'partner_id': self.partner_a.id, + 'user_id': self.user_salesperson.id + }) + + sol_service_purchase = self.env['sale.order.line'].with_user(self.user_salesperson).create({ + 'name': self.service_purchase_1.name, + 'product_id': self.service_purchase_1.id, + 'product_uom_qty': 4, + 'product_uom': self.service_purchase_1.uom_id.id, + 'price_unit': self.service_purchase_1.list_price, + 'order_id': sale_order.id, + 'tax_id': False, + }) + + # confirming SO will create the PO even if you don't have the rights + sale_order.action_confirm() + sale_order.action_cancel() + + self.assertTrue(sale_order.name, "Saleperson can read its own SO") + + action = sale_order.sudo().action_view_purchase_orders() + + # try to access PO as sale person + with self.assertRaises(AccessError): + purchase_orders = self.env['purchase.order'].with_user(self.user_salesperson).browse(action['res_id']) + purchase_orders.read() + + # try to access PO as purchase person + purchase_orders = self.env['purchase.order'].with_user(self.user_purchaseperson).browse(action['res_id']) + purchase_orders.read() + + # try to access the PO lines from the SO, as sale person + with self.assertRaises(AccessError): + sol_service_purchase.with_user(self.user_salesperson).purchase_line_ids.read() |
