2008-12-10 14:10:57 +00:00
|
|
|
# Copyright (c) 2003-2008 Zooko Wilcox-O'Hearn
|
2006-11-30 22:22:25 +00:00
|
|
|
# mailto:zooko@zooko.com
|
|
|
|
# http://zooko.com/
|
|
|
|
# Permission is hereby granted, free of charge, to any person obtaining a
|
2007-11-01 22:34:18 +00:00
|
|
|
# copy of this work to deal in this work without restriction (including the
|
2006-11-30 22:22:25 +00:00
|
|
|
# rights to use, modify, distribute, sublicense, and/or sell copies)
|
|
|
|
|
|
|
|
"""
|
|
|
|
Tests useful in assertion checking, prints out nicely formated messages too.
|
|
|
|
"""
|
|
|
|
|
|
|
|
from humanreadable import hr
|
|
|
|
|
|
|
|
def _assert(___cond=False, *___args, **___kwargs):
|
|
|
|
if ___cond:
|
|
|
|
return True
|
|
|
|
msgbuf=[]
|
|
|
|
if ___args:
|
|
|
|
msgbuf.append("%s %s" % tuple(map(hr, (___args[0], type(___args[0]),))))
|
|
|
|
msgbuf.extend([", %s %s" % tuple(map(hr, (arg, type(arg),))) for arg in ___args[1:]])
|
|
|
|
if ___kwargs:
|
|
|
|
msgbuf.append(", %s: %s %s" % ((___kwargs.items()[0][0],) + tuple(map(hr, (___kwargs.items()[0][1], type(___kwargs.items()[0][1]),)))))
|
|
|
|
else:
|
|
|
|
if ___kwargs:
|
|
|
|
msgbuf.append("%s: %s %s" % ((___kwargs.items()[0][0],) + tuple(map(hr, (___kwargs.items()[0][1], type(___kwargs.items()[0][1]),)))))
|
|
|
|
msgbuf.extend([", %s: %s %s" % tuple(map(hr, (k, v, type(v),))) for k, v in ___kwargs.items()[1:]])
|
|
|
|
|
|
|
|
raise AssertionError, "".join(msgbuf)
|
|
|
|
|
|
|
|
return False
|
|
|
|
|
|
|
|
def precondition(___cond=False, *___args, **___kwargs):
|
|
|
|
try:
|
|
|
|
if ___cond:
|
|
|
|
return True
|
|
|
|
msgbuf=["precondition", ]
|
|
|
|
if ___args or ___kwargs:
|
|
|
|
msgbuf.append(": ")
|
|
|
|
if ___args:
|
|
|
|
msgbuf.append("%s %s" % tuple(map(hr, (___args[0], type(___args[0]),))))
|
|
|
|
msgbuf.extend([", %s %s" % tuple(map(hr, (arg, type(arg),))) for arg in ___args[1:]])
|
|
|
|
if ___kwargs:
|
|
|
|
msgbuf.append(", %s: %s %s" % ((___kwargs.items()[0][0],) + tuple(map(hr, (___kwargs.items()[0][1], type(___kwargs.items()[0][1]),)))))
|
|
|
|
else:
|
|
|
|
if ___kwargs:
|
|
|
|
msgbuf.append("%s: %s %s" % ((___kwargs.items()[0][0],) + tuple(map(hr, (___kwargs.items()[0][1], type(___kwargs.items()[0][1]),)))))
|
|
|
|
msgbuf.extend([", %s: %s %s" % tuple(map(hr, (k, v, type(v),))) for k, v in ___kwargs.items()[1:]])
|
|
|
|
except:
|
2008-12-10 14:10:57 +00:00
|
|
|
import logging
|
|
|
|
logging.exception("assertutil.precondition(): INTERNAL ERROR in allmydata.util.assertutil.")
|
2006-11-30 22:22:25 +00:00
|
|
|
raise
|
|
|
|
|
|
|
|
raise AssertionError, "".join(msgbuf)
|
|
|
|
|
|
|
|
return False
|
|
|
|
|
|
|
|
def postcondition(___cond=False, *___args, **___kwargs):
|
|
|
|
if ___cond:
|
|
|
|
return True
|
|
|
|
msgbuf=["postcondition", ]
|
|
|
|
if ___args or ___kwargs:
|
|
|
|
msgbuf.append(": ")
|
|
|
|
if ___args:
|
|
|
|
msgbuf.append("%s %s" % tuple(map(hr, (___args[0], type(___args[0]),))))
|
|
|
|
msgbuf.extend([", %s %s" % tuple(map(hr, (arg, type(arg),))) for arg in ___args[1:]])
|
|
|
|
if ___kwargs:
|
|
|
|
msgbuf.append(", %s: %s %s" % ((___kwargs.items()[0][0],) + tuple(map(hr, (___kwargs.items()[0][1], type(___kwargs.items()[0][1]),)))))
|
|
|
|
else:
|
|
|
|
if ___kwargs:
|
|
|
|
msgbuf.append("%s: %s %s" % ((___kwargs.items()[0][0],) + tuple(map(hr, (___kwargs.items()[0][1], type(___kwargs.items()[0][1]),)))))
|
|
|
|
msgbuf.extend([", %s: %s %s" % tuple(map(hr, (k, v, type(v),))) for k, v in ___kwargs.items()[1:]])
|
|
|
|
|
|
|
|
raise AssertionError, "".join(msgbuf)
|
|
|
|
|
|
|
|
return False
|
|
|
|
|