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
This site is hosted by Intevation GmbH (Datenschutzerklärung und Impressum | Privacy Policy and Imprint)