def probar(intento, caso_de_prueba, mail):
def diff(prueba, mail, orig, new, name, origname='alumno', newname='catedra', longname=None):
from difflib import unified_diff, HtmlDiff
- #TODO diferenciar pruebas públicas de privadas
if longname is None: longname = name
diff = ''.join(list(unified_diff(orig, new, fromfile=name+'.'+origname, tofile=name+'.'+newname)))
nota = ''
if diff:
prueba.pasada = False
- nota = "- %s no coincide con lo esperado (archivo '%s.diff').\n" % (longname, name)
+ nota += "* %s no coincide con lo esperado (archivo '%s.diff').\n" % (longname, name)
+ nota += ('-' * 72) + '\n' + diff + ('-' * 72) + '\n'
if not prueba.casoDePrueba.privado:
mail.attachText(diff, name + '.diff')
diff = HtmlDiff().make_file(orig, new, fromdesc=name+'.'+origname, todesc=name+'.'+newname, context=True, numlines=3)
# Salió con una señal?
if proc.returncode < 0:
sig = -proc.returncode
+ # Conversor de nro de señal a string
sigs = {}
for s in [s for s in dir(signal) if s.startswith('SIG') and s.isalpha()]:
sigs[getattr(signal, s)] = s
caso_de_prueba.nombre + '.stderr', longname='La salida de error')
for f in caso_de_prueba.archivosSalida:
if f not in prueba.archivosSalida:
- #TODO agregar error FALTA ARCHIVO
log.debug('Falta el archivo %s y no lo hizo.', f)
prueba.pasada = False
- obs += "- Falta el archivo de salida '%s'.\n" % f
+ obs += "* Falta el archivo de salida '%s'.\n" % f
continue
obs += diff(prueba, mail,
file(os.path.join(intento.chrootPath, f)).readlines(),
file(os.path.join(caso_de_prueba.pathSalidas, f)).readlines(),
caso_de_prueba.nombre + '.' + f)
for f in prueba.archivosSalida - (caso_de_prueba.archivosSalida | caso_de_prueba.archivosEntrada):
- #TODO agregar error SOBRA ARCHIVO
log.debug('El programa debía generar el archivo %s y no lo hizo.', f)
prueba.pasada = False
- obs += "- Se generó un archivo ('%s') que no se esperaba.\n" % f
+ obs += "* Se generó un archivo ('%s') que no se esperaba.\n" % f
log.debug('Fin de ejecución de caso de prueba (hijo: %d, ret: %d)',
proc.pid, proc.returncode)
if obs: