[CRIU] [PATCH] zdtm: check /proc/sys/kernel/taint and fail if it is non-zero
Andrei Vagin
avagin at virtuozzo.com
Fri Jun 30 19:26:02 MSK 2017
On Fri, Jun 30, 2017 at 09:44:04AM +0300, Pavel Emelyanov wrote:
> On 06/30/2017 04:10 AM, Andrei Vagin wrote:
> > 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.
>
> Why does the latter thing matter?
You can use --ignore-taint to ignore an initial non-zero value,
but zdtm.py will notify you if its value will be changed.
>
> > Signed-off-by: Andrei Vagin <avagin at virtuozzo.com>
>
> Acked-by: Pavel Emelyanov <xemul 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)
> >
>
More information about the CRIU
mailing list