view recipes/gnupg/gnupg2.py @ 141:2c942b75b98b

Extend the gnupg2 recipe so that it extracts the PKITS log.
author Bernhard Herzog <bh@intevation.de>
date Mon, 02 Jun 2008 15:58:13 +0000
parents 605f6784aae7
children 27e78096a3fe
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

import treepkg.packager
import treepkg.util

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))
        outfile = open(self.pkits_log, "w")
        outfile.writelines(testlog)
        outfile.close()


class RevisionPackager(treepkg.packager.RevisionPackager):

    source_packager_cls = SourcePackager
    binary_packager_cls = BinaryPackager

    pkits_log = treepkg.packager._filenameproperty("pkits_log.txt",
                                                   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)