X-Git-Url: https://git.llucax.com/software/sercom-old.git/blobdiff_plain/03ce95b6b4735ac353999a4ee8969762a3a25766..330b4d4054a7e9a47b376a1ba51e1ec8efe8e9a0:/src/sercom/sqlo.py diff --git a/src/sercom/sqlo.py b/src/sercom/sqlo.py index 9673e00..c81e066 100644 --- a/src/sercom/sqlo.py +++ b/src/sercom/sqlo.py @@ -16,7 +16,7 @@ class BaseSQLObject(SQLObject): @classmethod def by(cls, **kw): try: - return cls.selectBy(limit=1, **kw)[0] + return cls.selectBy(**kw)[0] except IndexError: raise SQLObjectNotFound, "The object %s with columns %s does not exist" % (cls.__name__, kw) @@ -35,18 +35,18 @@ class Curso(BaseSQLObject): class Inscripto(BaseSQLObject): # Clave - padron = IntCol(alternateID = True) + padron = IntCol(alternateID=True) # Campos curso = ForeignKey('Curso') mail = StringCol() - activo = BoolCol(default = True) + activo = BoolCol(default=True) # Joins intentos = MultipleJoin('Intento') correcciones = MultipleJoin('Correccion') class Docente(BaseSQLObject): # Clave - nombre = StringCol(alternateID = True) + nombre = StringCol(alternateID=True) # Campos mail = StringCol() corrige = BoolCol() @@ -62,7 +62,7 @@ class Ejercicio(BaseSQLObject): numero = Col() docente = ForeignKey('Docente') # Joins - casosDePrueba = MultipleJoin('CasoDePrueba', joinMethodName='casosDePrueba') # XXX hack + casosDePrueba = MultipleJoin('CasoDePrueba') entregas = MultipleJoin('Entrega') cursos = RelatedJoin('Curso', intermediateTable = 'entrega') @@ -96,10 +96,10 @@ class CasoDePrueba(BaseSQLObject): nombre = StringCol() # Campos privado = BoolCol() - activo = BoolCol(default = True) - parametros = StringCol(default = None) - codigoRetorno = IntCol(default = False) - tiempoCpu = FloatCol(default = None) + activo = BoolCol(default=True) + parametros = StringCol(default=None) + codigoRetorno = IntCol(default=False) + tiempoCpu = FloatCol(default=None) # Joins pruebas = MultipleJoin('Prueba') @@ -137,13 +137,13 @@ class Intento(BaseSQLObject): numero = IntCol() # Campos llegada = DateTimeCol() - inicioCompila = DateTimeCol(default = None) - finCompila = DateTimeCol(default = None) - inicioPruebas = DateTimeCol(default = None) - finPruebas = DateTimeCol(default = None) - compila = BoolCol(default = None) + inicioCompila = DateTimeCol(default=None) + finCompila = DateTimeCol(default=None) + inicioPruebas = DateTimeCol(default=None) + finPruebas = DateTimeCol(default=None) + compila = BoolCol(default=None) mailRespuesta = StringCol() - observaciones = StringCol(default = None) + observaciones = StringCol(default=None) # Joins pruebas = MultipleJoin('Prueba') @@ -155,6 +155,17 @@ class Intento(BaseSQLObject): except IndexError: return None + @classmethod + def faltaCompilar(cls, entrega, connection=None): + no_compilados = cls.selectBy(entregaID=entrega.id, compila=None, + connection=connection).count() + no_probados = cls.selectBy(entregaID=entrega.id, compila=True, + finPruebas=None, connection=connection).count() + return no_compilados + no_probados + + def chrootPath(self, caso_de_prueba): + return path.join(self.path, 'pruebas', caso_de_prueba.nombre) + def _get_path(self): curso = self.inscripto.curso entrega = self.entrega @@ -163,22 +174,21 @@ class Intento(BaseSQLObject): '%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): + if not self.compila: return False for p in self.pruebas: - if not p.pasada: - return False + if not p.pasada: return False return True def _get_pruebasPublicasPasadas(self): + if not self.compila: return False for p in self.pruebas: if not p.pasada and not p.casoDePrueba.privado: return False return True def _get_pruebasPrivadasPasadas(self): + if not self.compila: return False for p in self.pruebas: if not p.pasada and p.casoDePrueba.privado: return False @@ -186,13 +196,13 @@ class Intento(BaseSQLObject): class Correccion(BaseSQLObject): # Clave - entrega = ForeignKey('Ejercicio') + entrega = ForeignKey('Entrega') inscripto = ForeignKey('Inscripto') # Campos intento = ForeignKey('Intento') docente = ForeignKey('Docente') - nota = IntCol(default = None) - observaciones = StringCol(default = None) + nota = IntCol(default=None) + observaciones = StringCol(default=None) class Prueba(BaseSQLObject): # Clave @@ -200,14 +210,14 @@ class Prueba(BaseSQLObject): casoDePrueba = ForeignKey('CasoDePrueba') # Campos inicio = DateTimeCol() - fin = DateTimeCol(default = None) - pasada = BoolCol(default = None) - observaciones = StringCol(default = None) + fin = DateTimeCol(default=None) + 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) \ + return frozenset([f for f in os.listdir(self.intento.chrootPath(self.casoDePrueba)) \ if f in sal or f not in ent and f <> 'tp']) # vim: set et sw=4 sts=4 :