mirror of
https://github.com/openSUSE/osc.git
synced 2025-01-14 17:46:17 +01:00
osc build:
* rework buildinfo parser. * handle new (or rather, future) attributes named noinstall, package (we call it repopackage), repoarch. * handle kiwi builds. The urllist template (for constructing download URLs) was changed to make the '_repository' part variable.
This commit is contained in:
parent
b6b4550ae7
commit
8383e9e895
95
osc/build.py
95
osc/build.py
@ -93,34 +93,18 @@ class Buildinfo:
|
|||||||
|
|
||||||
self.deps = []
|
self.deps = []
|
||||||
for node in root.findall('bdep'):
|
for node in root.findall('bdep'):
|
||||||
p_name = node.get('name')
|
p = Pac(node,
|
||||||
p_arch = node.get('arch')
|
|
||||||
if not p_arch:
|
|
||||||
p_arch = self.buildarch
|
|
||||||
p_version = node.get('version')
|
|
||||||
p_release = node.get('release')
|
|
||||||
|
|
||||||
if not (p_name and p_arch and p_version):
|
|
||||||
raise oscerr.APIError(
|
|
||||||
"buildinfo for package %s/%s/%s is incomplete" % (p_name, p_arch, p_version))
|
|
||||||
|
|
||||||
p = Pac(p_name,
|
|
||||||
p_version,
|
|
||||||
p_release,
|
|
||||||
node.get('project'),
|
|
||||||
node.get('repository'),
|
|
||||||
p_arch,
|
|
||||||
node.get('preinstall'),
|
|
||||||
node.get('runscripts'),
|
|
||||||
self.buildarch, # buildarch is used only for the URL to access the full tree...
|
self.buildarch, # buildarch is used only for the URL to access the full tree...
|
||||||
self.pacsuffix,
|
self.pacsuffix,
|
||||||
scheme,
|
scheme,
|
||||||
apisrv)
|
apisrv)
|
||||||
|
|
||||||
self.deps.append(p)
|
self.deps.append(p)
|
||||||
|
|
||||||
self.preinstall_list = [ dep.name for dep in self.deps if dep.preinstall ]
|
self.preinstall_list = [ dep.name for dep in self.deps if dep.preinstall ]
|
||||||
self.runscripts_list = [ dep.name for dep in self.deps if dep.runscripts ]
|
self.runscripts_list = [ dep.name for dep in self.deps if dep.runscripts ]
|
||||||
|
|
||||||
|
|
||||||
def has_dep(self, name):
|
def has_dep(self, name):
|
||||||
for i in self.deps:
|
for i in self.deps:
|
||||||
if i.name == name:
|
if i.name == name:
|
||||||
@ -136,33 +120,34 @@ class Buildinfo:
|
|||||||
|
|
||||||
|
|
||||||
class Pac:
|
class Pac:
|
||||||
"""represent a package to be downloaded"""
|
"""represent a package to be downloaded
|
||||||
def __init__(self, name, version, release, project, repository, arch,
|
|
||||||
preinstall, runscripts, buildarch, pacsuffix, scheme=config['scheme'], apisrv=config['apisrv']):
|
|
||||||
|
|
||||||
self.name = name
|
We build a map that's later used to fill our URL templates
|
||||||
self.version = version
|
"""
|
||||||
self.release = release
|
def __init__(self, node,
|
||||||
self.arch = arch
|
buildarch, pacsuffix,
|
||||||
self.project = project
|
scheme=config['scheme'], apisrv=config['apisrv']):
|
||||||
self.repository = repository
|
|
||||||
self.preinstall = preinstall
|
|
||||||
self.runscripts = runscripts
|
|
||||||
self.buildarch = buildarch
|
|
||||||
self.pacsuffix = pacsuffix
|
|
||||||
|
|
||||||
# build a map to fill our the URL templates
|
|
||||||
self.mp = {}
|
self.mp = {}
|
||||||
self.mp['name'] = self.name
|
for i in ['name', 'package',
|
||||||
self.mp['version'] = self.version
|
'version', 'release',
|
||||||
self.mp['release'] = self.release
|
'project', 'repository',
|
||||||
self.mp['arch'] = self.arch
|
'preinstall', 'noinstall', 'runscripts',
|
||||||
self.mp['project'] = self.project
|
]:
|
||||||
self.mp['repository'] = self.repository
|
self.mp[i] = node.get(i)
|
||||||
self.mp['preinstall'] = self.preinstall
|
|
||||||
self.mp['runscripts'] = self.runscripts
|
self.mp['buildarch'] = buildarch
|
||||||
self.mp['buildarch'] = self.buildarch
|
self.mp['pacsuffix'] = pacsuffix
|
||||||
self.mp['pacsuffix'] = self.pacsuffix
|
|
||||||
|
|
||||||
|
self.mp['repopackage'] = node.get('repopackage') or '_repository'
|
||||||
|
self.mp['arch'] = node.get('arch') or self.mp['buildarch']
|
||||||
|
self.mp['repoarch'] = node.get('repoarch') or self.mp['arch']
|
||||||
|
|
||||||
|
if not (self.mp['name'] and self.mp['arch'] and self.mp['version']):
|
||||||
|
raise oscerr.APIError(
|
||||||
|
"buildinfo for package %s/%s/%s is incomplete"
|
||||||
|
% (self.mp['name'], self.mp['arch'], self.mp['version']))
|
||||||
|
|
||||||
self.mp['scheme'] = scheme
|
self.mp['scheme'] = scheme
|
||||||
self.mp['apisrv'] = apisrv
|
self.mp['apisrv'] = apisrv
|
||||||
@ -171,6 +156,9 @@ class Pac:
|
|||||||
|
|
||||||
self.mp['filename'] = self.filename
|
self.mp['filename'] = self.filename
|
||||||
|
|
||||||
|
# make the content of the dictionary accessible as class attributes
|
||||||
|
self.__dict__.update(self.mp)
|
||||||
|
|
||||||
|
|
||||||
def makeurls(self, cachedir, urllist):
|
def makeurls(self, cachedir, urllist):
|
||||||
|
|
||||||
@ -246,7 +234,13 @@ def main(opts, argv):
|
|||||||
|
|
||||||
repo = argv[0]
|
repo = argv[0]
|
||||||
arch = argv[1]
|
arch = argv[1]
|
||||||
spec = argv[2]
|
build_descr = argv[2]
|
||||||
|
|
||||||
|
build_type = os.path.splitext(build_descr)[1][1:]
|
||||||
|
if build_type not in ['spec', 'dsc', 'kiwi']:
|
||||||
|
raise oscerr.WrongArgs(
|
||||||
|
"Unknown build type: '%s'. Build description should end in .spec, .dsc or .kiwi." \
|
||||||
|
% build_type)
|
||||||
|
|
||||||
buildargs = []
|
buildargs = []
|
||||||
if not opts.userootforbuild:
|
if not opts.userootforbuild:
|
||||||
@ -277,8 +271,8 @@ def main(opts, argv):
|
|||||||
pac = store_read_package(os.curdir)
|
pac = store_read_package(os.curdir)
|
||||||
apiurl = store_read_apiurl(os.curdir)
|
apiurl = store_read_apiurl(os.curdir)
|
||||||
|
|
||||||
if not os.path.exists(spec):
|
if not os.path.exists(build_descr):
|
||||||
print >>sys.stderr, 'Error: specfile \'%s\' does not exist.' % spec
|
print >>sys.stderr, 'Error: build description named \'%s\' does not exist.' % build_descr
|
||||||
return 1
|
return 1
|
||||||
|
|
||||||
# make it possible to override configuration of the rc file
|
# make it possible to override configuration of the rc file
|
||||||
@ -308,7 +302,7 @@ def main(opts, argv):
|
|||||||
pac,
|
pac,
|
||||||
repo,
|
repo,
|
||||||
arch,
|
arch,
|
||||||
specfile=open(spec).read(),
|
specfile=open(build_descr).read(),
|
||||||
addlist=extra_pkgs))
|
addlist=extra_pkgs))
|
||||||
except urllib2.HTTPError, e:
|
except urllib2.HTTPError, e:
|
||||||
if e.code == 404:
|
if e.code == 404:
|
||||||
@ -373,6 +367,9 @@ def main(opts, argv):
|
|||||||
# now update the package cache
|
# now update the package cache
|
||||||
fetcher.run(bi)
|
fetcher.run(bi)
|
||||||
|
|
||||||
|
if build_type == 'kiwi' and not os.path.exists('repos'):
|
||||||
|
os.symlink(config['packagecachedir'], 'repos')
|
||||||
|
|
||||||
if bi.pacsuffix == 'rpm':
|
if bi.pacsuffix == 'rpm':
|
||||||
"""don't know how to verify .deb packages. They are verified on install
|
"""don't know how to verify .deb packages. They are verified on install
|
||||||
anyway, I assume... verifying package now saves time though, since we don't
|
anyway, I assume... verifying package now saves time though, since we don't
|
||||||
@ -386,7 +383,7 @@ def main(opts, argv):
|
|||||||
|
|
||||||
print 'Writing build configuration'
|
print 'Writing build configuration'
|
||||||
|
|
||||||
rpmlist = [ '%s %s\n' % (i.name, i.fullfilename) for i in bi.deps ]
|
rpmlist = [ '%s %s\n' % (i.name, i.fullfilename) for i in bi.deps if not i.noinstall ]
|
||||||
rpmlist += [ '%s %s\n' % (i[0], i[1]) for i in rpmlist_prefers ]
|
rpmlist += [ '%s %s\n' % (i[0], i[1]) for i in rpmlist_prefers ]
|
||||||
|
|
||||||
rpmlist.append('preinstall: ' + ' '.join(bi.preinstall_list) + '\n')
|
rpmlist.append('preinstall: ' + ' '.join(bi.preinstall_list) + '\n')
|
||||||
@ -412,7 +409,7 @@ def main(opts, argv):
|
|||||||
config['build-root'],
|
config['build-root'],
|
||||||
rpmlist_file.name,
|
rpmlist_file.name,
|
||||||
bc_file.name,
|
bc_file.name,
|
||||||
spec,
|
build_descr,
|
||||||
buildargs)
|
buildargs)
|
||||||
|
|
||||||
if config['su-wrapper'].startswith('su '):
|
if config['su-wrapper'].startswith('su '):
|
||||||
|
@ -29,7 +29,7 @@ The configuration dictionary could look like this:
|
|||||||
'packagecachedir': '/var/cache/osbuild',
|
'packagecachedir': '/var/cache/osbuild',
|
||||||
'su-wrapper': 'sudo',
|
'su-wrapper': 'sudo',
|
||||||
'urllist': ['http://download.opensuse.org/repositories/%(project)s/%(repository)s/%(arch)s/%(filename)s',
|
'urllist': ['http://download.opensuse.org/repositories/%(project)s/%(repository)s/%(arch)s/%(filename)s',
|
||||||
'http://api.opensuse.org/rpm/%(project)s/%(repository)s/_repository/%(buildarch)s/%(name)s'],
|
'http://api.opensuse.org/rpm/%(project)s/%(repository)s/%(repopackage)s/%(buildarch)s/%(name)s'],
|
||||||
}
|
}
|
||||||
|
|
||||||
"""
|
"""
|
||||||
@ -55,7 +55,7 @@ DEFAULTS = { 'apisrv': 'https://api.opensuse.org/',
|
|||||||
# the normal repo server, redirecting to mirrors
|
# the normal repo server, redirecting to mirrors
|
||||||
'http://download.opensuse.org/repositories/%(project)s/%(repository)s/%(arch)s/%(filename)s',
|
'http://download.opensuse.org/repositories/%(project)s/%(repository)s/%(arch)s/%(filename)s',
|
||||||
# direct access to "full" tree
|
# direct access to "full" tree
|
||||||
'%(scheme)s://%(apisrv)s/build/%(project)s/%(repository)s/%(buildarch)s/_repository/%(name)s',
|
'%(scheme)s://%(apisrv)s/build/%(project)s/%(repository)s/%(buildarch)s/%(repopackage)s/%(name)s',
|
||||||
],
|
],
|
||||||
|
|
||||||
'debug': '0',
|
'debug': '0',
|
||||||
|
Loading…
Reference in New Issue
Block a user