Skip to content

Commit

Permalink
[FIX] dms_field: Test compatibility
Browse files Browse the repository at this point in the history
We need to avoid applying a template except when testing functionality
with dms_field* modules to avoid the error that a directory with the same
name already exists (example: create partner).

Related to #378
  • Loading branch information
victoralmau committed Nov 29, 2024
1 parent 9bb2272 commit 1388109
Show file tree
Hide file tree
Showing 4 changed files with 18 additions and 14 deletions.
13 changes: 11 additions & 2 deletions dms_field/models/dms_field_mixin.py
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@
# License LGPL-3.0 or later (http://www.gnu.org/licenses/lgpl).

from odoo import api, fields, models
from odoo.tools import config


class DMSFieldMixin(models.AbstractModel):
Expand Down Expand Up @@ -30,10 +31,18 @@ def models_to_track_dms_field_template(self):

@api.model_create_multi
def create(self, vals_list):
"""Create a dms directory when creating the record if exist a template."""
"""Create a dms directory when creating the record if exist a template.
We need to avoid applying a template except when testing functionality
with dms_field* modules to avoid the error that a directory with the same
name already exists (example: create partner).
"""
result = super().create(vals_list)
test_condition = not config["test_enable"] or self.env.context.get(
"test_dms_field"
)
if (
not self.env.context.get("skip_track_dms_field_template")
test_condition
and not self.env.context.get("skip_track_dms_field_template")
and self._name in self.models_to_track_dms_field_template()
):
template = self.env["dms.field.template"].with_context(res_model=self._name)
Expand Down
17 changes: 5 additions & 12 deletions dms_field/tests/test_dms_field.py
Original file line number Diff line number Diff line change
Expand Up @@ -4,24 +4,17 @@

from odoo import fields
from odoo.exceptions import UserError, ValidationError
from odoo.tests import TransactionCase, new_test_user
from odoo.tests import new_test_user
from odoo.tools import mute_logger

from odoo.addons.base.tests.common import BaseCommon

class TestDmsField(TransactionCase):

class TestDmsField(BaseCommon):
@classmethod
def setUpClass(cls):
super().setUpClass()
cls.env = cls.env(
context=dict(
cls.env.context,
mail_create_nolog=True,
mail_create_nosubscribe=True,
mail_notrack=True,
no_reset_password=True,
tracking_disable=True,
)
)
cls.env = cls.env(context=dict(cls.env.context, test_dms_field=True))
cls.user_a = new_test_user(cls.env, login="test-user-a")
cls.group = cls.env["res.groups"].create(
{"name": "Test group", "users": [(4, cls.user_a.id)]}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,7 @@ class TestDmsFieldAutoClassification(BaseCommon):
@classmethod
def setUpClass(cls):
super().setUpClass()
cls.env = cls.env(context=dict(cls.env.context, test_dms_field=True))
cls.template = cls.env.ref(
"dms_field_auto_classification.dms_classification_template_partners"
)
Expand Down
1 change: 1 addition & 0 deletions hr_dms_field/tests/test_hr_dms_field.py
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,7 @@ class TestHrDmsField(BaseCommon):
@classmethod
def setUpClass(cls):
super().setUpClass()
cls.env = cls.env(context=dict(cls.env.context, test_dms_field=True))
cls.template = cls.env.ref("hr_dms_field.field_template_employee")
cls.storage = cls.template.storage_id
cls.access_group = cls.template.group_ids
Expand Down

0 comments on commit 1388109

Please sign in to comment.