class Fields(W.WidgetsList):
tareaID = W.HiddenField()
orden = W.TextField(label=_(u'Orden'), validator=V.Int(not_empty=True))
- comando = W.TextField(label=_(u'Comando'), validator=V.UnicodeString(min=3, max=255, strip=True))
- descripcion = W.TextField(label=_(u'Descripcion'), validator=V.UnicodeString(min=3, max=255, strip=True))
- retorno = W.TextField(label=_(u'Retorno'), help_text=u"Codigo de retorno esperado",validator=V.Int(if_empty=0))
+ comando = W.TextField(label=_(u'Comando'), validator=V.UnicodeString(max=255, strip=True))
+ descripcion = W.TextField(label=_(u'Descripcion'), validator=V.UnicodeString(min=5, max=255, strip=True))
+ retorno = W.TextField(label=_(u'Retorno'), help_text=u"Codigo de retorno esperado",validator=V.Int(if_empty=ComandoPrueba.RET_PRUEBA))
max_tiempo_cpu = W.TextField(label=_(u'CPU'), help_text=u"Maximo tiempo de CPU que puede utilizar [seg]",validator=V.Int())
max_memoria = W.TextField(label=_(u'Memoria'), help_text=u"Maximo cantidad de memoria que puede utilizar [MB]",validator=V.Int())
max_tam_archivo = W.TextField(label=_(u'Tam. Archivo'), help_text=u"Maximo tamanio de archivo a crear [MB]",validator=V.Int())
terminar_si_falla = W.CheckBox(label=_(u'Terminar si falla?'), default=1, validator=V.Bool(if_empty=1))
rechazar_si_falla = W.CheckBox(label=_(u'Rechazar si falla?'), default=1, validator=V.Bool(if_empty=1))
publico = W.CheckBox(label=_(u'Es público?'), default=1, validator=V.Bool(if_empty=1))
- archivos_entrada = W.FileField(label=_(u'Archivos Entrada'))
- archivos_a_comparar = W.FileField(label=_(u'Archivos a Comparar'))
+ los_archivos_entrada = W.FileField(label=_(u'Archivos Entrada'))
+ los_archivos_a_comparar = W.FileField(label=_(u'Archivos a Comparar'))
archivos_guardar = W.TextField(label=_(u'Archivos a Guardar'))
activo = W.CheckBox(label=_(u'Activo'), default=1, validator=V.Bool(if_empty=1))
fields = Fields()
"""Save or create record to model"""
t = TareaPrueba.get(kw['tareaID'])
orden = kw['orden']
- del(kw['orden'])
- del(kw['tareaID'])
- if kw['archivos_entrada'].filename:
- kw['archivos_entrada'] = kw['archivos_entrada'].file.read()
- else:
- kw['archivos_entrada'] = None
- if kw['archivos_a_comparar'].filename:
- kw['archivos_a_comparar'] = kw['archivos_a_comparar'].file.read()
- else:
- kw['archivos_a_comparar'] = None
+ del kw['orden']
+ del kw['tareaID']
+ if kw['los_archivos_entrada'].filename:
+ kw['archivos_entrada'] = kw['los_archivos_entrada'].file.read()
+ del kw['los_archivos_entrada']
+ if kw['los_archivos_a_comparar'].filename:
+ kw['archivos_a_comparar'] = kw['los_archivos_a_comparar'].file.read()
+ del kw['los_archivos_a_comparar']
# TODO : Hacer ventanita mas amigable para cargar esto.
try:
kw['archivos_a_guardar'] = tuple(kw['archivos_guardar'].split(','))
except AttributeError:
pass
- del(kw['archivos_guardar'])
+ del kw['archivos_guardar']
t.add_comando(orden, **kw)
flash(_(u'Se creó un nuevo %s.') % name)
raise redirect('list/%d' % t.id)
@expose()
def update(self, id, **kw):
"""Save or create record to model"""
+ orden = kw['orden']
+ del kw['orden']
+ del kw['tareaID']
+ if kw['los_archivos_entrada'].filename:
+ kw['archivos_entrada'] = kw['los_archivos_entrada'].file.read()
+ del kw['los_archivos_entrada']
+ if kw['los_archivos_a_comparar'].filename:
+ kw['archivos_a_comparar'] = kw['los_archivos_a_comparar'].file.read()
+ del kw['los_archivos_a_comparar']
+ # TODO : Hacer ventanita mas amigable para cargar esto.
+ try:
+ kw['archivos_a_guardar'] = tuple(kw['archivos_guardar'].split(','))
+ except AttributeError:
+ pass
+ del kw['archivos_guardar']
r = validate_set(id, kw)
flash(_(u'El %s fue actualizado.') % name)
raise redirect('../list/%d' % r.tarea.id)
def show(self,id, **kw):
"""Show record in model"""
r = validate_get(id)
- if r.observaciones is None:
- r.obs = ''
- else:
- r.obs = publish_parts(r.observaciones, writer_name='html')['html_body']
return dict(name=name, namepl=namepl, record=r)
@expose()
flash(_(u'El %s fue eliminado permanentemente.') % name)
raise redirect('../list/%d' % tareaID)
+ @expose()
+ def file(self, name, id):
+ from cherrypy import request, response
+ r = validate_get(id)
+ response.headers["Content-Type"] = "application/zip"
+ response.headers["Content-disposition"] = "attachment;filename=%s_%d.zip" % (name, r.id)
+ if name == "archivos_entrada":
+ ret = r.archivos_entrada
+ elif name == "archivos_a_comparar":
+ ret = r.archivos_a_comparar
+ else:
+ raise NotFound
+ return ret
#}}}