- buffer = StringIO()
- zip = ZipFile(buffer, 'w')
- # Guardamos stdout/stderr
- if self.guardar_stdouterr:
- zip.write('/tmp/sercom.tester.%s.stdouterr'
- % comando_ejecutado.id, '__stdouterr__')
- else:
- if self.guardar_stdout:
- zip.write('/tmp/sercom.tester.%s.stdout'
- % comando_ejecutado.id, '__stdout__')
- if self.guardar_stderr:
- zip.write('/tmp/sercom.tester.%s.stderr'
- % comando_ejecutado.id, '__stderr__')
- # Guardamos otros
- for f in self.archivos_a_guardar:
- if not os.path.exists(join(path, f)):
+ if a_guardar:
+ buffer = StringIO()
+ zip = ZipFile(buffer, 'w')
+ # Guardamos stdout/stderr
+ if self.STDOUTERR in a_guardar:
+ a_guardar.remove(self.STDOUTERR)
+ zip.write('/tmp/sercom.tester.%s.stdouterr'
+ % comando_ejecutado.id, self.STDOUTERR)
+ else:
+ if self.STDOUT in a_guardar:
+ a_guardar.remove(self.STDOUT)
+ zip.write('/tmp/sercom.tester.%s.stdout'
+ % comando_ejecutado.id, self.STDOUT)
+ if self.STDERR in a_guardar:
+ a_guardar.remove(self.STDERR)
+ zip.write('/tmp/sercom.tester.%s.stderr'
+ % comando_ejecutado.id, self.STDERR)
+ # Guardamos otros
+ for f in a_guardar:
+ if not os.path.exists(join(path, f)):
+ if self.rechazar_si_falla:
+ entrega.correcta = False
+ comando_ejecutado.exito = False
+ comando_ejecutado.observaciones += _(u'Se esperaba un archivo '
+ u'"%s" para guardar pero no fue encontrado.\n') % f
+ log.debug(_(u'Se esperaba un archivo "%s" para guardar pero '
+ u'no fue encontrado'), f)
+ else:
+ zip.write(join(path, f), f)
+ zip.close()
+ comando_ejecutado.archivos_guardados = buffer.getvalue()
+ file('/tmp/guardado.zip', 'w').write(buffer.getvalue()) # XXX TODO FIXME sacar
+ def diff(new, zip_in, zip_out, name, longname=None, origname='correcto',
+ newname='entregado'):
+ if longname is None:
+ longname = name
+ new = file(new, 'r').readlines()
+ orig = zip_in.read(name).split('\n')
+ udiff = ''.join(list(unified_diff(orig, new, fromfile=name+'.'+origname,
+ tofile=name+'.'+newname)))
+ if udiff:
+ if self.rechazar_si_falla:
+ entrega.correcta = False