# -*- coding: utf-8 -*- # Part of Odoo. See LICENSE file for full copyright and licensing details. from odoo.exceptions import AccessError from odoo.tests.common import new_test_user from odoo.addons.mail.tests.common import MailCommon class TestRecruitmentInterviewer(MailCommon): @classmethod def setUpClass(cls): super().setUpClass() cls.simple_user = new_test_user(cls.env, 'smp', groups='base.group_user', name='Simple User', email='smp@example.com') cls.interviewer_user = new_test_user(cls.env, 'itw', groups='base.group_user,hr_recruitment.group_hr_recruitment_interviewer', name='Recruitment Interviewer', email='itw@example.com') cls.manager_user = new_test_user(cls.env, 'mng', groups='base.group_user,hr_recruitment.group_hr_recruitment_manager', name='Recruitment Manager', email='mng@example.com') cls.job = cls.env['hr.job'].create({ 'name': 'super nice job', 'user_id': cls.manager_user.id, }) def test_interviewer_group(self): """ Test that adding a user as interviewer to a job / applicant adds that user in the Interviewer group. Also checks that removing the user will remove them when they are no longer required (e.g. no longer interviewer of any job/applicant). """ interviewer_group = self.env.ref('hr_recruitment.group_hr_recruitment_interviewer') self.assertFalse(interviewer_group.id in self.simple_user.groups_id.ids, "Simple User should not be interviewer") self.job.interviewer_ids = self.simple_user.ids self.assertTrue(interviewer_group.id in self.simple_user.groups_id.ids, "Simple User should be added as interviewer") self.job.write({'interviewer_ids': [(5, 0, 0)]}) self.assertFalse(interviewer_group.id in self.simple_user.groups_id.ids, "Simple User should be removed from interviewer") applicant = self.env['hr.applicant'].create({ 'name': 'toto', 'partner_name': 'toto', 'job_id': self.job.id, 'interviewer_ids': self.simple_user.ids, }) self.assertTrue(interviewer_group.id in self.simple_user.groups_id.ids, "Simple User should be added as interviewer") applicant.interviewer_ids = False self.assertFalse(interviewer_group.id in self.simple_user.groups_id.ids, "Simple User should be removed from interviewer") self.job.interviewer_ids = self.simple_user.ids applicant.interviewer_ids = self.simple_user.ids self.assertTrue(interviewer_group.id in self.simple_user.groups_id.ids, "Simple User should be added as interviewer") applicant.interviewer_ids = False self.assertTrue(interviewer_group.id in self.simple_user.groups_id.ids, "Simple User should stay interviewer") self.job.write({'interviewer_ids': [(5, 0, 0)]}) applicant.interviewer_ids = self.simple_user.ids self.assertTrue(interviewer_group.id in self.simple_user.groups_id.ids, "Simple User should stay interviewer") applicant.interviewer_ids = False self.assertFalse(interviewer_group.id in self.simple_user.groups_id.ids, "Simple User should be removed from interviewer") # A Manager should not be added to the Interviewer group self.assertFalse(interviewer_group.id in self.manager_user.groups_id.ids, "Manager User should not be interviewer") applicant.interviewer_ids = self.manager_user.ids self.assertFalse(interviewer_group.id in self.manager_user.groups_id.ids, "Manager User should not be added in Interviewer group") def test_interviewer_access_rights(self): applicant = self.env['hr.applicant'].create({ 'name': 'toto', 'partner_name': 'toto', 'job_id': self.job.id, }) with self.assertRaises(AccessError): applicant.with_user(self.interviewer_user).read() applicant = self.env['hr.applicant'].create({ 'name': 'toto', 'partner_name': 'toto', 'job_id': self.job.id, 'interviewer_ids': self.interviewer_user.ids, }) applicant.with_user(self.interviewer_user).read() self.job.interviewer_ids = self.interviewer_user.ids applicant = self.env['hr.applicant'].create({ 'name': 'toto', 'partner_name': 'toto', 'job_id': self.job.id, }) applicant.with_user(self.interviewer_user).read() # An interviewer can change the interviewers applicant.with_user(self.interviewer_user).interviewer_ids = self.simple_user.ids self.assertEqual(self.simple_user, applicant.interviewer_ids) with self.assertRaises(AccessError): applicant.with_user(self.interviewer_user).create_employee_from_applicant() def test_interviewer_chatter(self): self.manager_user.notification_type = 'email' self.interviewer_user.notification_type = 'email' applicant = self.env['hr.applicant'].create({ 'name': 'toto', 'partner_name': 'toto', 'job_id': self.job.id, 'interviewer_ids': self.interviewer_user.ids, }) applicant.message_subscribe(partner_ids=[self.interviewer_user.partner_id.id]) with self.mock_mail_gateway(): message = applicant.message_post(body='A super secret message', message_type='comment', subtype_xmlid='mail.mt_comment') with self.assertRaises(AccessError): message.with_user(self.interviewer_user).read() try: self._find_mail_mail_wpartners(self.interviewer_user.partner_id, None) except AssertionError: pass else: raise AssertionError('No mail.mail should be sent to members of Interviewer group') self.assertSentEmail(self.env.user.partner_id, [self.manager_user.partner_id])