Skip to content

Commit

Permalink
[COV] l10n_it_fiscal_document_type: Access
Browse files Browse the repository at this point in the history
  • Loading branch information
SirTakobi committed Aug 24, 2023
1 parent 625daf1 commit 3345932
Show file tree
Hide file tree
Showing 2 changed files with 71 additions and 2 deletions.
6 changes: 5 additions & 1 deletion l10n_it_fiscal_document_type/__manifest__.py
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
# Copyright 2017 Alessandro Camilli
# Copyright 2018 Sergio Zanchetta (Associazione PNLUG - Gruppo Odoo)
# Copyright 2018 Lorenzo Battistini (https://github.com/eLBati)
# Copyright 2023 Simone Rubino - TAKOBI
# License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl).

{
Expand All @@ -12,7 +13,10 @@
'website': 'https://github.com/OCA/l10n-italy'
'/tree/12.0/l10n_it_fiscal_document_type',
'license': 'AGPL-3',
'depends': ['l10n_it_account'],
'depends': [
'l10n_it_account',
'mail',
],
'data': [
'views/fiscal_document_type_view.xml',
'views/res_partner_view.xml',
Expand Down
67 changes: 66 additions & 1 deletion l10n_it_fiscal_document_type/tests/test_doc_type.py
Original file line number Diff line number Diff line change
@@ -1,6 +1,10 @@
# Copyright 2017 Lorenzo Battistini
# Copyright 2023 Simone Rubino - TAKOBI
# License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl).

from odoo.tests.common import TransactionCase
from odoo.addons.test_mail.tests.common import mail_new_test_user
from odoo.exceptions import AccessError
from odoo.tests.common import TransactionCase, users


class TestDocType(TransactionCase):
Expand All @@ -20,6 +24,11 @@ def setUp(self):
"name": "FP",
"fiscal_document_type_id": self.TD01.id,
})
self.adviser = mail_new_test_user(
self.env,
login="Adviser",
groups='account.group_account_manager',
)

def test_doc_type(self):
self.TD01.journal_ids = [self.journalrec.id]
Expand Down Expand Up @@ -80,3 +89,59 @@ def test_doc_type_refund(self):
invoice.journal_id.id
)
self.assertEqual(refund.fiscal_document_type_id.id, self.TD04.id)

@users("Adviser", "admin")
def test_access(self):
"""Users can only read fiscal documents,
Users can't create/update/delete fiscal documents."""
# Arrange
user = self.env.user
doc_type_model = self.doc_type_model
doc_type = self.TD01
user_doc_type_model = doc_type_model.sudo(user=user.id)
user_doc_type = user_doc_type_model.browse(doc_type.id)
# pre-condition: user_* objects are linked to current user
root_user = self.env.ref("base.user_root")
self.assertEqual(doc_type_model.env.uid, root_user.id)
self.assertEqual(doc_type.env.uid, root_user.id)
self.assertEqual(user_doc_type.env.uid, user.id)
self.assertEqual(user_doc_type_model.env.uid, user.id)

# Act: Read
code = user_doc_type.code

# Assert: Read
self.assertEqual(code, "TD01")

# Act: Create
with self.assertRaises(AccessError) as ae, self.env.cr.savepoint():
user_doc_type_model.create({
"code": "TC04",
"name": "Test Code",
})

# Assert: Create
exc_message = ae.exception.args[0]
self.assertIn("not allowed", exc_message)
self.assertIn("Operation: create", exc_message)
self.assertIn("Document model: " + user_doc_type_model._name, exc_message)

# Act: Update
with self.assertRaises(AccessError) as ae, self.env.cr.savepoint():
user_doc_type.name = "Update is forbidden"

# Assert: Update
exc_message = ae.exception.args[0]
self.assertIn("not allowed", exc_message)
self.assertIn("Operation: write", exc_message)
self.assertIn("Document model: " + user_doc_type_model._name, exc_message)

# Act: Delete
with self.assertRaises(AccessError) as ae, self.env.cr.savepoint():
user_doc_type.unlink()

# Assert: Delete
exc_message = ae.exception.args[0]
self.assertIn("not allowed", exc_message)
self.assertIn("Operation: unlink", exc_message)
self.assertIn("Document model: " + user_doc_type_model._name, exc_message)

0 comments on commit 3345932

Please sign in to comment.