from sqlobject import *
from sqlobject.sqlbuilder import *
+import errno
+import os
from os import path
__all__ = ('Curso', 'Inscripto', 'Docente', 'Ejercicio', 'Entrega',
def _get_path(self):
return path.join(self.ejercicio.path, 'casos_de_prueba', self.nombre)
+ def _get_pathEntradas(self):
+ return path.join(self.path, 'entradas')
+
+ def _get_pathSalidas(self):
+ return path.join(self.path, 'salidas')
+
def _get_archivosEntrada(self):
try:
- return os.listdir(path.join(self.path, 'entradas'))
- except:
- return []
+ return frozenset(os.listdir(self.pathEntradas))
+ except OSError, (err, msg):
+ if err == errno.ENOENT:
+ return frozenset()
+ else:
+ raise
def _get_archivosSalida(self):
try:
- return os.listdir(path.join(self.path, 'salidas'))
- except:
- return []
+ return frozenset(os.listdir(self.pathSalidas))
+ except OSError, (err, msg):
+ if err == errno.ENOENT:
+ return frozenset()
+ else:
+ raise
class Intento(BaseSQLObject):
# Clave
'%s.%s.%s' % (curso.curso, entrega.nroEjercicio, entrega.entrega),
'%s.%s' % (self.inscripto.padron, self.numero))
+ def _get_chrootPath(self):
+ return path.join(self.path, 'chroot')
+
def _get_pruebasPasadas(self):
for p in self.pruebas:
if not p.pasada:
pasada = BoolCol(default = None)
observaciones = StringCol(default = None)
+ def _get_archivosSalida(self):
+ ent = self.casoDePrueba.archivosEntrada
+ sal = self.casoDePrueba.archivosSalida
+ return frozenset([f for f in os.listdir(self.intento.chrootPath) \
+ if f in sal or f not in ent and f <> 'tp'])
+
# vim: set et sw=4 sts=4 :