Odoo18-Base/addons/hr_recruitment/tests/test_recruitment.py
2025-01-06 10:57:38 +07:00

150 lines
6.5 KiB
Python

# -*- coding: utf-8 -*-
# Part of Odoo. See LICENSE file for full copyright and licensing details.
from odoo.tests import tagged, TransactionCase
@tagged('recruitment')
class TestRecruitment(TransactionCase):
def test_infer_applicant_lang_from_context(self):
# Prerequisites
self.env['res.lang']._activate_lang('pl_PL')
self.env['res.lang']._activate_lang('en_US')
self.env['ir.default'].set('res.partner', 'lang', 'en_US')
# Creating an applicant will create a partner (email_from inverse)
candidate = self.env['hr.candidate'].sudo().with_context(lang='pl_PL').create({
'partner_name': 'Test Applicant', 'email_from': "test_aplicant@example.com"
})
applicant = self.env['hr.applicant'].sudo().with_context(lang='pl_PL').create({
'candidate_id': candidate.id,
})
self.assertEqual(applicant.partner_id.lang, 'pl_PL', 'Context langague not used for partner creation')
def test_duplicate_email(self):
# Tests that duplicate email match ignores case
# And that no match is found when there is none
dup1, dup2, no_dup = self.env['hr.applicant'].create([
{
'candidate_id': self.env['hr.candidate'].create({'partner_name': 'Application 1'}).id,
'partner_name': 'Application 1',
'email_from': 'laurie.poiret@aol.ru',
},
{
'candidate_id': self.env['hr.candidate'].create({'partner_name': 'Application 2'}).id,
'partner_name': 'Application 2',
'email_from': 'laurie.POIRET@aol.ru',
},
{
'candidate_id': self.env['hr.candidate'].create({'partner_name': 'Application 3'}).id,
'partner_name': 'Application 3',
'email_from': 'laure.poiret@aol.ru',
},
])
self.assertEqual(dup1.candidate_id.similar_candidates_count, 1)
self.assertEqual(dup2.candidate_id.similar_candidates_count, 1)
self.assertEqual(no_dup.candidate_id.similar_candidates_count, 0)
def test_similar_candidates_count(self):
""" Test that we find same candidates based on simmilar mail,
phone or mobile phone.
"""
A, B, C, D, E, _ = self.env['hr.applicant'].create([
{
'active': False, # Refused/archived application should still count
'candidate_id': self.env['hr.candidate'].create({
'partner_name': 'Application A',
'email_from': 'abc@odoo.com',
'partner_phone': '123',
}).id,
},
{
'candidate_id': self.env['hr.candidate'].create({
'partner_name': 'Application B',
'partner_phone': '456',
}).id,
},
{
'candidate_id': self.env['hr.candidate'].create({
'partner_name': 'Application C',
'email_from': 'def@odoo.com',
'partner_phone': '123',
}).id,
},
{
'candidate_id': self.env['hr.candidate'].create({
'partner_name': 'Application D',
'email_from': 'abc@odoo.com',
'partner_phone': '456',
}).id,
},
{
'candidate_id': self.env['hr.candidate'].create({
'partner_name': 'Application E',
'partner_phone': '',
}).id,
},
{
'candidate_id': self.env['hr.candidate'].create({
'partner_name': 'Application F',
}).id,
},
])
self.assertEqual(A.candidate_id.similar_candidates_count, 2) # C, D
self.assertEqual(B.candidate_id.similar_candidates_count, 1) # D, F
self.assertEqual(C.candidate_id.similar_candidates_count, 1) # A, D
self.assertEqual(D.candidate_id.similar_candidates_count, 2) # A, B, C
self.assertEqual(E.candidate_id.similar_candidates_count, 0) # Should not match with G
def test_application_no_partner_duplicate(self):
""" Test that when applying, the existing partner
doesn't get duplicated.
"""
applicant_data = {
'candidate_id': self.env['hr.candidate'].create({'partner_name': 'Test - CEO'}).id,
'partner_name': 'Test',
'email_from': 'test@thisisatest.com',
}
# First application, a partner should be created
self.env['hr.applicant'].create(applicant_data)
partner_count = self.env['res.partner'].search_count([('email', '=', 'test@thisisatest.com')])
self.assertEqual(partner_count, 1)
# Second application, no partner should be created
self.env['hr.applicant'].create(applicant_data)
partner_count = self.env['res.partner'].search_count([('email', '=', 'test@thisisatest.com')])
self.assertEqual(partner_count, 1)
def test_applicant_refuse_reason(self):
refuse_reason = self.env['hr.applicant.refuse.reason'].create([{'name': 'Fired'}])
dup1, dup2, no_dup = self.env['hr.applicant'].create([
{
'candidate_id': self.env['hr.candidate'].create({'partner_name': 'Application 1'}).id,
'partner_name': 'Laurie Poiret',
'email_from': 'laurie.poiret@aol.ru',
},
{
'candidate_id': self.env['hr.candidate'].create({'partner_name': 'Application 2'}).id,
'partner_name': 'Laurie Poiret (lap)',
'email_from': 'laurie.POIRET@aol.ru',
},
{
'candidate_id': self.env['hr.candidate'].create({'partner_name': 'Application 3'}).id,
'partner_name': 'Mitchell Admin',
'email_from': 'mitchell_admin@example.com',
},
])
applicant_get_refuse_reason = self.env['applicant.get.refuse.reason'].create([{
'refuse_reason_id': refuse_reason.id,
'applicant_ids': [dup1.id],
'duplicates': True
}])
applicant_get_refuse_reason.action_refuse_reason_apply()
self.assertFalse(self.env['hr.applicant'].search([('email_from', 'ilike', 'laurie.poiret@aol.ru')]))
self.assertEqual(
self.env['hr.applicant'].search([('email_from', 'ilike', 'mitchell_admin@example.com')]),
no_dup
)