mirror of
https://github.com/bringout/oca-ocb-test.git
synced 2026-04-20 11:02:08 +02:00
Initial commit: Test packages
This commit is contained in:
commit
080accd21c
338 changed files with 32413 additions and 0 deletions
|
|
@ -0,0 +1,44 @@
|
|||
# -*- coding: utf-8 -*-
|
||||
# Part of Odoo. See LICENSE file for full copyright and licensing details.
|
||||
|
||||
import logging
|
||||
import time
|
||||
import pytz
|
||||
|
||||
from datetime import datetime
|
||||
from dateutil.relativedelta import relativedelta
|
||||
|
||||
from odoo.tests import TransactionCase, warmup
|
||||
|
||||
_logger = logging.getLogger(__name__)
|
||||
|
||||
class TestResourcePerformance(TransactionCase):
|
||||
|
||||
@warmup
|
||||
def test_performance_attendance_intervals_batch(self):
|
||||
# Tests the performance of _attendance_intervals_batch with a batch of 100 resources
|
||||
calendar = self.env['resource.calendar'].create({
|
||||
'name': 'Calendar',
|
||||
})
|
||||
resources = self.env['resource.test'].create([
|
||||
{
|
||||
'name': 'Resource ' + str(i),
|
||||
'resource_calendar_id': calendar.id,
|
||||
}
|
||||
for i in range(100)
|
||||
])
|
||||
with self.assertQueryCount(__system__=1):
|
||||
# Generate attendances for a whole year
|
||||
start = pytz.utc.localize(datetime.now() + relativedelta(month=1, day=1))
|
||||
stop = pytz.utc.localize(datetime.now() + relativedelta(month=12, day=31))
|
||||
start_time = time.time()
|
||||
calendar._attendance_intervals_batch(start, stop, resources=resources)
|
||||
_logger.info('Attendance Intervals Batch (100): --- %s seconds ---', time.time() - start_time)
|
||||
# Before
|
||||
#INFO master test_performance: Attendance Intervals Batch (100): --- 2.0667169094085693 seconds ---
|
||||
#INFO master test_performance: Attendance Intervals Batch (100): --- 2.0868310928344727 seconds ---
|
||||
#INFO master test_performance: Attendance Intervals Batch (100): --- 1.9209258556365967 seconds ---
|
||||
#INFO master test_performance: Attendance Intervals Batch (100): --- 1.9474620819091797 seconds ---
|
||||
# After
|
||||
#INFO master test_performance: Attendance Intervals Batch (100): --- 0.4092371463775635 seconds ---
|
||||
#INFO master test_performance: Attendance Intervals Batch (100): --- 0.3598649501800537 seconds ---
|
||||
Loading…
Add table
Add a link
Reference in a new issue