Mercurial > treepkg
view recipes/gnupg/gnupg2.py @ 441:eadcb1bb54e2
Merged revisions 388-399 via svnmerge from
svn+ssh://svn.wald.intevation.org/treepkg/branches/treepkg-status
........
r388 | bricks | 2010-07-28 10:38:50 +0200 (Mi, 28 Jul 2010) | 3 lines
fix if statement
upload hook should be called if it's not empty
........
r389 | bricks | 2010-07-28 13:38:00 +0200 (Mi, 28 Jul 2010) | 2 lines
only rsync specified architectures from cachedir to publishdir
........
r390 | bricks | 2010-07-29 14:07:57 +0200 (Do, 29 Jul 2010) | 2 lines
introduced after_copy_hook and made rsync upload to publishdir optional
........
r391 | bricks | 2010-07-29 15:43:39 +0200 (Do, 29 Jul 2010) | 3 lines
publish package must be default to get original behaviour
be more verbose at publishing
........
r392 | bricks | 2010-07-29 16:50:53 +0200 (Do, 29 Jul 2010) | 2 lines
fix handling of showing only successfull builds together with num packages
........
r393 | bricks | 2010-07-29 16:52:42 +0200 (Do, 29 Jul 2010) | 2 lines
fixed typo
........
r394 | bricks | 2010-07-29 16:59:10 +0200 (Do, 29 Jul 2010) | 2 lines
fixed another typo
........
r395 | bricks | 2010-07-29 18:05:54 +0200 (Do, 29 Jul 2010) | 3 lines
fixed another typo
treepkg is really slow with many revisions
........
r396 | bricks | 2010-08-02 12:41:55 +0200 (Mo, 02 Aug 2010) | 2 lines
fixed typos
........
r397 | bricks | 2010-08-02 17:36:12 +0200 (Mo, 02 Aug 2010) | 3 lines
be more error prone in listing different files
not checking if a dir exists caused several errors if a build wasn't successful
........
r398 | bricks | 2010-08-05 18:21:47 +0200 (Do, 05 Aug 2010) | 2 lines
review changes
........
r399 | bricks | 2010-08-06 13:06:08 +0200 (Fr, 06 Aug 2010) | 4 lines
cleanup modules
fix test_info testcases
added testcases for remove_trailingslashes and expand_filename
........
author | Bjoern Ricks <bricks@intevation.de> |
---|---|
date | Fri, 06 Aug 2010 13:41:54 +0000 |
parents | e4512f045999 |
children |
line wrap: on
line source
# Copyright (C) 2008 by Intevation GmbH # Authors: # Bernhard Herzog <bh@intevation.de> # # This program is free software under the GPL (>=v2) # Read the file COPYING coming with the software for details. """Recipe to build gnugp2 from SVN""" import os import shutil import logging import re from genshi.template import TemplateLoader import treepkg.packager import treepkg.util import treepkg.report import base base.define_gnupg_packager("gnupg2") class BinaryPackager(treepkg.packager.BinaryPackager): pkits_log = treepkg.packager._fromparent("pkits_log") def package(self): self.status.creating_binary_package() treepkg.util.ensure_directory(self.binary_dir) self.create_pkits_workdir() try: logging.info("Building binary package; logging to %r", self.logfile) extra_env=dict(GNUPG_PKITS_DIRECTORY=self.pkits_workdir) self.track.builder.build(self.dsc_file, self.binary_dir, self.logfile, bindmounts=[self.pkits_workdir], extra_packages=["bzip2"], extra_env=extra_env) self.extract_pkits_log() finally: self.remove_pkits_workdir() self.status.binary_package_created() def create_pkits_workdir(self): self.pkits_workdir = os.path.join(self.parent.base_dir, "pkits-work") treepkg.util.ensure_directory(self.pkits_workdir) shutil.copy(os.path.join(self.track.checkout_dir, "tests", "pkits", "PKITS_data.tar.bz2"), self.pkits_workdir) def remove_pkits_workdir(self): shutil.rmtree(self.pkits_workdir) def extract_pkits_log(self): testlog = None for line in open(self.logfile): if re.match("--------- END PKITS LOG ---------", line): break elif re.match("-------- BEGIN PKITS LOG --------", line): testlog = [] elif testlog is not None and line[:1] in "0123456789": testlog.append(line) else: logging.info("Could not find PKITS LOG in %s", self.logfile) return treepkg.util.ensure_directory(os.path.dirname(self.pkits_log)) treepkg.util.writefile(self.pkits_log, self.htmlize_pkits_log(testlog), 0644) def htmlize_pkits_log(self, raw_lines): loader = TemplateLoader([os.path.dirname(__file__)]) template = loader.load("pkits.html") pkits = treepkg.report.struct(revision=self.parent.revision, lines=raw_lines) stream = template.generate(pkits=pkits) return stream.render('html') class RevisionPackager(treepkg.packager.RevisionPackager): source_packager_cls = SourcePackager binary_packager_cls = BinaryPackager pkits_log = treepkg.util.filenameproperty("pkits_log.html", dir_attr="log_dir") def list_log_files(self): files = super(RevisionPackager, self).list_log_files() if os.path.exists(self.pkits_log): files.append(("PKITS log", self.pkits_log)) return files