2012-03-24 13:32:11 -04:00
|
|
|
import nilmdb
|
|
|
|
from nilmdb.printf import *
|
|
|
|
|
|
|
|
import datetime_tz
|
|
|
|
|
|
|
|
from nose.tools import *
|
|
|
|
from nose.tools import assert_raises
|
|
|
|
import os
|
|
|
|
import sys
|
2012-03-24 17:15:24 -04:00
|
|
|
import cStringIO
|
2012-03-24 13:32:11 -04:00
|
|
|
|
2012-04-09 17:31:39 -04:00
|
|
|
from test_helpers import *
|
2012-03-24 13:32:11 -04:00
|
|
|
|
|
|
|
class TestTimestamper(object):
|
|
|
|
|
2012-03-24 17:15:24 -04:00
|
|
|
# Not a very comprehensive test, but it's good enough.
|
2012-04-09 17:31:39 -04:00
|
|
|
|
2012-03-24 13:32:11 -04:00
|
|
|
def test_timestamper(self):
|
2012-03-24 17:15:24 -04:00
|
|
|
def join(list):
|
|
|
|
return "\n".join(list) + "\n"
|
2012-03-24 13:32:11 -04:00
|
|
|
|
2012-03-24 17:15:24 -04:00
|
|
|
start = datetime_tz.datetime_tz.smartparse("03/24/2012").totimestamp()
|
2012-03-26 18:28:33 -04:00
|
|
|
lines_in = [ "hello", "world", "hello world", "# commented out" ]
|
2012-03-24 17:15:24 -04:00
|
|
|
lines_out = [ "1332561600.000000 hello",
|
|
|
|
"1332561600.000125 world",
|
|
|
|
"1332561600.000250 hello world" ]
|
2012-03-24 13:32:11 -04:00
|
|
|
|
2012-03-24 17:15:24 -04:00
|
|
|
# full
|
|
|
|
input = cStringIO.StringIO(join(lines_in))
|
|
|
|
ts = nilmdb.timestamper.TimestamperRate(input, start, 8000)
|
|
|
|
foo = ts.readlines()
|
|
|
|
eq_(foo, join(lines_out))
|
2012-04-09 17:31:39 -04:00
|
|
|
in_("TimestamperRate(..., start=", str(ts))
|
2012-03-24 17:15:24 -04:00
|
|
|
|
|
|
|
# first 30 or so bytes means the first 2 lines
|
|
|
|
input = cStringIO.StringIO(join(lines_in))
|
|
|
|
ts = nilmdb.timestamper.TimestamperRate(input, start, 8000)
|
|
|
|
foo = ts.readlines(30)
|
|
|
|
eq_(foo, join(lines_out[0:2]))
|
|
|
|
|
|
|
|
# stop iteration early
|
|
|
|
input = cStringIO.StringIO(join(lines_in))
|
|
|
|
ts = nilmdb.timestamper.TimestamperRate(input, start, 8000,
|
|
|
|
1332561600.000200)
|
|
|
|
foo = ""
|
|
|
|
for line in ts:
|
|
|
|
foo += line
|
|
|
|
eq_(foo, join(lines_out[0:2]))
|
|
|
|
|
|
|
|
# stop iteration early (readlines)
|
|
|
|
input = cStringIO.StringIO(join(lines_in))
|
|
|
|
ts = nilmdb.timestamper.TimestamperRate(input, start, 8000,
|
|
|
|
1332561600.000200)
|
|
|
|
foo = ts.readlines()
|
|
|
|
eq_(foo, join(lines_out[0:2]))
|
|
|
|
|
|
|
|
# stop iteration really early
|
|
|
|
input = cStringIO.StringIO(join(lines_in))
|
|
|
|
ts = nilmdb.timestamper.TimestamperRate(input, start, 8000,
|
|
|
|
1332561600.000000)
|
|
|
|
foo = ts.readlines()
|
|
|
|
eq_(foo, "")
|
|
|
|
|
|
|
|
# use iterator
|
|
|
|
input = cStringIO.StringIO(join(lines_in))
|
|
|
|
ts = nilmdb.timestamper.TimestamperRate(input, start, 8000)
|
|
|
|
foo = ""
|
|
|
|
for line in ts:
|
|
|
|
foo += line
|
|
|
|
eq_(foo, join(lines_out))
|
|
|
|
|
|
|
|
# check that TimestamperNow gives similar result
|
|
|
|
input = cStringIO.StringIO(join(lines_in))
|
|
|
|
ts = nilmdb.timestamper.TimestamperNow(input)
|
|
|
|
foo = ts.readlines()
|
|
|
|
ne_(foo, join(lines_out))
|
|
|
|
eq_(len(foo), len(join(lines_out)))
|
2012-04-09 17:31:39 -04:00
|
|
|
eq_(str(ts), "TimestamperNow(...)")
|
2012-03-24 17:15:24 -04:00
|
|
|
|
|
|
|
# Test passing a file (should be empty)
|
|
|
|
ts = nilmdb.timestamper.TimestamperNow("/dev/null")
|
2012-03-24 13:32:11 -04:00
|
|
|
for line in ts:
|
2012-03-24 17:15:24 -04:00
|
|
|
raise AssertionError
|
|
|
|
ts.close()
|
2012-04-09 17:31:39 -04:00
|
|
|
|
|
|
|
# Test the null timestamper
|
|
|
|
input = cStringIO.StringIO(join(lines_out)) # note: lines_out
|
|
|
|
ts = nilmdb.timestamper.TimestamperNull(input)
|
|
|
|
foo = ts.readlines()
|
|
|
|
eq_(foo, join(lines_out))
|
|
|
|
eq_(str(ts), "TimestamperNull(...)")
|