2018-01-16 11:28:15 +05:30
|
|
|
# -*- coding: utf-8 -*-
|
2018-01-16 02:34:37 -08:00
|
|
|
# Part of Odoo, Flectra. See LICENSE file for full copyright and licensing details.
|
2018-01-16 11:28:15 +05:30
|
|
|
|
|
|
|
import time
|
|
|
|
|
2018-01-16 02:34:37 -08:00
|
|
|
from flectra.tests.common import TransactionCase
|
2018-01-16 11:28:15 +05:30
|
|
|
from dateutil import relativedelta
|
|
|
|
import datetime
|
|
|
|
|
|
|
|
class TestEquipment(TransactionCase):
|
|
|
|
""" Test used to check that when doing equipment/maintenance_request/equipment_category creation."""
|
|
|
|
|
|
|
|
def setUp(self):
|
|
|
|
super(TestEquipment, self).setUp()
|
|
|
|
self.equipment = self.env['maintenance.equipment']
|
|
|
|
self.maintenance_request = self.env['maintenance.request']
|
|
|
|
self.res_users = self.env['res.users']
|
|
|
|
self.maintenance_team = self.env['maintenance.team']
|
|
|
|
self.main_company = self.env.ref('base.main_company')
|
|
|
|
res_user = self.env.ref('base.group_user')
|
|
|
|
res_manager = self.env.ref('maintenance.group_equipment_manager')
|
|
|
|
|
|
|
|
self.user = self.res_users.create(dict(
|
|
|
|
name="Normal User/Employee",
|
|
|
|
company_id=self.main_company.id,
|
|
|
|
login="emp",
|
|
|
|
password="emp",
|
|
|
|
email="empuser@yourcompany.example.com",
|
|
|
|
groups_id=[(6, 0, [res_user.id])]
|
|
|
|
))
|
|
|
|
|
|
|
|
self.manager = self.res_users.create(dict(
|
|
|
|
name="Equipment Manager",
|
|
|
|
company_id=self.main_company.id,
|
|
|
|
login="hm",
|
|
|
|
password="hm",
|
|
|
|
email="eqmanager@yourcompany.example.com",
|
|
|
|
groups_id=[(6, 0, [res_manager.id])]
|
|
|
|
))
|
|
|
|
|
|
|
|
def test_10_equipment_request_category(self):
|
|
|
|
|
|
|
|
# Create a new equipment
|
|
|
|
equipment_01 = self.equipment.sudo(self.manager).create({
|
|
|
|
'name': 'Samsung Monitor "15',
|
|
|
|
'category_id': self.ref('maintenance.equipment_monitor'),
|
|
|
|
'technician_user_id': self.ref('base.user_root'),
|
|
|
|
'owner_user_id': self.user.id,
|
|
|
|
'assign_date': time.strftime('%Y-%m-%d'),
|
|
|
|
'serial_no': 'MT/127/18291015',
|
|
|
|
'model': 'NP355E5X',
|
|
|
|
'color': 3,
|
|
|
|
})
|
|
|
|
|
|
|
|
# Check that equipment is created or not
|
|
|
|
assert equipment_01, "Equipment not created"
|
|
|
|
|
|
|
|
# Create new maintenance request
|
|
|
|
maintenance_request_01 = self.maintenance_request.sudo(self.user).create({
|
|
|
|
'name': 'Resolution is bad',
|
|
|
|
'technician_user_id': self.user.id,
|
|
|
|
'owner_user_id': self.user.id,
|
|
|
|
'equipment_id': equipment_01.id,
|
|
|
|
'color': 7,
|
|
|
|
'stage_id': self.ref('maintenance.stage_0'),
|
|
|
|
'maintenance_team_id': self.ref('maintenance.equipment_team_maintenance')
|
|
|
|
})
|
|
|
|
|
|
|
|
# I check that maintenance_request is created or not
|
|
|
|
assert maintenance_request_01, "Maintenance Request not created"
|
|
|
|
|
|
|
|
# I check that Initially maintenance request is in the "New Request" stage
|
|
|
|
self.assertEquals(maintenance_request_01.stage_id.id, self.ref('maintenance.stage_0'))
|
|
|
|
|
|
|
|
# I check that change the maintenance_request stage on click statusbar
|
|
|
|
maintenance_request_01.sudo(self.user).write({'stage_id': self.ref('maintenance.stage_1')})
|
|
|
|
|
|
|
|
# I check that maintenance request is in the "In Progress" stage
|
|
|
|
self.assertEquals(maintenance_request_01.stage_id.id, self.ref('maintenance.stage_1'))
|
|
|
|
|
|
|
|
def test_20_cron(self):
|
|
|
|
""" Check the cron creates the necessary preventive maintenance requests"""
|
|
|
|
equipment_cron = self.equipment.create({
|
|
|
|
'name': 'High Maintenance Monitor because of Color Calibration',
|
|
|
|
'category_id': self.ref('maintenance.equipment_monitor'),
|
|
|
|
'technician_user_id': self.ref('base.user_root'),
|
|
|
|
'owner_user_id': self.user.id,
|
|
|
|
'assign_date': time.strftime('%Y-%m-%d'),
|
|
|
|
'period': 7,
|
|
|
|
'color': 3,
|
|
|
|
})
|
|
|
|
|
|
|
|
maintenance_request_cron = self.maintenance_request.create({
|
|
|
|
'name': 'Need a special calibration',
|
|
|
|
'technician_user_id': self.user.id,
|
|
|
|
'request_date': (datetime.datetime.now() + relativedelta.relativedelta(days=7)).strftime('%Y-%m-%d'),
|
|
|
|
'maintenance_type': 'preventive',
|
|
|
|
'owner_user_id': self.user.id,
|
|
|
|
'equipment_id': equipment_cron.id,
|
|
|
|
'color': 7,
|
|
|
|
'stage_id': self.ref('maintenance.stage_0'),
|
|
|
|
'maintenance_team_id': self.ref('maintenance.equipment_team_maintenance')
|
|
|
|
})
|
|
|
|
|
|
|
|
self.env['maintenance.equipment']._cron_generate_requests()
|
|
|
|
# As it is generating the requests for one month in advance, we should have 4 requests in total
|
|
|
|
tot_requests = self.maintenance_request.search([('equipment_id', '=', equipment_cron.id)])
|
|
|
|
self.assertEqual(len(tot_requests), 1, 'The cron should have generated just 1 request for the High Maintenance Monitor.')
|
|
|
|
|
|
|
|
def test_21_cron(self):
|
|
|
|
""" Check the creation of maintenance requests by the cron"""
|
|
|
|
|
|
|
|
team_test = self.maintenance_team.create({
|
|
|
|
'name': 'team_test',
|
|
|
|
})
|
|
|
|
equipment = self.equipment.create({
|
|
|
|
'name': 'High Maintenance Monitor because of Color Calibration',
|
|
|
|
'category_id': self.ref('maintenance.equipment_monitor'),
|
|
|
|
'technician_user_id': self.ref('base.user_root'),
|
|
|
|
'owner_user_id': self.user.id,
|
|
|
|
'assign_date': time.strftime('%Y-%m-%d'),
|
|
|
|
'period': 7,
|
|
|
|
'color': 3,
|
|
|
|
'maintenance_team_id': team_test.id,
|
|
|
|
'maintenance_duration': 3.0,
|
|
|
|
})
|
|
|
|
|
|
|
|
self.env['maintenance.equipment']._cron_generate_requests()
|
|
|
|
tot_requests = self.maintenance_request.search([('equipment_id', '=', equipment.id)])
|
|
|
|
self.assertEqual(len(tot_requests), 1, 'The cron should have generated just 1 request for the High Maintenance Monitor.')
|
|
|
|
self.assertEqual(tot_requests.maintenance_team_id.id, team_test.id, 'The maintenance team should be the same as equipment one')
|
|
|
|
self.assertEqual(tot_requests.duration, 3.0, 'Equipement maintenance duration is not the same as the request one')
|