[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Qemu-devel] [PATCH 09/12] docker: Add travis tool
From: |
Fam Zheng |
Subject: |
[Qemu-devel] [PATCH 09/12] docker: Add travis tool |
Date: |
Fri, 5 Feb 2016 17:24:20 +0800 |
The script is not named test-travis.sh so it won't run with "make
docker-run", because it can take too long.
Run it with "make address@hidden".
Signed-off-by: Fam Zheng <address@hidden>
---
tests/docker/travis.py | 53 ++++++++++++++++++++++++++++++++++++++++++++++++++
tests/docker/travis.sh | 20 +++++++++++++++++++
2 files changed, 73 insertions(+)
create mode 100755 tests/docker/travis.py
create mode 100755 tests/docker/travis.sh
diff --git a/tests/docker/travis.py b/tests/docker/travis.py
new file mode 100755
index 0000000..75f0267
--- /dev/null
+++ b/tests/docker/travis.py
@@ -0,0 +1,53 @@
+#!/usr/bin/env python2 -B
+#
+# Travis YAML config parser
+#
+# Copyright (c) 2016 Red Hat Inc.
+#
+# Authors:
+# Fam Zheng <address@hidden>
+#
+# This work is licensed under the terms of the GNU GPL, version 2
+# or (at your option) any later version. See the COPYING file in
+# the top-level directory.
+
+import sys
+import yaml
+import json
+import itertools
+
+def load_yaml(fname):
+ return yaml.load(open(sys.argv[1], "r").read())
+
+def conf_iter(conf):
+ def env_list(e):
+ return e if type(e) is list else [e]
+ global_env = conf["env"]["global"]
+ for c in conf["matrix"]["include"]:
+ a = { "env": global_env + env_list(c["env"]),
+ "compiler": c["compiler"]
+ }
+ yield a
+ for c in itertools.product(conf["compiler"],
+ conf["env"]["matrix"]):
+ a = { "env": global_env + env_list(c[1]),
+ "compiler": c[0]
+ }
+ yield a
+
+def main():
+ if len(sys.argv) < 2:
+ sys.stderr.write("Usage: %s <travis-file>\n" % sys.argv[0])
+ return 1
+ conf = load_yaml(sys.argv[1])
+ for config in conf_iter(conf):
+ print "("
+ print "\n".join(config["env"])
+ print "CC=" + config["compiler"]
+ print "\n".join(conf["before_script"])
+ print "\n".join(conf["script"])
+ print ")"
+ return 0
+
+if __name__ == "__main__":
+ sys.exit(main())
diff --git a/tests/docker/travis.sh b/tests/docker/travis.sh
new file mode 100755
index 0000000..bfc9bf4
--- /dev/null
+++ b/tests/docker/travis.sh
@@ -0,0 +1,20 @@
+#!/bin/bash -e
+#
+# Mimic a travis testing matrix of environment
+#
+# Copyright (c) 2016 Red Hat Inc.
+#
+# Authors:
+# Fam Zheng <address@hidden>
+#
+# This work is licensed under the terms of the GNU GPL, version 2
+# or (at your option) any later version. See the COPYING file in
+# the top-level directory.
+
+. common.rc
+
+requires pyyaml
+
+cd $(mktemp -d)
+$QEMU_SRC/tests/docker/travis.py $QEMU_SRC/.travis.yml > travis_command_list
+. travis_command_list
--
2.4.3
- Re: [Qemu-devel] [PATCH 04/12] docker: Add test runner, (continued)
[Qemu-devel] [PATCH 05/12] docker: Add common.rc, Fam Zheng, 2016/02/05
[Qemu-devel] [PATCH 06/12] docker: Add basic test, Fam Zheng, 2016/02/05
[Qemu-devel] [PATCH 07/12] docker: Add clang test, Fam Zheng, 2016/02/05
[Qemu-devel] [PATCH 08/12] docker: Add mingw test, Fam Zheng, 2016/02/05
[Qemu-devel] [PATCH 09/12] docker: Add travis tool,
Fam Zheng <=
[Qemu-devel] [PATCH 10/12] docs: Add text for tests/docker in build-system.txt, Fam Zheng, 2016/02/05
[Qemu-devel] [PATCH 11/12] .gitignore: Ignore temporary dockerfile, Fam Zheng, 2016/02/05
[Qemu-devel] [PATCH 12/12] MAINTAINERS: Add tests/docker, Fam Zheng, 2016/02/05
Re: [Qemu-devel] [PATCH 00/12] tests: Introducing docker tests, Alex Bennée, 2016/02/10
Re: [Qemu-devel] [PATCH 00/12] tests: Introducing docker tests, Alex Bennée, 2016/02/15