deb-mock/mock/py/mockbuild/plugins/sign.py
robojerk 4c0dcb2522
Some checks failed
Build Deb-Mock Package / build (push) Successful in 54s
Lint Code / Lint All Code (push) Failing after 1s
Test Deb-Mock Build / test (push) Failing after 36s
enhance: Add comprehensive .gitignore for deb-mock project
- Add mock-specific build artifacts (chroot/, mock-*, mockroot/)
- Include package build files (*.deb, *.changes, *.buildinfo)
- Add development tools (.coverage, .pytest_cache, .tox)
- Include system files (.DS_Store, Thumbs.db, ._*)
- Add temporary and backup files (*.tmp, *.bak, *.backup)
- Include local configuration overrides (config.local.yaml, .env.local)
- Add test artifacts and documentation builds
- Comprehensive coverage for Python build system project

This ensures build artifacts, chroot environments, and development
tools are properly ignored in version control.
2025-08-18 23:37:49 -07:00

43 lines
1.4 KiB
Python

# -*- coding: utf-8 -*-
# vim:expandtab:autoindent:tabstop=4:shiftwidth=4:filetype=python:textwidth=0:
# License: GPL2 or later see COPYING
# Written by Julien BALLET <lta@fb.com>
# Copyright (C) 2014 Facebook
# python library imports
import os
import subprocess
from mockbuild.trace_decorator import getLog, traceLog
requires_api_version = "1.1"
# plugin entry point
@traceLog()
def init(plugins, conf, buildroot):
Sign(plugins, conf, buildroot)
class Sign(object):
"""Automatically sign package after build"""
@traceLog()
def __init__(self, plugins, conf, buildroot):
self.plugins = plugins
self.conf = conf
self.buildroot = buildroot
self.plugins.add_hook('postbuild', self.sign_results)
getLog().info(conf)
getLog().info("enabled package signing")
def sign_results(self):
if self.buildroot.final_rpm_list:
rpms = [os.path.join(self.buildroot.resultdir, rpm) for rpm in self.buildroot.final_rpm_list]
if rpms:
getLog().info("Signing %s", ', '.join(rpms))
opts = self.conf['opts'] % {'rpms': ' '.join(rpms), 'resultdir': self.buildroot.resultdir}
cmd = "{0} {1}".format(self.conf['cmd'], opts)
getLog().info("Executing %s", cmd)
with self.buildroot.uid_manager:
subprocess.check_call(cmd, shell=True, env=os.environ)