From c7326aa098ca3dcebde45d90d956cbfae03709fd Mon Sep 17 00:00:00 2001 From: Daniel Mensinger Date: Sat, 4 Apr 2020 22:42:16 +0200 Subject: ci: Added cuda image (Arch Linux based) --- ci/ciimage/build.py | 6 +++++- ci/ciimage/cuda/image.json | 5 +++++ ci/ciimage/cuda/install.sh | 18 ++++++++++++++++++ 3 files changed, 28 insertions(+), 1 deletion(-) create mode 100644 ci/ciimage/cuda/image.json create mode 100755 ci/ciimage/cuda/install.sh (limited to 'ci/ciimage') diff --git a/ci/ciimage/build.py b/ci/ciimage/build.py index 5e25e36..f57e8d7 100755 --- a/ci/ciimage/build.py +++ b/ci/ciimage/build.py @@ -26,6 +26,7 @@ class ImageDef: assert isinstance(data['env'], dict) self.base_image: str = data['base_image'] + self.args: T.List[str] = data.get('args', []) self.env: T.Dict[str, str] = data['env'] class BuilderBase(): @@ -64,6 +65,9 @@ class Builder(BuilderBase): out_file = self.temp_dir / 'env_vars.sh' out_data = '' + # run_tests.py parameters + self.image_def.env['CI_ARGS'] = ' '.join(self.image_def.args) + for key, val in self.image_def.env.items(): out_data += f'export {key}="{val}"\n' @@ -153,7 +157,7 @@ class ImageTester(BuilderBase): test_cmd = [ self.docker, 'run', '--rm', '-t', 'meson_test_image', - '/usr/bin/bash', '-c', 'source /ci/env_vars.sh; cd meson; ./run_tests.py' + '/usr/bin/bash', '-c', 'source /ci/env_vars.sh; cd meson; ./run_tests.py $CI_ARGS' ] if subprocess.run(test_cmd).returncode != 0: raise RuntimeError('Running tests failed') diff --git a/ci/ciimage/cuda/image.json b/ci/ciimage/cuda/image.json new file mode 100644 index 0000000..d395e71 --- /dev/null +++ b/ci/ciimage/cuda/image.json @@ -0,0 +1,5 @@ +{ + "base_image": "archlinux:latest", + "args": ["--only", "cuda"], + "env": {} +} diff --git a/ci/ciimage/cuda/install.sh b/ci/ciimage/cuda/install.sh new file mode 100755 index 0000000..011099d --- /dev/null +++ b/ci/ciimage/cuda/install.sh @@ -0,0 +1,18 @@ +#!/bin/bash + +set -e + +pkgs=( + python python-setuptools python-wheel python-pytest-xdist python-jsonschema + ninja gcc gcc-objc git cmake + cuda zlib pkgconf +) + +PACMAN_OPTS='--needed --noprogressbar --noconfirm' + +pacman -Syu $PACMAN_OPTS "${pkgs[@]}" + +# Manually remove cache to avoid GitHub space restrictions +rm -rf /var/cache/pacman + +echo "source /etc/profile.d/cuda.sh" >> /ci/env_vars.sh -- cgit v1.1