Commit e897dfa8 authored by Hanno Schlichting's avatar Hanno Schlichting

Fill in more tests for the plan

parent a9e41899
...@@ -251,7 +251,7 @@ class CatalogPlan(object): ...@@ -251,7 +251,7 @@ class CatalogPlan(object):
self.init_timer() self.init_timer()
self.start_time = time.time() self.start_time = time.time()
def start_split(self, name, result=None): def start_split(self, name):
self.interim[name] = Duration(time.time(), None) self.interim[name] = Duration(time.time(), None)
def stop_split(self, name, result=None, limit=False): def stop_split(self, name, result=None, limit=False):
......
...@@ -12,6 +12,7 @@ ...@@ -12,6 +12,7 @@
############################################################################## ##############################################################################
import os import os
import time
import unittest import unittest
from zope.testing import cleanup from zope.testing import cleanup
...@@ -194,25 +195,89 @@ class TestCatalogPlan(cleanup.CleanUp, unittest.TestCase): ...@@ -194,25 +195,89 @@ class TestCatalogPlan(cleanup.CleanUp, unittest.TestCase):
def setUp(self): def setUp(self):
cleanup.CleanUp.setUp(self) cleanup.CleanUp.setUp(self)
from Products.ZCatalog.ZCatalog import ZCatalog from Products.ZCatalog.Catalog import Catalog
self.zcat = ZCatalog('catalog') self.cat = Catalog('catalog')
self.zcat.long_query_time = 0.0
self.zcat.addIndex('num', 'FieldIndex')
self.zcat.addIndex('big', 'FieldIndex')
self.zcat.addIndex('numbers', 'KeywordIndex')
for i in range(9): def _makeOne(self, catalog=None, query=None):
obj = dummy(i) from ..plan import CatalogPlan
self.zcat.catalog_object(obj, str(i)) if catalog is None:
catalog = self.cat
return CatalogPlan(catalog, query=query)
def test_get_id(self):
plan = self._makeOne()
self.assertEquals(plan.get_id(), ('', 'NonPersistentCatalog'))
def test_get_id_persistent(self):
from Products.ZCatalog.ZCatalog import ZCatalog
zcat = ZCatalog('catalog')
plan = self._makeOne(zcat._catalog)
self.assertEquals(plan.get_id(), ('catalog',))
def test_plan_empty(self):
plan = self._makeOne()
self.assertEquals(plan.plan(), None)
def test_start(self):
plan = self._makeOne()
plan.start()
self.assert_(plan.start_time <= time.time())
def test_start_split(self):
plan = self._makeOne()
plan.start_split('index1')
self.assert_('index1' in plan.interim)
def test_stop_split(self):
plan = self._makeOne()
plan.start_split('index1')
plan.stop_split('index1')
self.assert_('index1' in plan.interim)
i1 = plan.interim['index1']
self.assert_(i1.start <= i1.end)
self.assert_('index1' in plan.benchmark)
def test_stop_split_sort_on(self):
plan = self._makeOne()
plan.start_split('sort_on')
plan.stop_split('sort_on')
self.assert_('sort_on' in plan.interim)
so = plan.interim['sort_on']
self.assert_(so.start <= so.end)
self.assert_('sort_on' not in plan.benchmark)
def test_stop(self):
plan = self._makeOne(query={'index1': 1, 'index2': 2})
plan.start()
plan.start_split('index1')
plan.stop_split('index1')
plan.start_split('index1')
plan.stop_split('index1')
plan.start_split('sort_on')
plan.stop_split('sort_on')
plan.stop()
self.assert_(plan.duration > 0)
self.assert_('index1' in plan.benchmark)
self.assertEquals(plan.benchmark['index1'].hits, 2)
self.assert_('index2' in plan.benchmark)
self.assertEquals(plan.benchmark['index2'].hits, 0)
self.assertEquals(set(plan.plan()), set(('index1', 'index2')))
def test_log(self):
plan = self._makeOne(query={'index1': 1})
plan.threshold = 0.0
plan.start()
plan.start_split('index1')
plan.stop_split('index1')
plan.stop()
plan.log()
report = plan.report()
self.assertEquals(len(report), 1)
self.assertEquals(report[0]['counter'], 2)
plan.reset()
self.assertEquals(len(plan.report()), 0)
# get_id
# init_timer
# plan
# start
# start_split
# stop_split
# stop
# log
class TestCatalogReport(cleanup.CleanUp, unittest.TestCase): class TestCatalogReport(cleanup.CleanUp, unittest.TestCase):
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment