You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

86 lines
3.5 KiB

###################################################################################
#
# Copyright (c) 2017-2019 MuK IT GmbH.
#
# This file is part of MuK Security
# (see https://mukit.at).
#
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU Lesser General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU Lesser General Public License for more details.
#
# You should have received a copy of the GNU Lesser General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>.
#
###################################################################################
import os
import base64
import logging
from odoo import exceptions
from odoo.tests import common
_path = os.path.dirname(os.path.dirname(__file__))
_logger = logging.getLogger(__name__)
class AccessGroupsTestCase(common.TransactionCase):
def setUp(self):
super(AccessGroupsTestCase, self).setUp()
self.user_id = self.ref('base.user_demo')
self.group_id = self.ref('base.group_system')
self.groups = self.env['muk_security.access_groups']
self.group01 = self.groups.create({
'name': 'Group 01',
'explicit_users': [(6, 0, [self.user_id])]})
self.group02 = self.groups.create({
'name': 'Group 02',
'groups': [(6, 0, [self.group_id])]})
self.user = self.env['res.users'].browse(self.user_id)
self.group = self.env['res.groups'].browse(self.group_id)
def tearDown(self):
super(AccessGroupsTestCase, self).tearDown()
def test_access_groups_users(self):
count = len(self.group02.users)
self.group02.write({'explicit_users': [(6, 0, [self.user_id])]})
self.assertTrue(len(self.group02.users) > count)
def test_access_groups_groups(self):
count = len(self.group01.users)
self.group01.write({'groups': [(6, 0, [self.group_id])]})
self.assertTrue(len(self.group01.users) > count)
def test_access_groups_groups_group(self):
count = len(self.group02.users)
self.group.write({'users': [(4, self.user_id)]})
self.assertTrue(len(self.group02.users) > count)
def test_access_groups_groups_user(self):
count = len(self.group02.users)
self.user.write({'groups_id':[(4, self.group_id)]})
self.assertTrue(len(self.group02.users) > count)
def test_access_groups_parent(self):
count = len(self.group02.users)
self.group02.write({'parent_group': self.group01.id})
self.assertTrue(len(self.group02.users) > count)
def test_access_groups_parent_multi(self):
group01 = self.groups.create({'name': 'MGroup 01'})
group02 = self.groups.create({'name': 'MGroup 02', 'parent_group': group01.id})
group03 = self.groups.create({'name': 'MGroup 03', 'parent_group': group02.id})
init_count = len(group03.users)
group02.write({'explicit_users': [(6, 0, [self.user_id])]})
self.assertTrue(len(group03.users) > init_count)
updated_count = len(group03.users)
group01.write({'groups': [(6, 0, [self.group_id])]})
self.assertTrue(len(group03.users) > updated_count)