Browse Source
[IMP]
[IMP]
- Added new optional tier definition for is_company = true. - Added auto active if no validation needed during create. - Added reset validation during write for specific fields. [FIX] Code White Space Formatting [IMP] Reviewer Suggestions [IMP] Added Tests14.0
Patrick Wilson
4 years ago
5 changed files with 101 additions and 8 deletions
-
6partner_tier_validation/data/tier_definition.xml
-
23partner_tier_validation/models/res_partner.py
-
9partner_tier_validation/readme/DESCRIPTION.rst
-
3partner_tier_validation/tests/__init__.py
-
68partner_tier_validation/tests/test_tier_validation.py
@ -1,12 +1,12 @@ |
|||
<odoo noupdate="1"> |
|||
<record id="partner_tier_definition" model="tier.definition"> |
|||
<field name="name">Partner Validation</field> |
|||
<record id="partner_tier_definition_company_only" model="tier.definition"> |
|||
<field name="name">Partner Validation (Company)</field> |
|||
<field name="model_id" ref="base.model_res_partner" /> |
|||
<field name="review_type">group</field> |
|||
<field name="reviewer_group_id" ref="base.group_user" /> |
|||
<field name="definition_type">domain</field> |
|||
<field |
|||
name="definition_domain" |
|||
>["&",["parent_id","=",False],"|",["active","=",True],["active","=",False]]</field> |
|||
>["&",["is_company","=",True],"|",["active","=",True],["active","=",False]]</field> |
|||
</record> |
|||
</odoo> |
@ -1,5 +1,12 @@ |
|||
Adds an approval workflow to Partners. |
|||
The default rule requires new parent Contacts to be approved |
|||
The default rule requires new company Contacts to be approved |
|||
before they can be used. |
|||
|
|||
The rule can be extended to new non-company contact, |
|||
but beware that may cause issues with automatically created new contacts, |
|||
such as the ones generated when processing incoming emails. |
|||
|
|||
If the 'Is Company' or 'Parent' field changes then the contact is Request |
|||
for approval. |
|||
|
|||
For this, the new Contact record is kept as "Archived" until it is approved. |
@ -0,0 +1,3 @@ |
|||
# License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl). |
|||
|
|||
from . import test_tier_validation |
@ -0,0 +1,68 @@ |
|||
# Copyright 2021 Patrick Wilson <pwilson@opensourceintegrators.com> |
|||
# License LGPL-3.0 or later (http://www.gnu.org/licenses/lgpl.html). |
|||
|
|||
from odoo.exceptions import ValidationError |
|||
from odoo.tests import common, tagged |
|||
|
|||
|
|||
@tagged("-at_install", "post_install") |
|||
class TestPartnerTierValidation(common.SavepointCase): |
|||
@classmethod |
|||
def setUpClass(cls): |
|||
super().setUpClass() |
|||
# Get res partner model |
|||
cls.partner_model = cls.env.ref("base.model_res_partner") |
|||
|
|||
# Create users |
|||
group_ids = cls.env.ref("base.group_system").ids |
|||
group_ids.append(cls.env.ref("base.group_partner_manager").id) |
|||
cls.test_user_1 = cls.env["res.users"].create( |
|||
{ |
|||
"name": "John", |
|||
"login": "test1", |
|||
"groups_id": [(6, 0, group_ids)], |
|||
"email": "test@examlple.com", |
|||
} |
|||
) |
|||
|
|||
# Create tier definitions: |
|||
cls.tier_def_obj = cls.env["tier.definition"] |
|||
cls.tier_def_obj.create( |
|||
{ |
|||
"model_id": cls.partner_model.id, |
|||
"review_type": "individual", |
|||
"reviewer_id": cls.test_user_1.id, |
|||
"definition_domain": "['&',('is_company','=',True),'|', \ |
|||
('active','=',True),('active','=',False)]", |
|||
} |
|||
) |
|||
|
|||
def test_tier_validation_model_name(self): |
|||
self.assertIn( |
|||
"res.partner", self.tier_def_obj._get_tier_validation_model_names() |
|||
) |
|||
|
|||
def test_validation_res_partner(self): |
|||
company = self.env["res.partner"].create( |
|||
{"name": "Company for test", "company_type": "company"} |
|||
) |
|||
# Since company need validation, it should be inactive |
|||
self.assertEqual(company.active, False) |
|||
|
|||
# Assert an error shows if trying to make it active |
|||
with self.assertRaises(ValidationError): |
|||
company.write({"state": "confirmed"}) |
|||
|
|||
# Request and validate partner |
|||
company.request_validation() |
|||
company.with_user(self.test_user_1).validate_tier() |
|||
company.with_user(self.test_user_1).write({"state": "confirmed"}) |
|||
self.assertEqual(company.state, "confirmed") |
|||
|
|||
# Change company type to retrigger validation |
|||
company.write({"company_type": "person", "is_company": False}) |
|||
self.assertEqual(company.state, "draft") |
|||
|
|||
# Test partner creation that doesn't need validation |
|||
customer = self.env["res.partner"].create({"name": "Partner for test"}) |
|||
self.assertEqual(customer.active, True) |
Write
Preview
Loading…
Cancel
Save
Reference in new issue