|
Server : Apache/2.2.2 (Fedora) System : Linux App1.pathumtani.go.th 2.6.20-1.2320.fc5smp #1 SMP Tue Jun 12 19:40:16 EDT 2007 i686 User : apache ( 48) PHP Version : 5.2.9 Disable Function : NONE Directory : /proc/self/root/proc/self/root/usr/lib/python2.4/site-packages/mx/DateTime/mxDateTime/ |
Upload File : |
#!/usr/local/bin/python -u
from mx.DateTime import *
from mx.DateTime import __version__
import time,sys,traceback
print 'Testing mxDateTime version',__version__
print
if not __debug__:
print '*** You have to run the test suite in non-optimized mode !'
print
sys.exit(1)
# wintertime
t = winter = DateTimeFromAbsDateTime(729368,55931.522913)
print t
print repr(t)
x = float(t)
print 'as ticks:',x
print 'time.gmtime:',time.gmtime(x),'(note the seconds)'
print 'time.localtime:',time.localtime(x)
print 'tuple:',t.tuple()
print
# summertime
t = summer = DateTimeFromAbsDateTime(729200,55931.522913)
print t
print repr(t)
x = float(t)
print 'as ticks:',x
print 'time.gmtime:',time.gmtime(x),'(note the seconds)'
print 'time.localtime:',time.localtime(x)
print 'tuple:',t.tuple()
print
t = Timestamp(1900,1,1,12,23,34.5)
print t
assert t.tuple()[:6] == (1900,1,1,12,23,34.5)
t = DateTimeFromCOMDate(12345.6)
print t
assert t.COMDate() == 12345.6
t = DateTimeFromCOMDate(-12345.6)
print t
assert t.COMDate() == -12345.6
x = time.time()
print 'ticks:',x,'localtime:',time.localtime(x)
t = DateTimeFromTicks(x)
print t.tuple(), t.absdate, t.abstime
assert t.ticks() == x
print
# Python Number protocol:
t1 = Date(1997,12,31)
t2 = Date(1997,12,30)
d = t2 - t1
try:
t1 + t2
except TypeError:
pass
try:
t2 * t1
except TypeError:
pass
try:
t2 / t1
except TypeError:
pass
print 'Number protocol ok.'
print
# Deltas
assert DateTimeDelta(2,1,-1,-3).tuple() == (2, 0, 58, 57.0)
assert DateTimeDelta(2,0,-1,-3).tuple() == (1, 23, 58, 57.0)
assert DateTime(1998,1,9) + DateTimeDelta(-1) == DateTime(1998,1,8)
assert DateTime(1998,1,9) - DateTimeDelta(1) == DateTime(1998,1,8)
assert DateTime(1998,1,9) - DateTimeDelta(1.5) == DateTime(1998,1,7,12,0,0)
assert DateTime(1998,1,9) - DateTime(1969,4,6) == DateTimeDelta(10505)
assert DateTimeDelta(10000) / (DateTimeDelta(10000) * 0.5) == 2.0
assert DateTime(2000,12,31) + DateTimeDelta(1) == DateTime(2001, 1, 1)
assert DateTime(2000,12,31) + DateTimeDelta(2) == DateTime(2001, 1, 2)
assert DateTime(2000,12,31) + 1 == DateTime(2001, 1, 1)
assert DateTime(2000,12,31) + 2 == DateTime(2001, 1, 2)
a = Date(2000,11,9)
b = Date(2000,11,10)
assert (b-a).seconds == 86400.0
assert (b-a).day == 1
assert (b-a).hour == 0
assert (b-a).second == 0
print 'Deltas ok.'
print
# UTC vs. local time
t = DateTime(2000,11,17)
print 'UTC -> local time -> UTC'
for i in range(24*365):
x = t + 0.041666*i
try:
try:
assert cmp(x.gmtime().localtime(), x, 0.001) == 0
except AssertionError:
print ' Problem (local time) -- DST switching time ?:'
print ' %s -> %s -> %s' % \
(x, x.gmtime(), x.gmtime().localtime())
try:
assert cmp(x.localtime().gmtime(), x, 0.001) == 0
except AssertionError:
print ' Problem (gmt time) -- DST switching time ?:'
print ' %s -> %s -> %s' % \
(x, x.localtime(), x.localtime().gmtime())
except Error, why:
print '*** Problem: %s' % x
print 'ok.'
# Rounding problems with COM dates
t = DateTime(1998, 2, 24, 12, 40, 11)
c = DateTimeFromCOMDate(t.COMDate())
print 'DateTime->COM Date->DateTime rounding error:',(t == c) * 'no' or 'yes'
print 'COM Dates compare:',(t.COMDate()==c.COMDate()) * 'equal' or 'not equal'
print 'diff =',t-c,'in seconds:',t.second - c.second
print 'using cmp(,,0.5):',(cmp(t,c,0.5) == 0) * 'equal' or 'not equal'
print
# Sanity check
def testjdn(year,month,day):
# Reference taken from the Calendar FAQ (see docs for reference)
a = (14-month)/12
y = year+4800-a
m = month + 12*a - 3
# Gregorian
gJDN = day + (306*m+5)/10 + y*365 + y/4 - y/100 + y/400 - 32045
# Julian
jJDN = day + (306*m+5)/10 + y*365 + y/4 - 32083
return gJDN,jJDN
print 'Running constructor test... (this can take up to a few minutes)'
try:
if __version__ >= '1.3.0':
# New versions:
for suite in (range(-100,100),range(1900,2101)):
p = None
for year in suite:
print year,; sys.stdout.flush()
for month in range(1,13):
for day in range(1,32):
try:
t = DateTime(year,month,day,12)
jt = JulianDateTime(year,month,day,12)
ref_greg,ref_jul = testjdn(year,month,day)
except RangeError:
continue
if p:
try:
assert p + 1 == t
assert (p+1).tuple() == t.tuple()
assert t.tuple()[:3] == (year,month,day)
assert DateTimeFromAbsDateTime(t.absdate).tuple()[:3] \
== (year,month,day)
assert t.jdn == ref_greg
assert jt.jdn == ref_jul
except AssertionError:
print '*** Test failed for:'
print ' p = %s, p+1 = %s and' % (p,p+1)
print ' t = %s, jdn=%i; jdn reference = %i' % \
(t,t.jdn,ref_greg)
print ' jt = %s, jdn=%i; jdn reference = %i' % \
(jt,jt.jdn,ref_jul)
print
traceback.print_exc()
print
sys.exit(1)
p = t
print
else:
# Old versions and experimental Python version:
for suite in (range(1900,2101),):
p = None
for year in suite:
print year,; sys.stdout.flush()
for month in range(1,13):
for day in range(1,32):
try:
t = DateTime(year,month,day,12)
ref_greg,ref_jul = testjdn(year,month,day)
except RangeError:
continue
if p:
try:
assert p + 1 == t
assert (p+1).tuple() == t.tuple()
assert t.tuple()[:3] == (year,month,day)
assert DateTimeFromAbsDateTime(t.absdate).tuple()[:3] \
== (year,month,day)
assert t.jdn == ref_greg
except AssertionError:
print '*** Test failed for:'
print ' p = %s, p+1 = %s and' % (p,p+1)
print ' t = %s, jdn=%i; jdn reference = %i' % \
(t,t.jdn,ref_greg)
print
traceback.print_exc()
print
sys.exit(1)
p = t
print
except KeyboardInterrupt:
print
print 'Interrupted.'
else:
print 'Date construction works.'
print
# Non zero testing
if t:
print 'Non zero testing works.'
# ticks and dst
print 'Converting ticks and DST handling.'
try:
summer.ticks(0,0)
winter.ticks(0,0)
summer.ticks(0,1)
winter.ticks(0,1)
except SystemError:
print
print '-'*72
print 'WARNING:'
print
print 'The mktime() C API on your platform does not support'
print 'setting the DST flag to anything other than -1. This'
print 'will cause the datetime.ticks() method to raise an'
print 'error in case you pass a DST flag other than -1.'
print '-'*72
# Sanity checks
date1 = Date(2000,11,1) + \
RelativeDateTime(day=1,month=1,hour=0,minute=0,second=0)
date2 = Date(2000,11,1) + \
RelativeDateTime(day=1,month=6,hour=0,minute=0,second=0)
print '%.15f == %.15f ?' % (date1.ticks(), time.mktime(date1.tuple()))
print '%.15f == %.15f ?' % (date2.ticks(), time.mktime(date2.tuple()))
try:
assert date1.ticks() == time.mktime(date1.tuple())
assert date2.ticks() == time.mktime(date2.tuple())
except AssertionError:
print
print '-'*72
print 'WARNING:'
print
print 'Conversion from mx.DateTime instances to ticks is not relyable'
print 'on your platform. Please run "python testticks.py" and send'
print 'the output to the author at mal@lemburg.com.'
print
print '-'*72
print '%s == %s ?' % \
(time.localtime(time.mktime(date1.tuple()))[:6],
date1.tuple()[:6])
print '%s == %s ?' % \
(time.localtime(time.mktime(date2.tuple()))[:6],
date2.tuple()[:6])
try:
assert time.localtime(time.mktime(date1.tuple()))[:6] == \
date1.tuple()[:6]
assert time.localtime(time.mktime(date2.tuple()))[:6] == \
date2.tuple()[:6]
except AssertionError:
print
print '-'*72
print 'WARNING:'
print
print 'time.localtime() and time.mktime() are not inverse functions'
print 'on your platform. This may lead to strange results in some'
print 'applications. Please run "python testticks.py" and send'
print 'the output to the author at mal@lemburg.com.'
print
print '-'*72
print
# timegm() emulation
print 'Testing .gmticks()... (this can take up to a few minutes)'
t = start = 920710000
stop = 2140240000
oops = 0
try:
while 1:
if t % 10000 < 20:
print t,
d = apply(DateTime,time.gmtime(t)[:6])
try:
x = d.gmticks()
except Error:
break
if x != t:
print ' Ooops:',d,'t =',t,'diff =',x-t
oops = oops + 1
try:
t = t + 10011
except OverflowError:
break
else:
if t > stop:
break
except KeyboardInterrupt:
print
print 'Interrupted.'
else:
print
print ' Tested ticks range %i to %i.' % (start,t)
assert oops == 0
print '...Works.'
print
# Try importing a subpackage
print 'Importing subpackage Feasts.'
print
from mx.DateTime import Feasts
try:
Feasts._test()
except SystemError:
print '-'*72
print 'WARNING:'
print
print 'Subpackges ISO and ARPA will not work on your platform because'
print 'mxDateTime found no working API to query the timezone'
print 'for a given date/time. Please run "python testticks.py" and send'
print 'the output to the author at mal@lemburg.com.'
print
print '-'*72
print
# Run parser tests
print 'Importing subpackage Parser.'
print
from mx.DateTime import Parser
Parser._test()
print
print 'Works.'