1
0
mirror of https://github.com/openSUSE/osc.git synced 2025-01-26 14:46:14 +01:00

Merge pull request #1151 from adrianschroeter/cpc

add create-pbuild-config(cpc) command
This commit is contained in:
Daniel Mach 2022-10-05 11:17:04 +02:00 committed by GitHub
commit db225d44d8
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
5 changed files with 92 additions and 0 deletions

4
NEWS
View File

@ -1,3 +1,7 @@
1.0.0b3
- add create-pbuild-config(cpc) command which allows to create a working
config for pbuild tool based on OBS server side data
1.0.0b2
- Support ssh-agent forwarding
- ssh auth: Avoid password prompt when using TransientCredentialsManager

View File

@ -45,6 +45,22 @@ def alias(*aliases):
return decorate
def name(name):
"""
Decorator to explicitly name a Cmdln subcommand.
Example:
class MyShell(cmdln.Cmdln):
@cmdln.name("cmd-with-dashes")
def do_cmd_with_dashes(self, subcmd, opts):
#...
"""
def decorate(f):
f.name = name
return f
return decorate
def hide():
"""
For obsolete calls, hide them in help listings.
@ -134,6 +150,7 @@ class Cmdln:
cmd_func = getattr(self, attr)
# extract data from the function
cmd_name = getattr(cmd_func, "name", cmd_name)
options = getattr(cmd_func, "options", [])
aliases = getattr(cmd_func, "aliases", [])
hidden = getattr(cmd_func, "hidden", False)

View File

@ -8345,6 +8345,35 @@ Please submit there instead, or use --nodevelproject to force direct submission.
if len(user) == 3:
print("%s: \"%s\" <%s>" % (user[0], user[1], user[2]))
@cmdln.name("create-pbuild-config")
@cmdln.alias('cpc')
@cmdln.option("repository")
@cmdln.option("arch")
def do_create_pbuild_config(self, subcmd, opts):
"""
This command is creating the necessary files to build using pbuild tool.
It basically creates _config and _pbuild file in the project directory.
Changes from there can not get submitted back, except the project is managed
in git.
Examples:
osc cpc REPOSITORY ARCH
"""
apiurl = self.get_api_url()
project = None
project_dir = os.curdir
if is_project_dir(project_dir):
project = store_read_project(project_dir)
elif is_package_dir(project_dir):
project_dir += '/..'
project = store_read_project(project_dir)
else:
raise oscerr.WrongArgs('Creating pbuild only works in a checked out project or package')
create_pbuild_config(apiurl, project, opts.repository, opts.arch, project_dir)
@cmdln.option('-r', '--revision', metavar='rev',
help='print out the specified revision')
@cmdln.option('-e', '--expand', action='store_true',

View File

@ -6379,6 +6379,39 @@ def get_buildconfig(apiurl, prj, repository, path=None):
return f.read()
def create_pbuild_config(apiurl, project, repository, arch, project_dir):
"""
This is always replacing a possible exiting config for now
we could extend the _pbuild file easily, but what should we do with multiple instances of the _config?
"""
# get expanded buildconfig for given project and repository
bc = get_buildconfig(apiurl, project, repository)
if not bc:
msg = "Failed to get build config for project '{project}', repository '{repository}'"
raise oscerr.NotFoundAPIError(msg)
with open(os.path.join(project_dir, '_config'), "w") as f:
f.write(decode_it(bc))
# create the _pbuild file based on expanded repository path informations
pb = ET.fromstring('<pbuild></pbuild>')
tree = ET.ElementTree(pb)
preset = ET.SubElement(pb, 'preset', name=repository, default="") # default should be empty, but ET crashes
bi_text = decode_it(get_buildinfo(apiurl, project, '_repository', repository, arch, specfile="Name: dummy"))
root = ET.fromstring(bi_text)
# cross compile setups are not yet supported
# for path in root.findall('hostsystem'):
# ET.SubElement(preset, 'hostrepo').text = path.get('url')
for path in root.findall('path'):
ET.SubElement(preset, 'repo').text = path.get('url')
ET.SubElement(preset, 'arch').text = arch
xmlindent(tree)
tree.write(os.path.join(project_dir,'_pbuild'), encoding="utf-8", xml_declaration=True)
def get_worker_info(apiurl, worker):
u = makeurl(apiurl, ['worker', worker])
f = http_GET(u)

View File

@ -50,6 +50,15 @@ class APIError(OscBaseError):
super().__init__()
self.msg = msg
def __str__(self):
return f"{self.__class__.__name__}: {self.msg}"
class NotFoundAPIError(APIError):
"""
Requested data was not found.
"""
class NoConfigfile(OscBaseError):
"""Exception raised when osc's configfile cannot be found"""