blob: cd9e5729a2da2ab87479fbc8164595bc5e63fdd6 [file] [log] [blame]
import xml.sax.saxutils
import time
def make_test_name( library_idx, test_idx ):
return "test_%02d_%02d" % ( library_idx, test_idx )
def make_library_name( library_idx ):
if library_idx % 4 in ( 0, 1 ):
return "library_%02d/%02d" % ( int( library_idx / 4 ) * 4, library_idx % 4 )
else:
return "library_%02d" % library_idx
def make_toolset_name( toolset_idx ):
return "toolset_%02d" % toolset_idx
def make_library_target_directory( library_idx, toolset_idx, variant = None ):
base = "lib/%s/%s" % ( make_library_name( library_idx )
, make_toolset_name( toolset_idx ) )
if variant is not None:
return "%s/%s" % ( base, variant )
else:
return base
def make_test_target_directory( library_idx, toolset_idx, test_name, variant ):
base = "%s/%s/%s" % ( make_library_name( library_idx )
, make_toolset_name( toolset_idx )
, test_name )
if variant is not None:
return "%s/%s" % ( base, variant )
else:
return base
def format_timestamp( timestamp ):
return time.strftime( "%Y-%m-%dT%H:%M:%SZ", timestamp )
def make_test_log( xml_generator
, library_idx
, toolset_idx
, test_name
, test_type
, test_result
, show_run_output
, variant ):
library = make_library_name( library_idx )
toolset_name = make_toolset_name( toolset_idx )
target_directory = ""
if test_type != "lib":
target_directory = make_test_target_directory( library_idx, toolset_idx, test_name, variant )
else:
target_directory = make_library_target_directory( library_idx, toolset_idx, variant )
xml_generator.startElement( "test-log", { "library": library
, "test-name": test_name
, "toolset": toolset_name
, "test-type": test_type
, "test-program": "some_program"
, "target-directory": target_directory
, "show-run-output": show_run_output
} )
if test_type != "lib":
if test_result == "success" and ( toolset_idx + 1 ) % 4:
xml_generator.startElement( "compile", { "result": "success" } );
xml_generator.characters( "Compiling in %s" % target_directory )
xml_generator.endElement( "compile" )
if test_type.find( "link" ) == 0 or test_type.find( "run" ) == 0 and toolset_idx % 4:
xml_generator.startElement( "lib", { "result": test_result } );
xml_generator.characters( make_library_target_directory( library_idx, toolset_idx ) )
xml_generator.endElement( "lib" )
xml_generator.startElement( "link", { "result": "success" } );
xml_generator.characters( "Linking in %s" % target_directory )
xml_generator.endElement( "link" )
if test_type.find( "run" ) == 0 and ( toolset_idx + 2 ) % 4:
xml_generator.startElement( "run", { "result": test_result } );
xml_generator.characters( "Running in %s" % target_directory )
xml_generator.endElement( "run" )
else:
xml_generator.startElement( "compile", { "result": test_result } );
xml_generator.characters( "Compiling in %s" % make_library_target_directory( library_idx, toolset_idx ) )
xml_generator.endElement( "compile" )
xml_generator.endElement( "test-log" )
def make_expicit_failure_markup( num_of_libs, num_of_toolsets, num_of_tests ):
g = xml.sax.saxutils.XMLGenerator( open( "explicit-failures-markup.xml", "w" ), "utf-8" )
g.startDocument()
g.startElement( "explicit-failures-markup", {} );
# required toolsets
for i_toolset in range( 0, num_of_toolsets ):
if i_toolset < 2:
g.startElement( "mark-toolset", { "name": "toolset_%02d" % i_toolset, "status":"required"} )
g.endElement( "mark-toolset" )
for i_library in range( 0, num_of_libs ):
g.startElement( "library", { "name": make_library_name( i_library ) } )
if i_library % 4 == 0:
g.startElement( "mark-unusable", {} )
for i_toolset in range( 0, num_of_toolsets ):
if i_toolset % 2 == 1:
g.startElement( "toolset", { "name": make_toolset_name( i_toolset ) } )
g.endElement( "toolset" )
g.startElement( "note", { "author": u"T. T\xe8st" } )
g.characters( "Test note" )
g.endElement( "note" )
g.endElement( "mark-unusable" )
for i_test in range( 0, num_of_tests ):
category = 0
explicitly_marked_failure = 0
unresearched = 0
if i_test % 2 == 0:
category = i_test % 3
if i_test % 3 == 0:
explicitly_marked_failure = 1
if i_test % 2 == 0:
unresearched = 1
if category or explicitly_marked_failure:
test_attrs = { "name": make_test_name( i_library, i_test ) }
if category:
test_attrs[ "category" ] = "Category %s" % category
g.startElement( "test", test_attrs )
if explicitly_marked_failure:
failure_attrs = {}
if unresearched: failure_attrs[ "reason" ] = "not-researched"
g.startElement( "mark-failure", failure_attrs )
g.startElement( "toolset", { "name": make_toolset_name( 1 ) } )
g.endElement( "toolset" )
g.startElement( "toolset", { "name": make_toolset_name( 0 ) } )
g.endElement( "toolset" )
g.startElement( "toolset", { "name": make_toolset_name( 2 ) } )
g.endElement( "toolset" )
g.startElement( "note", { "author": u"V. Ann\xf3tated" } )
g.characters( "Some thoughtful note" )
g.endElement( "note" )
g.endElement( "mark-failure" )
g.endElement( "test" );
g.endElement( "library" )
g.endElement( "explicit-failures-markup" )
g.endDocument()
def make_expected_results( num_of_libs, num_of_toolsets, num_of_tests ):
pass