ostbuild: Port chroot-compile-one to ostbuild executor
This commit is contained in:
parent
be117edee4
commit
a080ff0181
|
|
@ -20,7 +20,6 @@ ostbuild: src/ostbuild/ostbuild.in Makefile
|
|||
bin_SCRIPTS += ostbuild
|
||||
|
||||
bin_SCRIPTS += \
|
||||
src/ostbuild/ostbuild-chroot-compile-one-impl \
|
||||
src/ostbuild/ostbuild-nice-and-log-output \
|
||||
$(NULL)
|
||||
|
||||
|
|
@ -32,6 +31,7 @@ pyostbuild_PYTHON = \
|
|||
src/ostbuild/pyostbuild/ostbuildlog.py \
|
||||
src/ostbuild/pyostbuild/subprocess_helpers.py \
|
||||
src/ostbuild/pyostbuild/builtin_autodiscover_meta.py \
|
||||
src/ostbuild/pyostbuild/builtin_chroot_compile_one.py \
|
||||
src/ostbuild/pyostbuild/builtin_commit_artifacts.py \
|
||||
src/ostbuild/pyostbuild/builtin_compile_one.py \
|
||||
$(NULL)
|
||||
|
|
|
|||
|
|
@ -1,148 +0,0 @@
|
|||
#!/usr/bin/python
|
||||
|
||||
# Copyright (C) 2011 Colin Walters <walters@verbum.org>
|
||||
#
|
||||
# This library is free software; you can redistribute it and/or
|
||||
# modify it under the terms of the GNU Lesser General Public
|
||||
# License as published by the Free Software Foundation; either
|
||||
# version 2 of the License, or (at your option) any later version.
|
||||
#
|
||||
# This library is distributed in the hope that it will be useful,
|
||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
# Lesser General Public License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU Lesser General Public
|
||||
# License along with this library; if not, write to the
|
||||
# Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
||||
# Boston, MA 02111-1307, USA.
|
||||
|
||||
import os,sys,re,subprocess,tempfile,shutil
|
||||
from StringIO import StringIO
|
||||
import argparse
|
||||
|
||||
sys.path
|
||||
|
||||
def get_build_env():
|
||||
return {'HOME' : '/',
|
||||
'HOSTNAME' : 'ostbuild',
|
||||
'LANG': 'C',
|
||||
'PATH' : '/usr/bin:/bin:/usr/sbin:/sbin',
|
||||
'SHELL' : '/bin/bash',
|
||||
'TERM' : 'vt100',
|
||||
'TMPDIR' : '/tmp',
|
||||
'TZ': 'EST5EDT'
|
||||
}
|
||||
|
||||
|
||||
parser = argparse.ArgumentParser(description="Build a module in a given root")
|
||||
parser.add_argument('--workdir')
|
||||
parser.add_argument('--repo')
|
||||
parser.add_argument('--resultdir')
|
||||
parser.add_argument('--branch')
|
||||
parser.add_argument('--meta')
|
||||
parser.add_argument('--debug-shell', type=bool)
|
||||
|
||||
args = parser.parse_args()
|
||||
|
||||
def log(m):
|
||||
sys.stdout.write(m)
|
||||
sys.stdout.write('\n')
|
||||
sys.stdout.flush()
|
||||
|
||||
if args.meta is None:
|
||||
output = subprocess.check_output(['ostbuild-autodiscover-meta'])
|
||||
ostbuild_meta_f = StringIO(output)
|
||||
else:
|
||||
ostbuild_meta_f = open(args.meta)
|
||||
|
||||
metadata = {}
|
||||
for line in ostbuild_meta_f:
|
||||
(k,v) = line.split('=', 1)
|
||||
metadata[k.strip()] = v.strip()
|
||||
|
||||
for k in ['NAME']:
|
||||
if k not in metadata:
|
||||
sys.stderr.write('Missing required key "%s" in metadata' % (k, ))
|
||||
sys.exit(1)
|
||||
|
||||
workdir_is_tmp = (args.workdir is None)
|
||||
if workdir_is_tmp:
|
||||
workdir = tempfile.mkdtemp(prefix='ostree-chroot-compile-')
|
||||
else:
|
||||
workdir = args.workdir
|
||||
|
||||
log("Using working directory: %s" % (workdir, ))
|
||||
|
||||
child_tmpdir=os.path.join(workdir, 'tmp')
|
||||
if os.path.isdir(child_tmpdir):
|
||||
log("Cleaning up previous tmpdir: %r" % (child_tmpdir, ))
|
||||
shutil.rmtree(child_tmpdir)
|
||||
os.mkdir(child_tmpdir)
|
||||
|
||||
rev = subprocess.check_output(['ostree', '--repo=' + args.repo, 'rev-parse', args.branch])
|
||||
rev=rev.strip()
|
||||
|
||||
metadata['BUILDROOT'] = args.branch
|
||||
metadata['BUILDROOT_VERSION'] = rev
|
||||
|
||||
rootdir = os.path.join(workdir, 'root-' + rev)
|
||||
rootdir_tmp = rootdir + '.tmp'
|
||||
builddir = os.path.join(rootdir, 'ostbuild');
|
||||
if not os.path.isdir(rootdir):
|
||||
if os.path.isdir(rootdir_tmp):
|
||||
shutil.rmtree(rootdir_tmp)
|
||||
child_args = ['ostree', '--repo=' + args.repo, 'checkout', '-U', rev, rootdir_tmp]
|
||||
log("Running: %r" % (child_args, ))
|
||||
subprocess.check_call(child_args)
|
||||
builddir_tmp = os.path.join(rootdir_tmp, 'ostbuild')
|
||||
os.mkdir(builddir_tmp)
|
||||
os.mkdir(os.path.join(builddir_tmp, 'source'))
|
||||
os.mkdir(os.path.join(builddir_tmp, 'results'))
|
||||
os.rename(rootdir_tmp, rootdir)
|
||||
log("Checked out root: %s" % (rootdir, ))
|
||||
else:
|
||||
log("Using existing root: %s" % (rootdir, ))
|
||||
|
||||
sourcedir=os.path.join(builddir, 'source', metadata['NAME'])
|
||||
if not os.path.isdir(sourcedir):
|
||||
os.mkdir(sourcedir)
|
||||
|
||||
output_metadata = open('_ostbuild-meta', 'w')
|
||||
for (k,v) in metadata.iteritems():
|
||||
output_metadata.write('%s=%s\n' % (k, v))
|
||||
output_metadata.close()
|
||||
|
||||
chroot_sourcedir = os.path.join('/ostbuild', 'source', metadata['NAME'])
|
||||
|
||||
# We need to search PATH here manually so we correctly pick up an
|
||||
# ostree install in e.g. ~/bin even though we're going to set PATH
|
||||
# below for our children inside the chroot.
|
||||
ostbuild_user_chroot_path = None
|
||||
for dirname in os.environ['PATH'].split(':'):
|
||||
path = os.path.join(dirname, 'ostbuild-user-chroot')
|
||||
if os.access(path, os.X_OK):
|
||||
ostbuild_user_chroot_path = path
|
||||
break
|
||||
if ostbuild_user_chroot_path is None:
|
||||
ostbuild_user_chroot_path = 'ostbuild-user-chroot'
|
||||
|
||||
child_args = [ostbuild_user_chroot_path, '--unshare-pid', '--unshare-net', '--unshare-ipc',
|
||||
'--mount-readonly', '/',
|
||||
'--mount-proc', '/proc',
|
||||
'--mount-bind', '/dev', '/dev',
|
||||
'--mount-bind', child_tmpdir, '/tmp',
|
||||
'--mount-bind', os.getcwd(), chroot_sourcedir,
|
||||
'--mount-bind', args.resultdir, '/ostbuild/results',
|
||||
rootdir,
|
||||
'/bin/sh']
|
||||
if not args.debug_shell:
|
||||
child_args += ['-c',
|
||||
'cd "%s" && ostbuild-compile-one-impl OSTBUILD_RESULTDIR=/ostbuild/results OSTBUILD_META=_ostbuild-meta' % (chroot_sourcedir, )
|
||||
]
|
||||
log("Running: %r" % (child_args, ))
|
||||
subprocess.check_call(child_args, env=get_build_env())
|
||||
|
||||
if workdir_is_tmp:
|
||||
shutil.rmtree(workdir)
|
||||
|
||||
|
|
@ -0,0 +1,146 @@
|
|||
# Copyright (C) 2011 Colin Walters <walters@verbum.org>
|
||||
#
|
||||
# This library is free software; you can redistribute it and/or
|
||||
# modify it under the terms of the GNU Lesser General Public
|
||||
# License as published by the Free Software Foundation; either
|
||||
# version 2 of the License, or (at your option) any later version.
|
||||
#
|
||||
# This library is distributed in the hope that it will be useful,
|
||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
# Lesser General Public License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU Lesser General Public
|
||||
# License along with this library; if not, write to the
|
||||
# Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
||||
# Boston, MA 02111-1307, USA.
|
||||
|
||||
import os,sys,re,subprocess,tempfile,shutil
|
||||
from StringIO import StringIO
|
||||
import argparse
|
||||
|
||||
from . import builtins
|
||||
from .ostbuildlog import log, fatal
|
||||
from .subprocess_helpers import run_sync
|
||||
|
||||
BUILD_ENV = {
|
||||
'HOME' : '/',
|
||||
'HOSTNAME' : 'ostbuild',
|
||||
'LANG': 'C',
|
||||
'PATH' : '/usr/bin:/bin:/usr/sbin:/sbin',
|
||||
'SHELL' : '/bin/bash',
|
||||
'TERM' : 'vt100',
|
||||
'TMPDIR' : '/tmp',
|
||||
'TZ': 'EST5EDT'
|
||||
}
|
||||
|
||||
class OstbuildChrootCompileOne(builtins.Builtin):
|
||||
name = "chroot-compile-one"
|
||||
short_description = "Build artifacts from the current source directory in a chroot"
|
||||
|
||||
def execute(self, argv):
|
||||
parser = argparse.ArgumentParser(description="Build a module in a given root")
|
||||
parser.add_argument('--workdir')
|
||||
parser.add_argument('--repo')
|
||||
parser.add_argument('--resultdir')
|
||||
parser.add_argument('--branch')
|
||||
parser.add_argument('--meta')
|
||||
parser.add_argument('--debug-shell', type=bool)
|
||||
|
||||
args = parser.parse_args(argv)
|
||||
|
||||
if args.meta is None:
|
||||
output = subprocess.check_output(['ostbuild-autodiscover-meta'])
|
||||
ostbuild_meta_f = StringIO(output)
|
||||
else:
|
||||
ostbuild_meta_f = open(args.meta)
|
||||
|
||||
metadata = {}
|
||||
for line in ostbuild_meta_f:
|
||||
(k,v) = line.split('=', 1)
|
||||
metadata[k.strip()] = v.strip()
|
||||
|
||||
for k in ['NAME']:
|
||||
if k not in metadata:
|
||||
sys.stderr.write('Missing required key "%s" in metadata' % (k, ))
|
||||
sys.exit(1)
|
||||
|
||||
workdir_is_tmp = (args.workdir is None)
|
||||
if workdir_is_tmp:
|
||||
workdir = tempfile.mkdtemp(prefix='ostree-chroot-compile-')
|
||||
else:
|
||||
workdir = args.workdir
|
||||
|
||||
log("Using working directory: %s" % (workdir, ))
|
||||
|
||||
child_tmpdir=os.path.join(workdir, 'tmp')
|
||||
if os.path.isdir(child_tmpdir):
|
||||
log("Cleaning up previous tmpdir: %r" % (child_tmpdir, ))
|
||||
shutil.rmtree(child_tmpdir)
|
||||
os.mkdir(child_tmpdir)
|
||||
|
||||
rev = subprocess.check_output(['ostree', '--repo=' + args.repo, 'rev-parse', args.branch])
|
||||
rev=rev.strip()
|
||||
|
||||
metadata['BUILDROOT'] = args.branch
|
||||
metadata['BUILDROOT_VERSION'] = rev
|
||||
|
||||
rootdir = os.path.join(workdir, 'root-' + rev)
|
||||
rootdir_tmp = rootdir + '.tmp'
|
||||
builddir = os.path.join(rootdir, 'ostbuild');
|
||||
if not os.path.isdir(rootdir):
|
||||
if os.path.isdir(rootdir_tmp):
|
||||
shutil.rmtree(rootdir_tmp)
|
||||
child_args = ['ostree', '--repo=' + args.repo, 'checkout', '-U', rev, rootdir_tmp]
|
||||
run_sync(child_args)
|
||||
builddir_tmp = os.path.join(rootdir_tmp, 'ostbuild')
|
||||
os.mkdir(builddir_tmp)
|
||||
os.mkdir(os.path.join(builddir_tmp, 'source'))
|
||||
os.mkdir(os.path.join(builddir_tmp, 'results'))
|
||||
os.rename(rootdir_tmp, rootdir)
|
||||
log("Checked out root: %s" % (rootdir, ))
|
||||
else:
|
||||
log("Using existing root: %s" % (rootdir, ))
|
||||
|
||||
sourcedir=os.path.join(builddir, 'source', metadata['NAME'])
|
||||
if not os.path.isdir(sourcedir):
|
||||
os.mkdir(sourcedir)
|
||||
|
||||
output_metadata = open('_ostbuild-meta', 'w')
|
||||
for (k,v) in metadata.iteritems():
|
||||
output_metadata.write('%s=%s\n' % (k, v))
|
||||
output_metadata.close()
|
||||
|
||||
chroot_sourcedir = os.path.join('/ostbuild', 'source', metadata['NAME'])
|
||||
|
||||
# We need to search PATH here manually so we correctly pick up an
|
||||
# ostree install in e.g. ~/bin even though we're going to set PATH
|
||||
# below for our children inside the chroot.
|
||||
ostbuild_user_chroot_path = None
|
||||
for dirname in os.environ['PATH'].split(':'):
|
||||
path = os.path.join(dirname, 'ostbuild-user-chroot')
|
||||
if os.access(path, os.X_OK):
|
||||
ostbuild_user_chroot_path = path
|
||||
break
|
||||
if ostbuild_user_chroot_path is None:
|
||||
ostbuild_user_chroot_path = 'ostbuild-user-chroot'
|
||||
|
||||
child_args = [ostbuild_user_chroot_path, '--unshare-pid', '--unshare-net', '--unshare-ipc',
|
||||
'--mount-readonly', '/',
|
||||
'--mount-proc', '/proc',
|
||||
'--mount-bind', '/dev', '/dev',
|
||||
'--mount-bind', child_tmpdir, '/tmp',
|
||||
'--mount-bind', os.getcwd(), chroot_sourcedir,
|
||||
'--mount-bind', args.resultdir, '/ostbuild/results',
|
||||
rootdir,
|
||||
'/bin/sh']
|
||||
if not args.debug_shell:
|
||||
child_args += ['-c',
|
||||
'cd "%s" && ostbuild-compile-one-impl OSTBUILD_RESULTDIR=/ostbuild/results OSTBUILD_META=_ostbuild-meta' % (chroot_sourcedir, )
|
||||
]
|
||||
run_sync(child_args, env=BUILD_ENV)
|
||||
|
||||
if workdir_is_tmp:
|
||||
shutil.rmtree(workdir)
|
||||
|
||||
builtins.register(OstbuildChrootCompileOne)
|
||||
|
|
@ -23,6 +23,7 @@ import argparse
|
|||
|
||||
from . import builtins
|
||||
from . import builtin_autodiscover_meta
|
||||
from . import builtin_chroot_compile_one
|
||||
from . import builtin_commit_artifacts
|
||||
from . import builtin_compile_one
|
||||
|
||||
|
|
|
|||
Loading…
Reference in New Issue