2008-04-30 18:39:13 +00:00
|
|
|
|
|
|
|
from twisted.trial import unittest
|
|
|
|
from twisted.application import service
|
|
|
|
from allmydata.stats import CPUUsageMonitor
|
2008-10-29 04:15:48 +00:00
|
|
|
from allmydata.util import testutil, pollmixin
|
2008-04-30 18:39:13 +00:00
|
|
|
|
|
|
|
class FasterMonitor(CPUUsageMonitor):
|
|
|
|
POLL_INTERVAL = 0.1
|
|
|
|
|
|
|
|
|
2008-10-29 04:15:48 +00:00
|
|
|
class CPUUsage(unittest.TestCase, pollmixin.PollMixin, testutil.StallMixin):
|
2008-04-30 18:39:13 +00:00
|
|
|
def setUp(self):
|
|
|
|
self.s = service.MultiService()
|
|
|
|
self.s.startService()
|
|
|
|
|
|
|
|
def tearDown(self):
|
|
|
|
return self.s.stopService()
|
|
|
|
|
|
|
|
def test_monitor(self):
|
|
|
|
m = FasterMonitor()
|
|
|
|
s = m.get_stats() # before it has been started
|
|
|
|
self.failIf("cpu_monitor.1min_avg" in s)
|
|
|
|
m.setServiceParent(self.s)
|
|
|
|
def _poller():
|
|
|
|
return bool(len(m.samples) == m.HISTORY_LENGTH+1)
|
|
|
|
d = self.poll(_poller)
|
2008-04-30 18:52:31 +00:00
|
|
|
# pause one more second, to make sure that the history-trimming code
|
|
|
|
# is exercised
|
|
|
|
d.addCallback(self.stall, 1.0)
|
2008-04-30 18:39:13 +00:00
|
|
|
def _check(res):
|
|
|
|
s = m.get_stats()
|
|
|
|
self.failUnless("cpu_monitor.1min_avg" in s)
|
|
|
|
self.failUnless("cpu_monitor.5min_avg" in s)
|
|
|
|
self.failUnless("cpu_monitor.15min_avg" in s)
|
|
|
|
self.failUnless("cpu_monitor.total" in s)
|
|
|
|
d.addCallback(_check)
|
|
|
|
return d
|
|
|
|
|