1
0
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:
Dr. Peter Poeml 2008-11-22 10:55:33 +00:00
parent b6b4550ae7
commit 8383e9e895
2 changed files with 48 additions and 51 deletions

View File

@ -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 '):

View File

@ -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',