[Checkins] SVN: zope.transaction/trunk/ TimeStamp doesn't go here. Remove duplicate README.txt.

Chris McDonough chrism at plope.com
Fri Nov 9 10:33:53 EST 2007


Log message for revision 81641:
  TimeStamp doesn't go here.  Remove duplicate README.txt.
  

Changed:
  U   zope.transaction/trunk/CHANGES.txt
  U   zope.transaction/trunk/setup.py
  D   zope.transaction/trunk/zope/transaction/README.txt
  D   zope.transaction/trunk/zope/transaction/TimeStamp.c
  D   zope.transaction/trunk/zope/transaction/tests/test_timestamp.py

-=-
Modified: zope.transaction/trunk/CHANGES.txt
===================================================================
--- zope.transaction/trunk/CHANGES.txt	2007-11-09 15:19:56 UTC (rev 81640)
+++ zope.transaction/trunk/CHANGES.txt	2007-11-09 15:33:52 UTC (rev 81641)
@@ -1,12 +1,9 @@
 1.0 
 
-  Initial release.
+  Initial release, branched from HEAD of ZODB on Nov. 8 2007 (aka
+  "3.9.0dev").
 
   Remove (deprecated) support for beforeCommitHook alias to
   addBeforeCommitHook.
 
   Add weakset tests.
-
-  Add TimeStamp tests.
-
-

Modified: zope.transaction/trunk/setup.py
===================================================================
--- zope.transaction/trunk/setup.py	2007-11-09 15:19:56 UTC (rev 81640)
+++ zope.transaction/trunk/setup.py	2007-11-09 15:33:52 UTC (rev 81641)
@@ -19,7 +19,7 @@
 from ez_setup import use_setuptools
 use_setuptools()
 
-from setuptools import setup, find_packages, Extension
+from setuptools import setup, find_packages
 
 here = os.path.abspath(os.path.dirname(__file__))
 README = open(os.path.join(here, 'README.txt')).read()
@@ -43,10 +43,6 @@
       license="ZPL 2.1",
       platforms=["any"],
       packages=find_packages(),
-      ext_modules = [
-            Extension('zope.transaction.TimeStamp',
-                      ['zope/transaction/TimeStamp.c']),
-            ],
       include_package_data=True,
       zip_safe=False,
       test_suite="zope.transaction.tests",

Deleted: zope.transaction/trunk/zope/transaction/README.txt
===================================================================
--- zope.transaction/trunk/zope/transaction/README.txt	2007-11-09 15:19:56 UTC (rev 81640)
+++ zope.transaction/trunk/zope/transaction/README.txt	2007-11-09 15:33:52 UTC (rev 81641)
@@ -1,13 +0,0 @@
-============
-Transactions
-============
-
-This package contains a generic transaction implementation for Python. It is
-mainly used by the ZODB, though.
-
-Note that the data manager API, ``transaction.interfaces.IDataManager``,
-is syntactically simple, but semantically complex.  The semantics
-were not easy to express in the interface. This could probably use
-more work.  The semantics are presented in detail through examples of
-a sample data manager in ``transaction.tests.test_SampleDataManager``.
-

Deleted: zope.transaction/trunk/zope/transaction/TimeStamp.c
===================================================================
--- zope.transaction/trunk/zope/transaction/TimeStamp.c	2007-11-09 15:19:56 UTC (rev 81640)
+++ zope.transaction/trunk/zope/transaction/TimeStamp.c	2007-11-09 15:33:52 UTC (rev 81641)
@@ -1,437 +0,0 @@
-/*****************************************************************************
-
-  Copyright (c) 2001, 2004 Zope Corporation and Contributors.
-  All Rights Reserved.
-
-  This software is subject to the provisions of the Zope Public License,
-  Version 2.1 (ZPL).  A copy of the ZPL should accompany this distribution.
-  THIS SOFTWARE IS PROVIDED "AS IS" AND ANY AND ALL EXPRESS OR IMPLIED
-  WARRANTIES ARE DISCLAIMED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
-  WARRANTIES OF TITLE, MERCHANTABILITY, AGAINST INFRINGEMENT, AND FITNESS
-  FOR A PARTICULAR PURPOSE
-
- ****************************************************************************/
-
-#include "Python.h"
-#include <time.h>
-
-PyObject *TimeStamp_FromDate(int, int, int, int, int, double);
-PyObject *TimeStamp_FromString(const char *);
-
-static char TimeStampModule_doc[] =
-"A 64-bit TimeStamp used as a ZODB serial number.\n"
-"\n"
-"$Id: TimeStamp.c 41599 2006-02-11 21:33:49Z tseaver $\n";
-
-
-typedef struct {
-    PyObject_HEAD
-    unsigned char data[8];
-} TimeStamp;
-
-/* The first dimension of the arrays below is non-leapyear / leapyear */
-
-static char month_len[2][12]={
-  {31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31},
-  {31, 29, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31}
-};
-
-static short joff[2][12] = {
-  {0, 31, 59, 90, 120, 151, 181, 212, 243, 273, 304, 334},
-  {0, 31, 60, 91, 121, 152, 182, 213, 244, 274, 305, 335}
-};
-
-static double gmoff=0;
-
-/* TODO:  May be better (faster) to store in a file static. */
-#define SCONV ((double)60) / ((double)(1<<16)) / ((double)(1<<16))
-
-static int
-leap(int year)
-{
-    return year % 4 == 0 && (year % 100 != 0 || year % 400 == 0);
-}
-
-static int
-days_in_month(int year, int month)
-{
-    return month_len[leap(year)][month];
-}
-
-static double
-TimeStamp_yad(int y)
-{
-    double d, s;
-
-    y -= 1900;
-
-    d = (y - 1) * 365;
-    if (y > 0) {
-        s = 1.0;
-	y -= 1;
-    } else {
-	s = -1.0;
-	y = -y;
-    }
-    return d + s * (y / 4 - y / 100 + (y + 300) / 400);
-}
-
-static double
-TimeStamp_abst(int y, int mo, int d, int m, int s)
-{
-    return (TimeStamp_yad(y) + joff[leap(y)][mo] + d) * 86400 + m * 60 + s;
-}
-
-static int
-TimeStamp_init_gmoff(void)
-{
-    struct tm *t;
-    time_t z=0;
-
-    t = gmtime(&z);
-    if (t == NULL) {
-	PyErr_SetString(PyExc_SystemError, "gmtime failed");
-	return -1;
-    }
-
-    gmoff = TimeStamp_abst(t->tm_year+1900, t->tm_mon, t->tm_mday - 1,
-			   t->tm_hour * 60 + t->tm_min, t->tm_sec);
-
-    return 0;
-}
-
-static void
-TimeStamp_dealloc(TimeStamp *ts)
-{
-    PyObject_Del(ts);
-}
-
-static int
-TimeStamp_compare(TimeStamp *v, TimeStamp *w)
-{
-    int cmp = memcmp(v->data, w->data, 8);
-    if (cmp < 0) return -1;
-    if (cmp > 0) return 1;
-    return 0;
-}
-
-static long
-TimeStamp_hash(TimeStamp *self)
-{
-    register unsigned char *p = (unsigned char *)self->data;
-    register int len = 8;
-    register long x = *p << 7;
-    while (--len >= 0)
-	x = (1000003*x) ^ *p++;
-    x ^= 8;
-    if (x == -1)
-	x = -2;
-    return x;
-}
-
-typedef struct {
-    /* TODO:  reverse-engineer what's in these things and comment them */
-    int y;
-    int m;
-    int d;
-    int mi;
-} TimeStampParts;
-
-static void
-TimeStamp_unpack(TimeStamp *self, TimeStampParts *p)
-{
-    unsigned long v;
-
-    v = (self->data[0] * 16777216 + self->data[1] * 65536
-	 + self->data[2] * 256 + self->data[3]);
-    p->y = v / 535680 + 1900;
-    p->m = (v % 535680) / 44640 + 1;
-    p->d = (v % 44640) / 1440 + 1;
-    p->mi = v % 1440;
-}
-
-static double
-TimeStamp_sec(TimeStamp *self)
-{
-    unsigned int v;
-
-    v = (self->data[4] * 16777216 + self->data[5] * 65536
-	 + self->data[6] * 256 + self->data[7]);
-    return SCONV * v;
-}
-
-static PyObject *
-TimeStamp_year(TimeStamp *self)
-{
-    TimeStampParts p;
-    TimeStamp_unpack(self, &p);
-    return PyInt_FromLong(p.y);
-}
-
-static PyObject *
-TimeStamp_month(TimeStamp *self)
-{
-    TimeStampParts p;
-    TimeStamp_unpack(self, &p);
-    return PyInt_FromLong(p.m);
-}
-
-static PyObject *
-TimeStamp_day(TimeStamp *self)
-{
-    TimeStampParts p;
-    TimeStamp_unpack(self, &p);
-    return PyInt_FromLong(p.d);
-}
-
-static PyObject *
-TimeStamp_hour(TimeStamp *self)
-{
-    TimeStampParts p;
-    TimeStamp_unpack(self, &p);
-    return PyInt_FromLong(p.mi / 60);
-}
-
-static PyObject *
-TimeStamp_minute(TimeStamp *self)
-{
-    TimeStampParts p;
-    TimeStamp_unpack(self, &p);
-    return PyInt_FromLong(p.mi % 60);
-}
-
-static PyObject *
-TimeStamp_second(TimeStamp *self)
-{
-    return PyFloat_FromDouble(TimeStamp_sec(self));
-}
-
-static PyObject *
-TimeStamp_timeTime(TimeStamp *self)
-{
-    TimeStampParts p;
-    TimeStamp_unpack(self, &p);
-    return PyFloat_FromDouble(TimeStamp_abst(p.y, p.m - 1, p.d - 1, p.mi, 0)
-			      + TimeStamp_sec(self) - gmoff);
-}
-
-static PyObject *
-TimeStamp_raw(TimeStamp *self)
-{
-    return PyString_FromStringAndSize((const char*)self->data, 8);
-}
-
-static PyObject *
-TimeStamp_str(TimeStamp *self)
-{
-    char buf[128];
-    TimeStampParts p;
-    int len;
-
-    TimeStamp_unpack(self, &p);
-    len =sprintf(buf, "%4.4d-%2.2d-%2.2d %2.2d:%2.2d:%09.6f",
-	         p.y, p.m, p.d, p.mi / 60, p.mi % 60,
-	         TimeStamp_sec(self));
-
-    return PyString_FromStringAndSize(buf, len);
-}
-
-
-static PyObject *
-TimeStamp_laterThan(TimeStamp *self, PyObject *obj)
-{
-    TimeStamp *o = NULL;
-    TimeStampParts p;
-    unsigned char new[8];
-    int i;
-
-    if (obj->ob_type != self->ob_type) {
-	PyErr_SetString(PyExc_TypeError, "expected TimeStamp object");
-	return NULL;
-    }
-    o = (TimeStamp *)obj;
-    if (memcmp(self->data, o->data, 8) > 0) {
-	Py_INCREF(self);
-	return (PyObject *)self;
-    }
-
-    memcpy(new, o->data, 8);
-    for (i = 7; i > 3; i--) {
-	if (new[i] == 255)
-	    new[i] = 0;
-	else {
-	    new[i]++;
-	    return TimeStamp_FromString((const char*)new);
-	}
-    }
-
-    /* All but the first two bytes are the same.  Need to increment
-       the year, month, and day explicitly. */
-    TimeStamp_unpack(o, &p);
-    if (p.mi >= 1439) {
-	p.mi = 0;
-	if (p.d == month_len[leap(p.y)][p.m - 1]) {
-	    p.d = 1;
-	    if (p.m == 12) {
-		p.m = 1;
-		p.y++;
-	    } else
-		p.m++;
-	} else
-	    p.d++;
-    } else
-	p.mi++;
-
-    return TimeStamp_FromDate(p.y, p.m, p.d, p.mi / 60, p.mi % 60, 0);
-}
-
-static struct PyMethodDef TimeStamp_methods[] = {
-    {"year", 	(PyCFunction)TimeStamp_year, 	METH_NOARGS},
-    {"minute", 	(PyCFunction)TimeStamp_minute, 	METH_NOARGS},
-    {"month", 	(PyCFunction)TimeStamp_month, 	METH_NOARGS},
-    {"day", 	(PyCFunction)TimeStamp_day,	METH_NOARGS},
-    {"hour", 	(PyCFunction)TimeStamp_hour, 	METH_NOARGS},
-    {"second", 	(PyCFunction)TimeStamp_second, 	METH_NOARGS},
-    {"timeTime",(PyCFunction)TimeStamp_timeTime, 	METH_NOARGS},
-    {"laterThan", (PyCFunction)TimeStamp_laterThan, 	METH_O},
-    {"raw",	(PyCFunction)TimeStamp_raw,	METH_NOARGS},
-    {NULL,	NULL},
-};
-
-static PyTypeObject TimeStamp_type = {
-    PyObject_HEAD_INIT(NULL)
-    0,
-    "persistent.TimeStamp",
-    sizeof(TimeStamp),
-    0,
-    (destructor)TimeStamp_dealloc,	/* tp_dealloc */
-    0,					/* tp_print */
-    0,					/* tp_getattr */
-    0,					/* tp_setattr */
-    (cmpfunc)TimeStamp_compare,		/* tp_compare */
-    (reprfunc)TimeStamp_raw,		/* tp_repr */
-    0,					/* tp_as_number */
-    0,					/* tp_as_sequence */
-    0,					/* tp_as_mapping */
-    (hashfunc)TimeStamp_hash,		/* tp_hash */
-    0,					/* tp_call */
-    (reprfunc)TimeStamp_str,		/* tp_str */
-    0,					/* tp_getattro */
-    0,					/* tp_setattro */
-    0,					/* tp_as_buffer */
-    Py_TPFLAGS_DEFAULT | Py_TPFLAGS_BASETYPE, /* tp_flags */
-    0,					/* tp_doc */
-    0,					/* tp_traverse */
-    0,					/* tp_clear */
-    0,					/* tp_richcompare */
-    0,					/* tp_weaklistoffset */
-    0,					/* tp_iter */
-    0,					/* tp_iternext */
-    TimeStamp_methods,			/* tp_methods */
-    0,					/* tp_members */
-    0,					/* tp_getset */
-    0,					/* tp_base */
-    0,					/* tp_dict */
-    0,					/* tp_descr_get */
-    0,					/* tp_descr_set */
-};
-
-PyObject *
-TimeStamp_FromString(const char *buf)
-{
-    /* buf must be exactly 8 characters */
-    TimeStamp *ts = (TimeStamp *)PyObject_New(TimeStamp, &TimeStamp_type);
-    memcpy(ts->data, buf, 8);
-    return (PyObject *)ts;
-}
-
-#define CHECK_RANGE(VAR, LO, HI) if ((VAR) < (LO) || (VAR) > (HI)) { \
-     return PyErr_Format(PyExc_ValueError, \
-			 # VAR " must be between %d and %d: %d", \
-			 (LO), (HI), (VAR)); \
-    }
-
-PyObject *
-TimeStamp_FromDate(int year, int month, int day, int hour, int min,
-		   double sec)
-{
-    TimeStamp *ts = NULL;
-    int d;
-    unsigned int v;
-
-    if (year < 1900)
-	return PyErr_Format(PyExc_ValueError,
-			    "year must be greater than 1900: %d", year);
-    CHECK_RANGE(month, 1, 12);
-    d = days_in_month(year, month - 1);
-    if (day < 1 || day > d)
-	return PyErr_Format(PyExc_ValueError,
-			    "day must be between 1 and %d: %d", d, day);
-    CHECK_RANGE(hour, 0, 23);
-    CHECK_RANGE(min, 0, 59);
-    /* Seconds are allowed to be anything, so chill
-       If we did want to be pickly, 60 would be a better choice.
-    if (sec < 0 || sec > 59)
-	return PyErr_Format(PyExc_ValueError,
-			    "second must be between 0 and 59: %f", sec);
-    */
-    ts = (TimeStamp *)PyObject_New(TimeStamp, &TimeStamp_type);
-    v = (((year - 1900) * 12 + month - 1) * 31 + day - 1);
-    v = (v * 24 + hour) * 60 + min;
-    ts->data[0] = v / 16777216;
-    ts->data[1] = (v % 16777216) / 65536;
-    ts->data[2] = (v % 65536) / 256;
-    ts->data[3] = v % 256;
-    sec /= SCONV;
-    v = (unsigned int)sec;
-    ts->data[4] = v / 16777216;
-    ts->data[5] = (v % 16777216) / 65536;
-    ts->data[6] = (v % 65536) / 256;
-    ts->data[7] = v % 256;
-
-    return (PyObject *)ts;
-}
-
-PyObject *
-TimeStamp_TimeStamp(PyObject *obj, PyObject *args)
-{
-    char *buf = NULL;
-    int len = 0, y, mo, d, h = 0, m = 0;
-    double sec = 0;
-
-    if (PyArg_ParseTuple(args, "s#:TimeStamp", &buf, &len)) {
-	if (len != 8) {
-	    PyErr_SetString(PyExc_ValueError, "8-character string expected");
-	    return NULL;
-	}
-	return TimeStamp_FromString(buf);
-    }
-    PyErr_Clear();
-
-    if (!PyArg_ParseTuple(args, "iii|iid", &y, &mo, &d, &h, &m, &sec))
-	return NULL;
-    return TimeStamp_FromDate(y, mo, d, h, m, sec);
-}
-
-static PyMethodDef TimeStampModule_functions[] = {
-    {"TimeStamp",	TimeStamp_TimeStamp,	METH_VARARGS},
-    {NULL,		NULL},
-};
-
-
-void
-initTimeStamp(void)
-{
-    PyObject *m;
-
-    if (TimeStamp_init_gmoff() < 0)
-	return;
-
-    m = Py_InitModule4("TimeStamp", TimeStampModule_functions,
-		       TimeStampModule_doc, NULL, PYTHON_API_VERSION);
-    if (m == NULL)
-	return;
-
-    TimeStamp_type.ob_type = &PyType_Type;
-    TimeStamp_type.tp_getattro = PyObject_GenericGetAttr;
-}

Deleted: zope.transaction/trunk/zope/transaction/tests/test_timestamp.py
===================================================================
--- zope.transaction/trunk/zope/transaction/tests/test_timestamp.py	2007-11-09 15:19:56 UTC (rev 81640)
+++ zope.transaction/trunk/zope/transaction/tests/test_timestamp.py	2007-11-09 15:33:52 UTC (rev 81641)
@@ -1,181 +0,0 @@
-#############################################################################
-#
-# Copyright (c) 2006 Zope Corporation and Contributors.
-# All Rights Reserved.
-#
-# This software is subject to the provisions of the Zope Public License,
-# Version 2.1 (ZPL).  A copy of the ZPL should accompany this distribution.
-# THIS SOFTWARE IS PROVIDED "AS IS" AND ANY AND ALL EXPRESS OR IMPLIED
-# WARRANTIES ARE DISCLAIMED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
-# WARRANTIES OF TITLE, MERCHANTABILITY, AGAINST INFRINGEMENT, AND FITNESS
-# FOR A PARTICULAR PURPOSE.
-#
-##############################################################################
-
-import unittest
-import time
-from zope.transaction.TimeStamp import TimeStamp
-
-EPSILON = 0.000001
-
-class TimeStampTests(unittest.TestCase):
-    def testStringInput(self):
-        ts = TimeStamp('00000000')
-        self.assertEqual(repr(ts), '00000000')
-        ts = TimeStamp('11111111')
-        self.assertEqual(repr(ts), '11111111')
-
-    def testTupleInput(self):
-        t = int(time.time())
-        args = time.gmtime(t)[:6]
-        ts = TimeStamp(*args)
-        self.assertEqual(ts.year(), args[0])
-        self.assertEqual(ts.month(), args[1])
-        self.assertEqual(ts.day(), args[2])
-        self.assertEqual(ts.hour(), args[3])
-        self.assertEqual(ts.minute(), args[4])
-        self.assertEqual(int(round(ts.second())), args[5])
-
-    def testRaw(self):
-        ts = TimeStamp('00000000')
-        self.assertEqual(repr(ts), ts.raw())
-        ts = TimeStamp('11111111')
-        self.assertEqual(repr(ts), ts.raw())
-
-    def testStr(self):
-        t1 = 1141445984
-        args1 = time.gmtime(t1)[:6]
-        ts1 = TimeStamp(*args1)
-        self.assertEqual(str(ts1), '2006-03-04 04:19:44.000000')
-
-    def testTimeTime(self):
-        t = int(time.time())
-        args = time.gmtime(t)[:6]
-        ts = TimeStamp(*args)
-        tt = ts.timeTime()
-        self.assertEqual(tt, t)
-
-    def testYMDTimeStamp(self):
-        self._check_ymd(2001, 6, 3)
-
-    def _check_ymd(self, yr, mo, dy):
-        ts = TimeStamp(yr, mo, dy)
-        self.assertEqual(ts.year(), yr)
-        self.assertEqual(ts.month(), mo)
-        self.assertEqual(ts.day(), dy)
-
-        self.assertEquals(ts.hour(), 0)
-        self.assertEquals(ts.minute(), 0)
-        self.assertEquals(ts.second(), 0)
-
-        t = time.gmtime(ts.timeTime())
-        self.assertEquals(yr, t[0])
-        self.assertEquals(mo, t[1])
-        self.assertEquals(dy, t[2])
-
-    def testFullTimeStamp(self):
-        native_ts = int(time.time()) # fractional seconds get in the way
-        t = time.gmtime(native_ts)   # the corresponding GMT struct tm
-        ts = TimeStamp(*t[:6])
-
-        # Seconds are stored internally via (conceptually) multiplying by
-        # 2**32 then dividing by 60, ending up with a 32-bit integer.
-        # While this gives a lot of room for cramming many distinct
-        # TimeStamps into a second, it's not good at roundtrip accuracy.
-        # For example, 1 second is stored as int(2**32/60) == 71582788.
-        # Converting back gives 71582788*60.0/2**32 == 0.9999999962747097.
-        # In general, we can lose up to 0.999... to truncation during
-        # storing, creating an absolute error up to about 1*60.0/2**32 ==
-        # 0.000000014 on the seconds value we get back.  This is so even
-        # when we have an exact integral second value going in (as we
-        # do in this test), so we can't expect equality in any comparison
-        # involving seconds.  Minutes (etc) are stored exactly, so we
-        # can expect equality for those.
-
-        self.assert_(abs(ts.timeTime() - native_ts) < EPSILON)
-        self.assertEqual(ts.year(), t[0])
-        self.assertEqual(ts.month(), t[1])
-        self.assertEqual(ts.day(), t[2])
-        self.assertEquals(ts.hour(), t[3])
-        self.assertEquals(ts.minute(), t[4])
-        self.assert_(abs(ts.second() - t[5]) < EPSILON)
-
-    def testRawTimestamp(self):
-        t = time.gmtime()
-        ts1 = TimeStamp(*t[:6])
-        ts2 = TimeStamp(`ts1`)
-
-        self.assertEquals(ts1, ts2)
-        self.assertEquals(ts1.timeTime(), ts2.timeTime())
-        self.assertEqual(ts1.year(), ts2.year())
-        self.assertEqual(ts1.month(), ts2.month())
-        self.assertEqual(ts1.day(), ts2.day())
-        self.assertEquals(ts1.hour(), ts2.hour())
-        self.assertEquals(ts1.minute(), ts2.minute())
-        self.assert_(abs(ts1.second() - ts2.second()) < EPSILON)
-
-    def testDictKey(self):
-        t = time.gmtime()
-        ts1 = TimeStamp(*t[:6])
-        ts2 = TimeStamp(2000, *t[1:6])
-
-        d = {}
-        d[ts1] = 1
-        d[ts2] = 2
-
-        self.assertEquals(len(d), 2)
-
-    def testCompare(self):
-        ts1 = TimeStamp(1972, 6, 27)
-        ts2 = TimeStamp(1971, 12, 12)
-        self.assert_(ts1 > ts2)
-        self.assert_(ts2 <= ts1)
-
-    def testLaterThan(self):
-        t = time.gmtime()
-        ts = TimeStamp(*t[:6])
-        ts2 = ts.laterThan(ts)
-        self.assert_(ts2 > ts)
-
-    # TODO:  should test for bogus inputs to TimeStamp constructor
-
-    def testTimeStamp(self):
-        # Alternate test suite
-        t = TimeStamp(2002, 1, 23, 10, 48, 5) # GMT
-        self.assertEquals(str(t), '2002-01-23 10:48:05.000000')
-        self.assertEquals(repr(t), '\x03B9H\x15UUU')
-        self.assertEquals(TimeStamp('\x03B9H\x15UUU'), t)
-        self.assertEquals(t.year(), 2002)
-        self.assertEquals(t.month(), 1)
-        self.assertEquals(t.day(), 23)
-        self.assertEquals(t.hour(), 10)
-        self.assertEquals(t.minute(), 48)
-        self.assertEquals(round(t.second()), 5)
-        self.assertEquals(t.timeTime(), 1011782885)
-        t1 = TimeStamp(2002, 1, 23, 10, 48, 10)
-        self.assertEquals(str(t1), '2002-01-23 10:48:10.000000')
-        self.assert_(t == t)
-        self.assert_(t != t1)
-        self.assert_(t < t1)
-        self.assert_(t <= t1)
-        self.assert_(t1 >= t)
-        self.assert_(t1 > t)
-        self.failIf(t == t1)
-        self.failIf(t != t)
-        self.failIf(t > t1)
-        self.failIf(t >= t1)
-        self.failIf(t1 < t)
-        self.failIf(t1 <= t)
-        self.assertEquals(cmp(t, t), 0)
-        self.assertEquals(cmp(t, t1), -1)
-        self.assertEquals(cmp(t1, t), 1)
-        self.assertEquals(t1.laterThan(t), t1)
-        self.assert_(t.laterThan(t1) > t1)
-        self.assertEquals(TimeStamp(2002,1,23), TimeStamp(2002,1,23,0,0,0))
-
-
-def test_suite():
-    return unittest.makeSuite(TimeStampTests)
-
-if __name__ == '__main__':
-    unittest.main()



More information about the Checkins mailing list