File: test_project_update_access_rights.py

package info (click to toggle)
odoo 18.0.0%2Bdfsg-2
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 878,716 kB
  • sloc: javascript: 927,937; python: 685,670; xml: 388,524; sh: 1,033; sql: 415; makefile: 26
file content (96 lines) | stat: -rw-r--r-- 4,803 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
# -*- coding: utf-8 -*-

from odoo.exceptions import AccessError
from odoo.tests import tagged
from odoo.tests.common import users

from odoo.addons.mail.tests.common import mail_new_test_user
from odoo.addons.project.tests.test_project_base import TestProjectCommon

@tagged('-at_install', 'post_install')
class TestProjectUpdateAccessRights(TestProjectCommon):
    @classmethod
    def setUpClass(cls):
        super(TestProjectUpdateAccessRights, cls).setUpClass()
        cls.project_update_1 = cls.env['project.update'].create({
            'name': "Test Project Update",
            'project_id': cls.project_pigs.id,
            'status': 'on_track',
        })
        cls.project_milestone = cls.env['project.milestone'].create({
            'name': 'Test Projec Milestone',
            'project_id': cls.project_pigs.id,
        })
        cls.base_user = mail_new_test_user(cls.env, 'Base user', groups='base.group_user')
        cls.project_user = mail_new_test_user(cls.env, 'Project user', groups='project.group_project_user')
        cls.project_manager = mail_new_test_user(cls.env, 'Project admin', groups='project.group_project_manager')
        cls.portal_user = mail_new_test_user(cls.env, 'Portal user', groups='base.group_portal')

    @users('Project user', 'Project admin', 'Base user')
    def test_project_update_user_can_read(self):
        self.project_update_1.with_user(self.env.user).name

    @users('Base user')
    def test_project_update_user_no_write(self):
        with self.assertRaises(AccessError, msg="%s should not be able to write in the project update" % self.env.user.name):
            self.project_update_1.with_user(self.env.user).name = "Test write"

    @users('Project admin')
    def test_project_update_admin_can_write(self):
        self.project_update_1.with_user(self.env.user).name = "Test write"

    @users('Base user')
    def test_project_update_user_no_unlink(self):
        with self.assertRaises(AccessError, msg="%s should not be able to unlink in the project update" % self.env.user.name):
            self.project_update_1.with_user(self.env.user).unlink()

    @users('Project admin')
    def test_project_update_admin_unlink(self):
        self.project_update_1.with_user(self.env.user).unlink()

    @users('Portal user')
    def test_project_update_portal_user_no_read(self):
        with self.assertRaises(AccessError, msg=f"{self.env.user.name} should not be able to read in the project update"):
            self.project_update_1.with_user(self.env.user).name

    @users('Portal user')
    def test_project_update_portal_user_no_write(self):
        with self.assertRaises(AccessError, msg=f"{self.env.user.name} should not be able to write in the project update"):
            self.project_update_1.with_user(self.env.user).name = 'Test write'

    @users('Portal user')
    def test_project_update_portal_user_no_create(self):
        with self.assertRaises(AccessError, msg=f"{self.env.user.name} should not be able to create in the project update model"):
            self.env['project.update'].with_user(self.env.user).create({
                'name': 'Test Create with portal user',
                'project_id': self.project_pigs.id,
                'state': 'on_track',
            })

    @users('Portal user')
    def test_project_update_portal_user_no_unlink(self):
        with self.assertRaises(AccessError, msg=f"{self.env.user.name} should not be able to unlink in the project update"):
            self.project_update_1.with_user(self.env.user).unlink()

    @users('Portal user')
    def test_project_milestone_portal_user_no_read(self):
        with self.assertRaises(AccessError, msg=f"{self.env.user.name} should not be able to read in the project update"):
            self.project_milestone.with_user(self.env.user).name

    @users('Portal user')
    def test_project_milestone_portal_user_no_write(self):
        with self.assertRaises(AccessError, msg=f"{self.env.user.name} should not be able to write in the project update"):
            self.project_milestone.with_user(self.env.user).name = 'Test write'

    @users('Portal user')
    def test_project_milestone_portal_user_no_create(self):
        with self.assertRaises(AccessError, msg=f"{self.env.user.name} should not be able to create in the project update model"):
            self.env['project.update'].with_user(self.env.user).create({
                'name': 'Test Create with portal user',
                'project_id': self.project_pigs.id,
            })

    @users('Portal user')
    def test_project_milestone_portal_user_no_unlink(self):
        with self.assertRaises(AccessError, msg=f"{self.env.user.name} should not be able to unlink in the project update"):
            self.project_milestone.with_user(self.env.user).unlink()