Blame xstc/xstc.py

Packit Service a31ea6
#!/usr/bin/env python
Packit Service a31ea6
Packit Service a31ea6
#
Packit Service a31ea6
# This is the MS subset of the W3C test suite for XML Schemas.
Packit Service a31ea6
# This file is generated from the MS W3c test suite description file.
Packit Service a31ea6
#
Packit Service a31ea6
Packit Service a31ea6
import sys, os
Packit Service a31ea6
import exceptions, optparse
Packit Service a31ea6
import libxml2
Packit Service a31ea6
Packit Service a31ea6
opa = optparse.OptionParser()
Packit Service a31ea6
Packit Service a31ea6
opa.add_option("-b", "--base", action="store", type="string", dest="baseDir",
Packit Service a31ea6
			   default="",
Packit Service a31ea6
			   help="""The base directory; i.e. the parent folder of the
Packit Service a31ea6
			   "nisttest", "suntest" and "msxsdtest" directories.""")
Packit Service a31ea6
Packit Service a31ea6
opa.add_option("-o", "--out", action="store", type="string", dest="logFile",
Packit Service a31ea6
			   default="test.log",
Packit Service a31ea6
			   help="The filepath of the log file to be created")
Packit Service a31ea6
Packit Service a31ea6
opa.add_option("--log", action="store_true", dest="enableLog",
Packit Service a31ea6
			   default=False,
Packit Service a31ea6
			   help="Create the log file")
Packit Service a31ea6
Packit Service a31ea6
opa.add_option("--no-test-out", action="store_true", dest="disableTestStdOut",
Packit Service a31ea6
			   default=False,
Packit Service a31ea6
			   help="Don't output test results")
Packit Service a31ea6
Packit Service a31ea6
opa.add_option("-s", "--silent", action="store_true", dest="silent", default=False,
Packit Service a31ea6
			   help="Disables display of all tests")
Packit Service a31ea6
Packit Service a31ea6
opa.add_option("-v", "--verbose", action="store_true", dest="verbose",
Packit Service a31ea6
			   default=False,
Packit Service a31ea6
			   help="Displays all tests (only if --silent is not set)")
Packit Service a31ea6
Packit Service a31ea6
opa.add_option("-x", "--max", type="int", dest="maxTestCount",
Packit Service a31ea6
			   default="-1",
Packit Service a31ea6
			   help="The maximum number of tests to be run")
Packit Service a31ea6
Packit Service a31ea6
opa.add_option("-t", "--test", type="string", dest="singleTest",
Packit Service a31ea6
			   default=None,
Packit Service a31ea6
			   help="Runs the specified test only")
Packit Service a31ea6
			   
Packit Service a31ea6
opa.add_option("--tsw", "--test-starts-with", type="string", dest="testStartsWith",
Packit Service a31ea6
			   default=None,
Packit Service a31ea6
			   help="Runs the specified test(s), starting with the given string")
Packit Service a31ea6
Packit Service a31ea6
opa.add_option("--rieo", "--report-internal-errors-only", action="store_true",
Packit Service a31ea6
			   dest="reportInternalErrOnly", default=False,
Packit Service a31ea6
			   help="Display erroneous tests of type 'internal' only")
Packit Service a31ea6
Packit Service a31ea6
opa.add_option("--rueo", "--report-unimplemented-errors-only", action="store_true",
Packit Service a31ea6
			   dest="reportUnimplErrOnly", default=False,
Packit Service a31ea6
			   help="Display erroneous tests of type 'unimplemented' only")
Packit Service a31ea6
Packit Service a31ea6
opa.add_option("--rmleo", "--report-mem-leak-errors-only", action="store_true",
Packit Service a31ea6
			   dest="reportMemLeakErrOnly", default=False,
Packit Service a31ea6
			   help="Display erroneous tests of type 'memory leak' only")
Packit Service a31ea6
Packit Service a31ea6
opa.add_option("-c", "--combines", type="string", dest="combines",
Packit Service a31ea6
			   default=None,
Packit Service a31ea6
			   help="Combines to be run (all if omitted)")
Packit Service a31ea6
			   
Packit Service a31ea6
opa.add_option("--csw", "--csw", type="string", dest="combineStartsWith",
Packit Service a31ea6
			   default=None,
Packit Service a31ea6
			   help="Combines to be run (all if omitted)")			   
Packit Service a31ea6
Packit Service a31ea6
opa.add_option("--rc", "--report-combines", action="store_true",
Packit Service a31ea6
			   dest="reportCombines", default=False,
Packit Service a31ea6
			   help="Display combine reports")
Packit Service a31ea6
Packit Service a31ea6
opa.add_option("--rec", "--report-err-combines", action="store_true",
Packit Service a31ea6
			   dest="reportErrCombines", default=False,
Packit Service a31ea6
			   help="Display erroneous combine reports only")
Packit Service a31ea6
Packit Service a31ea6
opa.add_option("--debug", action="store_true",
Packit Service a31ea6
			   dest="debugEnabled", default=False,
Packit Service a31ea6
			   help="Displays debug messages")
Packit Service a31ea6
Packit Service a31ea6
opa.add_option("--info", action="store_true",
Packit Service a31ea6
			   dest="info", default=False,
Packit Service a31ea6
			   help="Displays info on the suite only. Does not run any test.")
Packit Service a31ea6
opa.add_option("--sax", action="store_true",
Packit Service a31ea6
			   dest="validationSAX", default=False,
Packit Service a31ea6
			   help="Use SAX2-driven validation.")
Packit Service a31ea6
opa.add_option("--tn", action="store_true",
Packit Service a31ea6
			   dest="displayTestName", default=False,
Packit Service a31ea6
			   help="Display the test name in every case.")
Packit Service a31ea6
Packit Service a31ea6
(options, args) = opa.parse_args()
Packit Service a31ea6
Packit Service a31ea6
if options.combines is not None:
Packit Service a31ea6
	options.combines = options.combines.split()
Packit Service a31ea6
Packit Service a31ea6
################################################
Packit Service a31ea6
# The vars below are not intended to be changed.
Packit Service a31ea6
#
Packit Service a31ea6
Packit Service a31ea6
msgSchemaNotValidButShould =  "The schema should be valid."
Packit Service a31ea6
msgSchemaValidButShouldNot = "The schema should be invalid."
Packit Service a31ea6
msgInstanceNotValidButShould = "The instance should be valid."
Packit Service a31ea6
msgInstanceValidButShouldNot = "The instance should be invalid."
Packit Service a31ea6
vendorNIST = "NIST"
Packit Service a31ea6
vendorNIST_2 = "NIST-2"
Packit Service a31ea6
vendorSUN  = "SUN"
Packit Service a31ea6
vendorMS   = "MS"
Packit Service a31ea6
Packit Service a31ea6
###################
Packit Service a31ea6
# Helper functions.
Packit Service a31ea6
#
Packit Service a31ea6
vendor = None
Packit Service a31ea6
Packit Service a31ea6
def handleError(test, msg):
Packit Service a31ea6
	global options
Packit Service a31ea6
	if not options.silent:
Packit Service a31ea6
		test.addLibLog("'%s'   LIB: %s" % (test.name, msg))
Packit Service a31ea6
	if msg.find("Unimplemented") > -1:
Packit Service a31ea6
		test.failUnimplemented()
Packit Service a31ea6
	elif msg.find("Internal") > -1:
Packit Service a31ea6
		test.failInternal()
Packit Service a31ea6
		
Packit Service a31ea6
	
Packit Service a31ea6
def fixFileNames(fileName):
Packit Service a31ea6
	if (fileName is None) or (fileName == ""):
Packit Service a31ea6
		return ""
Packit Service a31ea6
	dirs = fileName.split("/")
Packit Service a31ea6
	if dirs[1] != "Tests":
Packit Service a31ea6
		fileName = os.path.join(".", "Tests")
Packit Service a31ea6
		for dir in dirs[1:]:
Packit Service a31ea6
			fileName = os.path.join(fileName, dir)	
Packit Service a31ea6
	return fileName
Packit Service a31ea6
Packit Service a31ea6
class XSTCTestGroup:
Packit Service a31ea6
	def __init__(self, name, schemaFileName, descr):
Packit Service a31ea6
		global vendor, vendorNIST_2
Packit Service a31ea6
		self.name = name
Packit Service a31ea6
		self.descr = descr
Packit Service a31ea6
		self.mainSchema = True
Packit Service a31ea6
		self.schemaFileName = fixFileNames(schemaFileName)
Packit Service a31ea6
		self.schemaParsed = False
Packit Service a31ea6
		self.schemaTried = False
Packit Service a31ea6
Packit Service a31ea6
	def setSchema(self, schemaFileName, parsed):
Packit Service a31ea6
		if not self.mainSchema:			
Packit Service a31ea6
			return
Packit Service a31ea6
		self.mainSchema = False
Packit Service a31ea6
		self.schemaParsed = parsed
Packit Service a31ea6
		self.schemaTried = True
Packit Service a31ea6
Packit Service a31ea6
class XSTCTestCase:
Packit Service a31ea6
Packit Service a31ea6
		   # 
Packit Service a31ea6
	def __init__(self, isSchema, groupName, name, accepted, file, val, descr):
Packit Service a31ea6
		global options
Packit Service a31ea6
		#
Packit Service a31ea6
		# Constructor.
Packit Service a31ea6
		#
Packit Service a31ea6
		self.testRunner = None
Packit Service a31ea6
		self.isSchema = isSchema
Packit Service a31ea6
		self.groupName = groupName
Packit Service a31ea6
		self.name = name
Packit Service a31ea6
		self.accepted = accepted		
Packit Service a31ea6
		self.fileName = fixFileNames(file)
Packit Service a31ea6
		self.val = val
Packit Service a31ea6
		self.descr = descr
Packit Service a31ea6
		self.failed = False
Packit Service a31ea6
		self.combineName = None
Packit Service a31ea6
Packit Service a31ea6
		self.log = []
Packit Service a31ea6
		self.libLog = []
Packit Service a31ea6
		self.initialMemUsed = 0
Packit Service a31ea6
		self.memLeak = 0
Packit Service a31ea6
		self.excepted = False
Packit Service a31ea6
		self.bad = False
Packit Service a31ea6
		self.unimplemented = False
Packit Service a31ea6
		self.internalErr = False
Packit Service a31ea6
		self.noSchemaErr = False
Packit Service a31ea6
		self.failed = False
Packit Service a31ea6
		#
Packit Service a31ea6
		# Init the log.
Packit Service a31ea6
		#
Packit Service a31ea6
		if not options.silent:
Packit Service a31ea6
			if self.descr is not None:
Packit Service a31ea6
				self.log.append("'%s'   descr: %s\n" % (self.name, self.descr))		
Packit Service a31ea6
			self.log.append("'%s'   exp validity: %d\n" % (self.name, self.val))
Packit Service a31ea6
Packit Service a31ea6
	def initTest(self, runner):
Packit Service a31ea6
		global vendorNIST, vendorSUN, vendorMS, vendorNIST_2, options, vendor
Packit Service a31ea6
		#
Packit Service a31ea6
		# Get the test-group.
Packit Service a31ea6
		#
Packit Service a31ea6
		self.runner = runner
Packit Service a31ea6
		self.group = runner.getGroup(self.groupName)				
Packit Service a31ea6
		if vendor == vendorMS or vendor == vendorSUN:
Packit Service a31ea6
			#
Packit Service a31ea6
			# Use the last given directory for the combine name.
Packit Service a31ea6
			#
Packit Service a31ea6
			dirs = self.fileName.split("/")
Packit Service a31ea6
			self.combineName = dirs[len(dirs) -2]					
Packit Service a31ea6
		elif vendor == vendorNIST:
Packit Service a31ea6
			#
Packit Service a31ea6
			# NIST files are named in the following form:
Packit Service a31ea6
			# "NISTSchema-short-pattern-1.xsd"
Packit Service a31ea6
			#						
Packit Service a31ea6
			tokens = self.name.split("-")
Packit Service a31ea6
			self.combineName = tokens[1]
Packit Service a31ea6
		elif vendor == vendorNIST_2:
Packit Service a31ea6
			#
Packit Service a31ea6
			# Group-names have the form: "atomic-normalizedString-length-1"
Packit Service a31ea6
			#
Packit Service a31ea6
			tokens = self.groupName.split("-")
Packit Service a31ea6
			self.combineName = "%s-%s" % (tokens[0], tokens[1])
Packit Service a31ea6
		else:
Packit Service a31ea6
			self.combineName = "unkown"
Packit Service a31ea6
			raise Exception("Could not compute the combine name of a test.")
Packit Service a31ea6
		if (not options.silent) and (self.group.descr is not None):
Packit Service a31ea6
			self.log.append("'%s'   group-descr: %s\n" % (self.name, self.group.descr))
Packit Service a31ea6
		
Packit Service a31ea6
Packit Service a31ea6
	def addLibLog(self, msg):		
Packit Service a31ea6
		"""This one is intended to be used by the error handler
Packit Service a31ea6
		function"""
Packit Service a31ea6
		global options		
Packit Service a31ea6
		if not options.silent:
Packit Service a31ea6
			self.libLog.append(msg)
Packit Service a31ea6
Packit Service a31ea6
	def fail(self, msg):
Packit Service a31ea6
		global options
Packit Service a31ea6
		self.failed = True
Packit Service a31ea6
		if not options.silent:
Packit Service a31ea6
			self.log.append("'%s' ( FAILED: %s\n" % (self.name, msg))
Packit Service a31ea6
Packit Service a31ea6
	def failNoSchema(self):
Packit Service a31ea6
		global options
Packit Service a31ea6
		self.failed = True
Packit Service a31ea6
		self.noSchemaErr = True
Packit Service a31ea6
		if not options.silent:
Packit Service a31ea6
			self.log.append("'%s' X NO-SCHEMA\n" % (self.name))
Packit Service a31ea6
Packit Service a31ea6
	def failInternal(self):
Packit Service a31ea6
		global options
Packit Service a31ea6
		self.failed = True
Packit Service a31ea6
		self.internalErr = True
Packit Service a31ea6
		if not options.silent:
Packit Service a31ea6
			self.log.append("'%s' * INTERNAL\n" % self.name)
Packit Service a31ea6
Packit Service a31ea6
	def failUnimplemented(self):
Packit Service a31ea6
		global options
Packit Service a31ea6
		self.failed = True
Packit Service a31ea6
		self.unimplemented = True
Packit Service a31ea6
		if not options.silent:
Packit Service a31ea6
			self.log.append("'%s' ? UNIMPLEMENTED\n" % self.name)
Packit Service a31ea6
Packit Service a31ea6
	def failCritical(self, msg):
Packit Service a31ea6
		global options
Packit Service a31ea6
		self.failed = True
Packit Service a31ea6
		self.bad = True
Packit Service a31ea6
		if not options.silent:
Packit Service a31ea6
			self.log.append("'%s' ! BAD: %s\n" % (self.name, msg))
Packit Service a31ea6
Packit Service a31ea6
	def failExcept(self, e):
Packit Service a31ea6
		global options
Packit Service a31ea6
		self.failed = True
Packit Service a31ea6
		self.excepted = True
Packit Service a31ea6
		if not options.silent:
Packit Service a31ea6
			self.log.append("'%s' # EXCEPTION: %s\n" % (self.name, e.__str__()))
Packit Service a31ea6
Packit Service a31ea6
	def setUp(self):
Packit Service a31ea6
		#
Packit Service a31ea6
		# Set up Libxml2.
Packit Service a31ea6
		#
Packit Service a31ea6
		self.initialMemUsed = libxml2.debugMemory(1)
Packit Service a31ea6
		libxml2.initParser()
Packit Service a31ea6
		libxml2.lineNumbersDefault(1)
Packit Service a31ea6
		libxml2.registerErrorHandler(handleError, self)
Packit Service a31ea6
Packit Service a31ea6
	def tearDown(self):
Packit Service a31ea6
		libxml2.schemaCleanupTypes()
Packit Service a31ea6
		libxml2.cleanupParser()
Packit Service a31ea6
		self.memLeak = libxml2.debugMemory(1) - self.initialMemUsed
Packit Service a31ea6
Packit Service a31ea6
	def isIOError(self, file, docType):
Packit Service a31ea6
		err = None
Packit Service a31ea6
		try:
Packit Service a31ea6
			err = libxml2.lastError()
Packit Service a31ea6
		except:
Packit Service a31ea6
			# Suppress exceptions.
Packit Service a31ea6
			pass
Packit Service a31ea6
		if (err is None):
Packit Service a31ea6
			return False
Packit Service a31ea6
		if err.domain() == libxml2.XML_FROM_IO:
Packit Service a31ea6
			self.failCritical("failed to access the %s resource '%s'\n" % (docType, file))
Packit Service a31ea6
Packit Service a31ea6
	def debugMsg(self, msg):
Packit Service a31ea6
		global options
Packit Service a31ea6
		if options.debugEnabled:
Packit Service a31ea6
			sys.stdout.write("'%s'   DEBUG: %s\n" % (self.name, msg))
Packit Service a31ea6
Packit Service a31ea6
	def finalize(self):
Packit Service a31ea6
		global options
Packit Service a31ea6
		"""Adds additional info to the log."""
Packit Service a31ea6
		#
Packit Service a31ea6
		# Add libxml2 messages.
Packit Service a31ea6
		#
Packit Service a31ea6
		if not options.silent:
Packit Service a31ea6
			self.log.extend(self.libLog)
Packit Service a31ea6
			#
Packit Service a31ea6
			# Add memory leaks.
Packit Service a31ea6
			#
Packit Service a31ea6
			if self.memLeak != 0:
Packit Service a31ea6
				self.log.append("%s + memory leak: %d bytes\n" % (self.name, self.memLeak))
Packit Service a31ea6
Packit Service a31ea6
	def run(self):
Packit Service a31ea6
		"""Runs a test."""
Packit Service a31ea6
		global options
Packit Service a31ea6
Packit Service a31ea6
		##filePath = os.path.join(options.baseDir, self.fileName)
Packit Service a31ea6
		# filePath = "%s/%s/%s/%s" % (options.baseDir, self.test_Folder, self.schema_Folder, self.schema_File)
Packit Service a31ea6
		if options.displayTestName:
Packit Service a31ea6
			sys.stdout.write("'%s'\n" % self.name)
Packit Service a31ea6
		try:
Packit Service a31ea6
			self.validate()
Packit Service a31ea6
		except (Exception, libxml2.parserError, libxml2.treeError), e:
Packit Service a31ea6
			self.failExcept(e)
Packit Service a31ea6
			
Packit Service a31ea6
def parseSchema(fileName):
Packit Service a31ea6
	schema = None
Packit Service a31ea6
	ctxt = libxml2.schemaNewParserCtxt(fileName)
Packit Service a31ea6
	try:
Packit Service a31ea6
		try:
Packit Service a31ea6
			schema = ctxt.schemaParse()
Packit Service a31ea6
		except:
Packit Service a31ea6
			pass
Packit Service a31ea6
	finally:		
Packit Service a31ea6
		del ctxt
Packit Service a31ea6
		return schema
Packit Service a31ea6
				
Packit Service a31ea6
Packit Service a31ea6
class XSTCSchemaTest(XSTCTestCase):
Packit Service a31ea6
Packit Service a31ea6
	def __init__(self, groupName, name, accepted, file, val, descr):
Packit Service a31ea6
		XSTCTestCase.__init__(self, 1, groupName, name, accepted, file, val, descr)
Packit Service a31ea6
Packit Service a31ea6
	def validate(self):
Packit Service a31ea6
		global msgSchemaNotValidButShould, msgSchemaValidButShouldNot
Packit Service a31ea6
		schema = None
Packit Service a31ea6
		filePath = self.fileName
Packit Service a31ea6
		# os.path.join(options.baseDir, self.fileName)
Packit Service a31ea6
		valid = 0
Packit Service a31ea6
		try:
Packit Service a31ea6
			#
Packit Service a31ea6
			# Parse the schema.
Packit Service a31ea6
			#
Packit Service a31ea6
			self.debugMsg("loading schema: %s" % filePath)
Packit Service a31ea6
			schema = parseSchema(filePath)
Packit Service a31ea6
			self.debugMsg("after loading schema")						
Packit Service a31ea6
			if schema is None:
Packit Service a31ea6
				self.debugMsg("schema is None")
Packit Service a31ea6
				self.debugMsg("checking for IO errors...")
Packit Service a31ea6
				if self.isIOError(file, "schema"):
Packit Service a31ea6
					return
Packit Service a31ea6
			self.debugMsg("checking schema result")
Packit Service a31ea6
			if (schema is None and self.val) or (schema is not None and self.val == 0):
Packit Service a31ea6
				self.debugMsg("schema result is BAD")
Packit Service a31ea6
				if (schema == None):
Packit Service a31ea6
					self.fail(msgSchemaNotValidButShould)
Packit Service a31ea6
				else:
Packit Service a31ea6
					self.fail(msgSchemaValidButShouldNot)
Packit Service a31ea6
			else:
Packit Service a31ea6
				self.debugMsg("schema result is OK")
Packit Service a31ea6
		finally:
Packit Service a31ea6
			self.group.setSchema(self.fileName, schema is not None)
Packit Service a31ea6
			del schema
Packit Service a31ea6
Packit Service a31ea6
class XSTCInstanceTest(XSTCTestCase):
Packit Service a31ea6
Packit Service a31ea6
	def __init__(self, groupName, name, accepted, file, val, descr):
Packit Service a31ea6
		XSTCTestCase.__init__(self, 0, groupName, name, accepted, file, val, descr)
Packit Service a31ea6
Packit Service a31ea6
	def validate(self):
Packit Service a31ea6
		instance = None
Packit Service a31ea6
		schema = None
Packit Service a31ea6
		filePath = self.fileName
Packit Service a31ea6
		# os.path.join(options.baseDir, self.fileName)
Packit Service a31ea6
Packit Service a31ea6
		if not self.group.schemaParsed and self.group.schemaTried:
Packit Service a31ea6
			self.failNoSchema()
Packit Service a31ea6
			return
Packit Service a31ea6
					
Packit Service a31ea6
		self.debugMsg("loading instance: %s" % filePath)
Packit Service a31ea6
		parserCtxt = libxml2.newParserCtxt()
Packit Service a31ea6
		if (parserCtxt is None):
Packit Service a31ea6
			# TODO: Is this one necessary, or will an exception
Packit Service a31ea6
			# be already raised?
Packit Service a31ea6
			raise Exception("Could not create the instance parser context.")
Packit Service a31ea6
		if not options.validationSAX:
Packit Service a31ea6
			try:
Packit Service a31ea6
				try:
Packit Service a31ea6
					instance = parserCtxt.ctxtReadFile(filePath, None, libxml2.XML_PARSE_NOWARNING)
Packit Service a31ea6
				except:
Packit Service a31ea6
					# Suppress exceptions.
Packit Service a31ea6
					pass
Packit Service a31ea6
			finally:
Packit Service a31ea6
				del parserCtxt
Packit Service a31ea6
			self.debugMsg("after loading instance")
Packit Service a31ea6
			if instance is None:
Packit Service a31ea6
				self.debugMsg("instance is None")
Packit Service a31ea6
				self.failCritical("Failed to parse the instance for unknown reasons.")
Packit Service a31ea6
				return		
Packit Service a31ea6
		try:
Packit Service a31ea6
			#
Packit Service a31ea6
			# Validate the instance.
Packit Service a31ea6
			#
Packit Service a31ea6
			self.debugMsg("loading schema: %s" % self.group.schemaFileName)
Packit Service a31ea6
			schema = parseSchema(self.group.schemaFileName)
Packit Service a31ea6
			try:
Packit Service a31ea6
				validationCtxt = schema.schemaNewValidCtxt()
Packit Service a31ea6
				#validationCtxt = libxml2.schemaNewValidCtxt(None)
Packit Service a31ea6
				if (validationCtxt is None):
Packit Service a31ea6
					self.failCritical("Could not create the validation context.")
Packit Service a31ea6
					return
Packit Service a31ea6
				try:
Packit Service a31ea6
					self.debugMsg("validating instance")
Packit Service a31ea6
					if options.validationSAX:
Packit Service a31ea6
						instance_Err = validationCtxt.schemaValidateFile(filePath, 0)
Packit Service a31ea6
					else:
Packit Service a31ea6
						instance_Err = validationCtxt.schemaValidateDoc(instance)
Packit Service a31ea6
					self.debugMsg("after instance validation")
Packit Service a31ea6
					self.debugMsg("instance-err: %d" % instance_Err)
Packit Service a31ea6
					if (instance_Err != 0 and self.val == 1) or (instance_Err == 0 and self.val == 0):
Packit Service a31ea6
						self.debugMsg("instance result is BAD")
Packit Service a31ea6
						if (instance_Err != 0):
Packit Service a31ea6
							self.fail(msgInstanceNotValidButShould)
Packit Service a31ea6
						else:
Packit Service a31ea6
							self.fail(msgInstanceValidButShouldNot)
Packit Service a31ea6
Packit Service a31ea6
					else:
Packit Service a31ea6
								self.debugMsg("instance result is OK")
Packit Service a31ea6
				finally:
Packit Service a31ea6
					del validationCtxt
Packit Service a31ea6
			finally:
Packit Service a31ea6
				del schema
Packit Service a31ea6
		finally:
Packit Service a31ea6
			if instance is not None:
Packit Service a31ea6
				instance.freeDoc()
Packit Service a31ea6
Packit Service a31ea6
Packit Service a31ea6
####################
Packit Service a31ea6
# Test runner class.
Packit Service a31ea6
#
Packit Service a31ea6
Packit Service a31ea6
class XSTCTestRunner:
Packit Service a31ea6
Packit Service a31ea6
	CNT_TOTAL = 0
Packit Service a31ea6
	CNT_RAN = 1
Packit Service a31ea6
	CNT_SUCCEEDED = 2
Packit Service a31ea6
	CNT_FAILED = 3
Packit Service a31ea6
	CNT_UNIMPLEMENTED = 4
Packit Service a31ea6
	CNT_INTERNAL = 5
Packit Service a31ea6
	CNT_BAD = 6
Packit Service a31ea6
	CNT_EXCEPTED = 7
Packit Service a31ea6
	CNT_MEMLEAK = 8
Packit Service a31ea6
	CNT_NOSCHEMA = 9
Packit Service a31ea6
	CNT_NOTACCEPTED = 10
Packit Service a31ea6
	CNT_SCHEMA_TEST = 11
Packit Service a31ea6
Packit Service a31ea6
	def __init__(self):
Packit Service a31ea6
		self.logFile = None
Packit Service a31ea6
		self.counters = self.createCounters()
Packit Service a31ea6
		self.testList = []
Packit Service a31ea6
		self.combinesRan = {}
Packit Service a31ea6
		self.groups = {}
Packit Service a31ea6
		self.curGroup = None
Packit Service a31ea6
Packit Service a31ea6
	def createCounters(self):
Packit Service a31ea6
		counters = {self.CNT_TOTAL:0, self.CNT_RAN:0, self.CNT_SUCCEEDED:0,
Packit Service a31ea6
		self.CNT_FAILED:0, self.CNT_UNIMPLEMENTED:0, self.CNT_INTERNAL:0, self.CNT_BAD:0,
Packit Service a31ea6
		self.CNT_EXCEPTED:0, self.CNT_MEMLEAK:0, self.CNT_NOSCHEMA:0, self.CNT_NOTACCEPTED:0,
Packit Service a31ea6
		self.CNT_SCHEMA_TEST:0}
Packit Service a31ea6
Packit Service a31ea6
		return counters
Packit Service a31ea6
Packit Service a31ea6
	def addTest(self, test):
Packit Service a31ea6
		self.testList.append(test)
Packit Service a31ea6
		test.initTest(self)
Packit Service a31ea6
Packit Service a31ea6
	def getGroup(self, groupName):
Packit Service a31ea6
		return self.groups[groupName]
Packit Service a31ea6
Packit Service a31ea6
	def addGroup(self, group):
Packit Service a31ea6
		self.groups[group.name] = group
Packit Service a31ea6
Packit Service a31ea6
	def updateCounters(self, test, counters):
Packit Service a31ea6
		if test.memLeak != 0:
Packit Service a31ea6
			counters[self.CNT_MEMLEAK] += 1
Packit Service a31ea6
		if not test.failed:
Packit Service a31ea6
			counters[self.CNT_SUCCEEDED] +=1
Packit Service a31ea6
		if test.failed:
Packit Service a31ea6
			counters[self.CNT_FAILED] += 1
Packit Service a31ea6
		if test.bad:
Packit Service a31ea6
			counters[self.CNT_BAD] += 1
Packit Service a31ea6
		if test.unimplemented:
Packit Service a31ea6
			counters[self.CNT_UNIMPLEMENTED] += 1
Packit Service a31ea6
		if test.internalErr:
Packit Service a31ea6
			counters[self.CNT_INTERNAL] += 1
Packit Service a31ea6
		if test.noSchemaErr:
Packit Service a31ea6
			counters[self.CNT_NOSCHEMA] += 1
Packit Service a31ea6
		if test.excepted:
Packit Service a31ea6
			counters[self.CNT_EXCEPTED] += 1
Packit Service a31ea6
		if not test.accepted:
Packit Service a31ea6
			counters[self.CNT_NOTACCEPTED] += 1
Packit Service a31ea6
		if test.isSchema:
Packit Service a31ea6
			counters[self.CNT_SCHEMA_TEST] += 1
Packit Service a31ea6
		return counters
Packit Service a31ea6
Packit Service a31ea6
	def displayResults(self, out, all, combName, counters):
Packit Service a31ea6
		out.write("\n")
Packit Service a31ea6
		if all:
Packit Service a31ea6
			if options.combines is not None:
Packit Service a31ea6
				out.write("combine(s): %s\n" % str(options.combines))
Packit Service a31ea6
		elif combName is not None:
Packit Service a31ea6
			out.write("combine : %s\n" % combName)
Packit Service a31ea6
		out.write("  total           : %d\n" % counters[self.CNT_TOTAL])
Packit Service a31ea6
		if all or options.combines is not None:
Packit Service a31ea6
			out.write("  ran             : %d\n" % counters[self.CNT_RAN])
Packit Service a31ea6
			out.write("    (schemata)    : %d\n" % counters[self.CNT_SCHEMA_TEST])
Packit Service a31ea6
		# out.write("    succeeded       : %d\n" % counters[self.CNT_SUCCEEDED])
Packit Service a31ea6
		out.write("  not accepted    : %d\n" % counters[self.CNT_NOTACCEPTED])
Packit Service a31ea6
		if counters[self.CNT_FAILED] > 0:		    
Packit Service a31ea6
			out.write("    failed                  : %d\n" % counters[self.CNT_FAILED])
Packit Service a31ea6
			out.write("     -> internal            : %d\n" % counters[self.CNT_INTERNAL])
Packit Service a31ea6
			out.write("     -> unimpl.             : %d\n" % counters[self.CNT_UNIMPLEMENTED])
Packit Service a31ea6
			out.write("     -> skip-invalid-schema : %d\n" % counters[self.CNT_NOSCHEMA])
Packit Service a31ea6
			out.write("     -> bad                 : %d\n" % counters[self.CNT_BAD])
Packit Service a31ea6
			out.write("     -> exceptions          : %d\n" % counters[self.CNT_EXCEPTED])
Packit Service a31ea6
			out.write("    memory leaks            : %d\n" % counters[self.CNT_MEMLEAK])
Packit Service a31ea6
Packit Service a31ea6
	def displayShortResults(self, out, all, combName, counters):
Packit Service a31ea6
		out.write("Ran %d of %d tests (%d schemata):" % (counters[self.CNT_RAN],
Packit Service a31ea6
				  counters[self.CNT_TOTAL], counters[self.CNT_SCHEMA_TEST]))
Packit Service a31ea6
		# out.write("    succeeded       : %d\n" % counters[self.CNT_SUCCEEDED])
Packit Service a31ea6
		if counters[self.CNT_NOTACCEPTED] > 0:
Packit Service a31ea6
			out.write(" %d not accepted" % (counters[self.CNT_NOTACCEPTED]))
Packit Service a31ea6
		if counters[self.CNT_FAILED] > 0 or counters[self.CNT_MEMLEAK] > 0:
Packit Service a31ea6
			if counters[self.CNT_FAILED] > 0:
Packit Service a31ea6
				out.write(" %d failed" % (counters[self.CNT_FAILED]))
Packit Service a31ea6
				out.write(" (")
Packit Service a31ea6
				if counters[self.CNT_INTERNAL] > 0:
Packit Service a31ea6
					out.write(" %d internal" % (counters[self.CNT_INTERNAL]))
Packit Service a31ea6
				if counters[self.CNT_UNIMPLEMENTED] > 0:
Packit Service a31ea6
					out.write(" %d unimplemented" % (counters[self.CNT_UNIMPLEMENTED]))
Packit Service a31ea6
				if counters[self.CNT_NOSCHEMA] > 0:
Packit Service a31ea6
					out.write(" %d skip-invalid-schema" % (counters[self.CNT_NOSCHEMA]))
Packit Service a31ea6
				if counters[self.CNT_BAD] > 0:
Packit Service a31ea6
					out.write(" %d bad" % (counters[self.CNT_BAD]))
Packit Service a31ea6
				if counters[self.CNT_EXCEPTED] > 0:
Packit Service a31ea6
					out.write(" %d exception" % (counters[self.CNT_EXCEPTED]))
Packit Service a31ea6
				out.write(" )")
Packit Service a31ea6
			if counters[self.CNT_MEMLEAK] > 0:
Packit Service a31ea6
				out.write(" %d leaks" % (counters[self.CNT_MEMLEAK]))			
Packit Service a31ea6
			out.write("\n")
Packit Service a31ea6
		else:
Packit Service a31ea6
			out.write(" all passed\n")
Packit Service a31ea6
Packit Service a31ea6
	def reportCombine(self, combName):
Packit Service a31ea6
		global options
Packit Service a31ea6
Packit Service a31ea6
		counters = self.createCounters()
Packit Service a31ea6
		#
Packit Service a31ea6
		# Compute evaluation counters.
Packit Service a31ea6
		#
Packit Service a31ea6
		for test in self.combinesRan[combName]:
Packit Service a31ea6
			counters[self.CNT_TOTAL] += 1
Packit Service a31ea6
			counters[self.CNT_RAN] += 1
Packit Service a31ea6
			counters = self.updateCounters(test, counters)
Packit Service a31ea6
		if options.reportErrCombines and (counters[self.CNT_FAILED] == 0) and (counters[self.CNT_MEMLEAK] == 0):
Packit Service a31ea6
			pass
Packit Service a31ea6
		else:
Packit Service a31ea6
			if options.enableLog:
Packit Service a31ea6
				self.displayResults(self.logFile, False, combName, counters)				
Packit Service a31ea6
			self.displayResults(sys.stdout, False, combName, counters)
Packit Service a31ea6
Packit Service a31ea6
	def displayTestLog(self, test):
Packit Service a31ea6
		sys.stdout.writelines(test.log)
Packit Service a31ea6
		sys.stdout.write("~~~~~~~~~~\n")
Packit Service a31ea6
Packit Service a31ea6
	def reportTest(self, test):
Packit Service a31ea6
		global options
Packit Service a31ea6
Packit Service a31ea6
		error = test.failed or test.memLeak != 0
Packit Service a31ea6
		#
Packit Service a31ea6
		# Only erroneous tests will be written to the log,
Packit Service a31ea6
		# except @verbose is switched on.
Packit Service a31ea6
		#
Packit Service a31ea6
		if options.enableLog and (options.verbose or error):
Packit Service a31ea6
			self.logFile.writelines(test.log)
Packit Service a31ea6
			self.logFile.write("~~~~~~~~~~\n")
Packit Service a31ea6
		#
Packit Service a31ea6
		# if not @silent, only erroneous tests will be
Packit Service a31ea6
		# written to stdout, except @verbose is switched on.
Packit Service a31ea6
		#
Packit Service a31ea6
		if not options.silent:
Packit Service a31ea6
			if options.reportInternalErrOnly and test.internalErr:
Packit Service a31ea6
				self.displayTestLog(test)
Packit Service a31ea6
			if options.reportMemLeakErrOnly and test.memLeak != 0:
Packit Service a31ea6
				self.displayTestLog(test)
Packit Service a31ea6
			if options.reportUnimplErrOnly and test.unimplemented:
Packit Service a31ea6
				self.displayTestLog(test)
Packit Service a31ea6
			if (options.verbose or error) and (not options.reportInternalErrOnly) and (not options.reportMemLeakErrOnly) and (not options.reportUnimplErrOnly):
Packit Service a31ea6
				self.displayTestLog(test)
Packit Service a31ea6
Packit Service a31ea6
Packit Service a31ea6
	def addToCombines(self, test):
Packit Service a31ea6
		found = False
Packit Service a31ea6
		if self.combinesRan.has_key(test.combineName):
Packit Service a31ea6
			self.combinesRan[test.combineName].append(test)
Packit Service a31ea6
		else:
Packit Service a31ea6
			self.combinesRan[test.combineName] = [test]
Packit Service a31ea6
Packit Service a31ea6
	def run(self):
Packit Service a31ea6
Packit Service a31ea6
		global options
Packit Service a31ea6
Packit Service a31ea6
		if options.info:
Packit Service a31ea6
			for test in self.testList:
Packit Service a31ea6
				self.addToCombines(test)
Packit Service a31ea6
			sys.stdout.write("Combines: %d\n" % len(self.combinesRan))
Packit Service a31ea6
			sys.stdout.write("%s\n" % self.combinesRan.keys())
Packit Service a31ea6
			return
Packit Service a31ea6
Packit Service a31ea6
		if options.enableLog:
Packit Service a31ea6
			self.logFile = open(options.logFile, "w")
Packit Service a31ea6
		try:
Packit Service a31ea6
			for test in self.testList:
Packit Service a31ea6
				self.counters[self.CNT_TOTAL] += 1
Packit Service a31ea6
				#
Packit Service a31ea6
				# Filter tests.
Packit Service a31ea6
				#
Packit Service a31ea6
				if options.singleTest is not None and options.singleTest != "":
Packit Service a31ea6
					if (test.name != options.singleTest):
Packit Service a31ea6
						continue
Packit Service a31ea6
				elif options.combines is not None:
Packit Service a31ea6
					if not options.combines.__contains__(test.combineName):
Packit Service a31ea6
						continue
Packit Service a31ea6
				elif options.testStartsWith is not None:
Packit Service a31ea6
					if not test.name.startswith(options.testStartsWith):
Packit Service a31ea6
						continue
Packit Service a31ea6
				elif options.combineStartsWith is not None:
Packit Service a31ea6
					if not test.combineName.startswith(options.combineStartsWith):
Packit Service a31ea6
						continue
Packit Service a31ea6
				
Packit Service a31ea6
				if options.maxTestCount != -1 and self.counters[self.CNT_RAN] >= options.maxTestCount:
Packit Service a31ea6
					break
Packit Service a31ea6
				self.counters[self.CNT_RAN] += 1
Packit Service a31ea6
				#
Packit Service a31ea6
				# Run the thing, dammit.
Packit Service a31ea6
				#
Packit Service a31ea6
				try:
Packit Service a31ea6
					test.setUp()
Packit Service a31ea6
					try:
Packit Service a31ea6
						test.run()
Packit Service a31ea6
					finally:
Packit Service a31ea6
						test.tearDown()
Packit Service a31ea6
				finally:
Packit Service a31ea6
					#
Packit Service a31ea6
					# Evaluate.
Packit Service a31ea6
					#
Packit Service a31ea6
					test.finalize()
Packit Service a31ea6
					self.reportTest(test)
Packit Service a31ea6
					if options.reportCombines or options.reportErrCombines:
Packit Service a31ea6
						self.addToCombines(test)
Packit Service a31ea6
					self.counters = self.updateCounters(test, self.counters)
Packit Service a31ea6
		finally:
Packit Service a31ea6
			if options.reportCombines or options.reportErrCombines:
Packit Service a31ea6
				#
Packit Service a31ea6
				# Build a report for every single combine.
Packit Service a31ea6
				#
Packit Service a31ea6
				# TODO: How to sort a dict?
Packit Service a31ea6
				#
Packit Service a31ea6
				self.combinesRan.keys().sort(None)
Packit Service a31ea6
				for key in self.combinesRan.keys():
Packit Service a31ea6
					self.reportCombine(key)
Packit Service a31ea6
Packit Service a31ea6
			#
Packit Service a31ea6
			# Display the final report.
Packit Service a31ea6
			#
Packit Service a31ea6
			if options.silent:
Packit Service a31ea6
				self.displayShortResults(sys.stdout, True, None, self.counters)
Packit Service a31ea6
			else:
Packit Service a31ea6
				sys.stdout.write("===========================\n")
Packit Service a31ea6
				self.displayResults(sys.stdout, True, None, self.counters)