[CRIU] [PATCH] zdtm: check /proc/sys/kernel/taint and fail if it is non-zero
Andrei Vagin
avagin at openvz.org
Fri Jun 30 04:10:29 MSK 2017
From: Andrei Vagin <avagin at virtuozzo.com>
We don't want to run tests, if a kernel has a problem. And we want
to know when the taint flag is changed.
Signed-off-by: Andrei Vagin <avagin at virtuozzo.com>
---
test/zdtm.py | 10 ++++++++++
1 file changed, 10 insertions(+)
diff --git a/test/zdtm.py b/test/zdtm.py
index 14263a6..7af0018 100755
--- a/test/zdtm.py
+++ b/test/zdtm.py
@@ -1501,6 +1501,11 @@ class launcher:
print >> self.__file_report, "# Timestamp: " + now.strftime("%Y-%m-%d %H:%M") + " (GMT+1)"
print >> self.__file_report, "# "
print >> self.__file_report, "1.." + str(nr_tests)
+ self.__taint = open("/proc/sys/kernel/tainted").read()
+ if int(self.__taint, 0) != 0:
+ print "The kernel is tainted: %r" % self.__taint
+ if not opts["ignore_taint"]:
+ raise Exception("The kernel is tainted: %r" % self.__taint)
def __show_progress(self, msg):
perc = self.__nr * 16 / self.__total
@@ -1520,6 +1525,10 @@ class launcher:
if len(self.__subs) >= self.__max:
self.wait()
+ taint = open("/proc/sys/kernel/tainted").read()
+ if self.__taint != taint:
+ raise Exception("The kernel is tainted: %r (%r)" % (taint, self.__taint))
+
if test_flag(desc, 'excl'):
self.wait_all()
@@ -2056,6 +2065,7 @@ rp.add_argument("--keep-going", help = "Keep running tests in spite of failures"
rp.add_argument("--lazy-pages", help = "restore pages on demand", action = 'store_true')
rp.add_argument("--remote-lazy-pages", help = "simulate lazy migration", action = 'store_true')
rp.add_argument("--check-only", help = "Additionally try to dump/restore in --check-only mode", action = 'store_true')
+rp.add_argument("--ignore-taint", help = "Don't care about a non-zero kernel taint flag", action = 'store_true')
lp = sp.add_parser("list", help = "List tests")
lp.set_defaults(action = list_tests)
--
2.9.4
More information about the CRIU
mailing list