mirror of
https://github.com/openSUSE/osc.git
synced 2025-01-01 04:36:13 +01:00
Merge pull request #1500 from dmach/fix-buildinfo
Fix 'buildinfo' command
This commit is contained in:
commit
557d6ef868
137
osc/build.py
137
osc/build.py
@ -11,8 +11,9 @@ import re
|
||||
import shutil
|
||||
import subprocess
|
||||
import sys
|
||||
|
||||
from tempfile import NamedTemporaryFile, mkdtemp
|
||||
from typing import List
|
||||
from typing import Optional
|
||||
from urllib.parse import urlsplit
|
||||
from urllib.request import URLError, HTTPError
|
||||
from xml.etree import ElementTree as ET
|
||||
@ -481,7 +482,6 @@ def get_repo(path):
|
||||
return None
|
||||
|
||||
|
||||
|
||||
def get_prefer_pkgs(dirs, wanted_arch, type, cpio):
|
||||
paths = []
|
||||
repositories = []
|
||||
@ -670,6 +670,76 @@ def run_build(opts, *args):
|
||||
return run_external(cmd[0], *cmd[1:])
|
||||
|
||||
|
||||
def create_build_descr_data(
|
||||
build_descr_path: Optional[str],
|
||||
*,
|
||||
build_type: Optional[str],
|
||||
repo: Optional[str] = None,
|
||||
arch: Optional[str] = None,
|
||||
prefer_pkgs: Optional[List[str]] = None,
|
||||
define: Optional[List[str]] = None,
|
||||
define_with: Optional[List[str]] = None,
|
||||
define_without: Optional[List[str]] = None,
|
||||
):
|
||||
if build_descr_path:
|
||||
build_descr_path = os.path.abspath(build_descr_path)
|
||||
topdir = os.path.dirname(build_descr_path)
|
||||
else:
|
||||
topdir = None
|
||||
result_data = []
|
||||
|
||||
if build_descr_path:
|
||||
print(f"Using local file: {os.path.basename(build_descr_path)}", file=sys.stderr)
|
||||
with open(build_descr_path, "rb") as f:
|
||||
build_descr_data = f.read()
|
||||
|
||||
# HACK: there's no api to provide custom defines
|
||||
# TODO: check if we're working with a spec?
|
||||
defines: List[bytes] = []
|
||||
for i in define or []:
|
||||
defines.append(f"%define {i}".encode("utf-8"))
|
||||
for i in define_with or []:
|
||||
defines.append(f"%define _with_{i} 1".encode("utf-8"))
|
||||
for i in define_without or []:
|
||||
defines.append(f"%define _without_{i} 1".encode("utf-8"))
|
||||
if defines:
|
||||
build_descr_data = b"\n".join(defines) + b"\n\n" + build_descr_data
|
||||
|
||||
# build recipe must go first for compatibility with the older OBS versions
|
||||
result_data.append((os.path.basename(build_descr_path).encode("utf-8"), build_descr_data))
|
||||
|
||||
if topdir:
|
||||
buildenv_file = os.path.join(topdir, f"_buildenv.{repo}.{arch}")
|
||||
if not os.path.isfile(buildenv_file):
|
||||
buildenv_file = os.path.join(topdir, f"_buildenv")
|
||||
if os.path.isfile(buildenv_file):
|
||||
print(f"Using local file: {os.path.basename(buildenv_file)}", file=sys.stderr)
|
||||
with open(buildenv_file, "rb") as f:
|
||||
result_data.append((b"buildenv", f.read()))
|
||||
|
||||
if topdir:
|
||||
service_file = os.path.join(topdir, "_service")
|
||||
if os.path.isfile(service_file):
|
||||
print("Using local file: _service", file=sys.stderr)
|
||||
with open(service_file, "rb") as f:
|
||||
result_data.append((b"_service", f.read()))
|
||||
|
||||
if not result_data and not prefer_pkgs:
|
||||
return None, None
|
||||
|
||||
cpio_data = cpio.CpioWrite()
|
||||
for key, value in result_data:
|
||||
cpio_data.add(key, value)
|
||||
|
||||
if prefer_pkgs:
|
||||
print("Scanning the following dirs for local preferred packages: {', '.join(dirs)}", file=sys.stderr)
|
||||
prefer_pkgs_result = get_prefer_pkgs(prefer_pkgs, arch, build_type, cpio_data)
|
||||
else:
|
||||
prefer_pkgs_result = None
|
||||
|
||||
return cpio_data.get(), prefer_pkgs_result
|
||||
|
||||
|
||||
def main(apiurl, store, opts, argv):
|
||||
|
||||
repo = argv[0]
|
||||
@ -898,59 +968,16 @@ def main(apiurl, store, opts, argv):
|
||||
if xp:
|
||||
extra_pkgs += xp
|
||||
|
||||
prefer_pkgs = {}
|
||||
build_descr_data = open(build_descr, 'rb').read()
|
||||
|
||||
# XXX: dirty hack but there's no api to provide custom defines
|
||||
if opts.without:
|
||||
s = ''
|
||||
for i in opts.without:
|
||||
s += "%%define _without_%s 1\n" % i
|
||||
build_descr_data = s.encode() + build_descr_data
|
||||
if opts._with:
|
||||
s = ''
|
||||
for i in opts._with:
|
||||
s += "%%define _with_%s 1\n" % i
|
||||
build_descr_data = s.encode() + build_descr_data
|
||||
if opts.define:
|
||||
s = ''
|
||||
for i in opts.define:
|
||||
s += "%%define %s\n" % i
|
||||
build_descr_data = s.encode() + build_descr_data
|
||||
|
||||
cpiodata = None
|
||||
servicefile = os.path.join(os.path.dirname(build_descr), "_service")
|
||||
if not os.path.isfile(servicefile):
|
||||
servicefile = os.path.join(os.path.dirname(build_descr), "_service")
|
||||
if not os.path.isfile(servicefile):
|
||||
servicefile = None
|
||||
else:
|
||||
print('Using local _service file')
|
||||
buildenvfile = os.path.join(os.path.dirname(build_descr), "_buildenv." + repo + "." + arch)
|
||||
if not os.path.isfile(buildenvfile):
|
||||
buildenvfile = os.path.join(os.path.dirname(build_descr), "_buildenv")
|
||||
if not os.path.isfile(buildenvfile):
|
||||
buildenvfile = None
|
||||
else:
|
||||
print('Using local buildenv file: %s' % os.path.basename(buildenvfile))
|
||||
if buildenvfile or servicefile:
|
||||
if not cpiodata:
|
||||
cpiodata = cpio.CpioWrite()
|
||||
|
||||
if opts.prefer_pkgs:
|
||||
print('Scanning the following dirs for local packages: %s' % ', '.join(opts.prefer_pkgs))
|
||||
if not cpiodata:
|
||||
cpiodata = cpio.CpioWrite()
|
||||
prefer_pkgs = get_prefer_pkgs(opts.prefer_pkgs, arch, build_type, cpiodata)
|
||||
|
||||
if cpiodata:
|
||||
cpiodata.add(os.path.basename(build_descr.encode()), build_descr_data)
|
||||
# buildenv must come last for compatibility reasons...
|
||||
if buildenvfile:
|
||||
cpiodata.add(b"buildenv", open(buildenvfile, 'rb').read())
|
||||
if servicefile:
|
||||
cpiodata.add(b"_service", open(servicefile, 'rb').read())
|
||||
build_descr_data = cpiodata.get()
|
||||
build_descr_data, prefer_pkgs = create_build_descr_data(
|
||||
build_descr,
|
||||
build_type=build_type,
|
||||
repo=repo,
|
||||
arch=arch,
|
||||
prefer_pkgs=opts.prefer_pkgs,
|
||||
define=opts.define,
|
||||
define_with=opts._with,
|
||||
define_without=opts.without,
|
||||
)
|
||||
|
||||
# special handling for overlay and rsync-src/dest
|
||||
specialcmdopts = []
|
||||
|
@ -21,6 +21,7 @@ import traceback
|
||||
from functools import cmp_to_key
|
||||
from operator import itemgetter
|
||||
from pathlib import Path
|
||||
from tempfile import NamedTemporaryFile
|
||||
from typing import List
|
||||
from urllib.parse import urlsplit
|
||||
from urllib.error import HTTPError
|
||||
@ -6642,6 +6643,8 @@ Please submit there instead, or use --nodevelproject to force direct submission.
|
||||
help='Add this package when computing the buildinfo')
|
||||
@cmdln.option('-p', '--prefer-pkgs', metavar='DIR', action='append',
|
||||
help='Prefer packages from this directory when installing the build-root')
|
||||
@cmdln.option('--nodebugpackages', '--no-debug-packages', action='store_true',
|
||||
help='Skip installation of additional debug packages for CLI builds (specified in obs:cli_debug_packages in project metadata)')
|
||||
def do_buildinfo(self, subcmd, opts, *args):
|
||||
"""
|
||||
Shows the build info
|
||||
@ -6701,28 +6704,50 @@ Please submit there instead, or use --nodevelproject to force direct submission.
|
||||
|
||||
apiurl = self.get_api_url()
|
||||
|
||||
build_descr_data = None
|
||||
if build_descr is not None:
|
||||
build_descr_data = open(build_descr, 'rb').read()
|
||||
if opts.prefer_pkgs and build_descr_data is None:
|
||||
raise oscerr.WrongArgs('error: a build description is needed if \'--prefer-pkgs\' is used')
|
||||
elif opts.prefer_pkgs:
|
||||
print(f"Scanning the following dirs for local packages: {', '.join(opts.prefer_pkgs)}")
|
||||
cpiodata = cpio.CpioWrite()
|
||||
prefer_pkgs = osc_build.get_prefer_pkgs(opts.prefer_pkgs, arch,
|
||||
os.path.splitext(build_descr)[1],
|
||||
cpiodata)
|
||||
cpiodata.add(os.path.basename(build_descr.encode()), build_descr_data)
|
||||
build_descr_data = cpiodata.get()
|
||||
# TODO: refactor retrieving build type in build.py and use it here or directly in create_build_descr_data()
|
||||
if build_descr:
|
||||
build_type = os.path.splitext(build_descr)[1]
|
||||
else:
|
||||
build_type = None
|
||||
|
||||
build_descr_data, prefer_pkgs = osc_build.create_build_descr_data(
|
||||
build_descr,
|
||||
build_type=build_type,
|
||||
repo=repository,
|
||||
arch=arch,
|
||||
prefer_pkgs=opts.prefer_pkgs,
|
||||
# define=,
|
||||
# define_with=,
|
||||
# define_without=,
|
||||
)
|
||||
|
||||
if opts.multibuild_package:
|
||||
package = package + ":" + opts.multibuild_package
|
||||
|
||||
print(decode_it(get_buildinfo(apiurl,
|
||||
project, package, repository, arch,
|
||||
specfile=build_descr_data,
|
||||
debug=opts.debug_dependencies,
|
||||
addlist=opts.extra_pkgs)))
|
||||
extra_pkgs = opts.extra_pkgs.copy() if opts.extra_pkgs else []
|
||||
|
||||
if os.path.exists("/usr/lib/build/queryconfig") and not opts.nodebugpackages:
|
||||
with NamedTemporaryFile(mode="w+b", prefix="obs_buildconfig_") as bc_file:
|
||||
# print('Getting buildconfig from server and store to %s' % bc_filename)
|
||||
bc = get_buildconfig(apiurl, project, repository)
|
||||
bc_file.write(bc)
|
||||
bc_file.flush()
|
||||
|
||||
debug_pkgs = decode_it(return_external("/usr/lib/build/queryconfig", "--dist", bc_file.name, "substitute", "obs:cli_debug_packages"))
|
||||
if debug_pkgs:
|
||||
extra_pkgs.extend(debug_pkgs.strip().split(" "))
|
||||
|
||||
buildinfo = get_buildinfo(
|
||||
apiurl,
|
||||
project,
|
||||
package,
|
||||
repository,
|
||||
arch,
|
||||
specfile=build_descr_data,
|
||||
debug=opts.debug_dependencies,
|
||||
addlist=extra_pkgs,
|
||||
)
|
||||
print(decode_it(buildinfo))
|
||||
|
||||
def do_buildconfig(self, subcmd, opts, *args):
|
||||
"""
|
||||
@ -7091,7 +7116,7 @@ Please submit there instead, or use --nodevelproject to force direct submission.
|
||||
@cmdln.option('--no-verify', '--noverify', action='store_true',
|
||||
help='Skip signature verification (via pgp keys) of packages used for build. (Global config in oscrc: no_verify)')
|
||||
@cmdln.option('--nodebugpackages', '--no-debug-packages', action='store_true',
|
||||
help='Skip installation of additional debug packages for CLI builds')
|
||||
help='Skip installation of additional debug packages for CLI builds (specified in obs:cli_debug_packages in project metadata)')
|
||||
@cmdln.option("--skip-local-service-run", "--noservice", "--no-service", default=False, action="store_true",
|
||||
help="Skip run of local source services as specified in _service file.")
|
||||
@cmdln.option('-p', '--prefer-pkgs', metavar='DIR', action='append',
|
||||
|
Loading…
Reference in New Issue
Block a user