Commit d499aead authored by Andrei Vagin's avatar Andrei Vagin

zdtm: enable lazy migration testing

The --lazy-migrate option allows testing of lazy migration when running ns
or uns flavor.
Signed-off-by: 's avatarAndrei Vagin <avagin@virtuozzo.com>
Signed-off-by: 's avatarMike Rapoport <rppt@linux.vnet.ibm.com>
parent 8c87d345
......@@ -487,6 +487,10 @@ class zdtm_test:
def getropts(self):
return self.__getcropts() + self.__freezer.getropts() + self.__desc.get('ropts', '').split()
def unlink_pidfile(self):
self.__pid = 0
os.unlink(self.__pidfile())
def gone(self, force = True):
if not self.auto_reap:
pid, status = os.waitpid(int(self.__pid), 0)
......@@ -817,6 +821,7 @@ class criu:
self.__remote_lazy_pages = (opts['remote_lazy_pages'] and True or False)
self.__lazy_pages = (self.__remote_lazy_pages or
opts['lazy_pages'] and True or False)
self.__lazy_migrate = (opts['lazy_migrate'] and True or False)
self.__restore_sibling = (opts['sibling'] and True or False)
self.__join_ns = (opts['join_ns'] and True or False)
self.__empty_ns = (opts['empty_ns'] and True or False)
......@@ -831,8 +836,11 @@ class criu:
self.__show_stats = (opts['show_stats'] and True or False)
self.__lazy_pages_p = None
self.__page_server_p = None
self.__dump_process = None
def fini(self):
if self.__lazy_migrate:
ret = self.__dump_process.wait()
if self.__lazy_pages_p:
ret = self.__lazy_pages_p.wait()
grep_errors(os.path.join(self.__ddir(), "lazy-pages.log"))
......@@ -845,6 +853,12 @@ class criu:
self.__page_server_p = None
if ret:
raise test_fail_exc("criu page-server exited with %s" % ret)
if self.__dump_process:
ret = self.__dump_process.wait()
grep_errors(os.path.join(self.__ddir(), "dump.log"))
self.__dump_process = None
if ret:
raise test_fail_exc("criu dump exited with %s" % ret)
return
def logs(self):
......@@ -994,7 +1008,11 @@ class criu:
if self.__empty_ns:
a_opts += ['--empty-ns', 'net']
self.__criu_act(action, opts = a_opts + opts)
nowait = False
if self.__lazy_migrate:
a_opts += ["--lazy-pages", "--port", "12345"]
nowait = True
self.__dump_process = self.__criu_act(action, opts = a_opts + opts, nowait = nowait)
if self.__mdedup and self.__iter > 1:
self.__criu_act("dedup", opts = [])
......@@ -1030,10 +1048,11 @@ class criu:
r_opts.append('--external')
r_opts.append('mnt[zdtm]:%s' % criu_dir)
if self.__lazy_pages:
if self.__lazy_pages or self.__lazy_migrate:
lp_opts = []
if self.__remote_lazy_pages:
if self.__remote_lazy_pages or self.__lazy_migrate:
lp_opts += ['--page-server', "--port", "12345"]
if self.__remote_lazy_pages:
ps_opts = ["--pidfile", "ps.pid",
"--port", "12345", "--lazy-pages"]
self.__page_server_p = self.__criu_act("page-server", opts = ps_opts, nowait = True)
......@@ -1071,6 +1090,11 @@ class criu:
print "criu page-server exited with %s" % self.__page_server_p.wait()
grep_errors(os.path.join(self.__ddir(), "page-server.log"))
self.__page_server_p = None
if self.__dump_process:
self.__dump_process.terminate()
print "criu dump exited with %s" % self.__dump_process.wait()
grep_errors(os.path.join(self.__ddir(), "dump.log"))
self.__dump_process = None
def try_run_hook(test, args):
......@@ -1136,7 +1160,10 @@ def cr(cr_api, test, opts):
else:
try_run_hook(test, ["--pre-dump"])
cr_api.dump("dump")
if not opts['lazy_migrate']:
test.gone()
else:
test.unlink_pidfile()
sbs('pre-restore')
try_run_hook(test, ["--pre-restore"])
cr_api.restore()
......@@ -1522,7 +1549,7 @@ class Launcher:
nd = ('nocr', 'norst', 'pre', 'iters', 'page_server', 'sibling', 'stop', 'empty_ns',
'fault', 'keep_img', 'report', 'snaps', 'sat', 'script', 'rpc', 'lazy_pages',
'join_ns', 'dedup', 'sbs', 'freezecg', 'user', 'dry_run', 'noauto_dedup',
'remote_lazy_pages', 'show_stats')
'remote_lazy_pages', 'show_stats', 'lazy_migrate')
arg = repr((name, desc, flavor, {d: self.__opts[d] for d in nd}))
if self.__use_log:
......@@ -1752,7 +1779,7 @@ def run_tests(opts):
if subprocess.Popen(["ip", "netns", "exec", "zdtm_netns", "ip", "link", "set", "up", "dev", "lo"]).wait():
raise Exception("ip link set up dev lo")
if opts['lazy_pages'] or opts['remote_lazy_pages']:
if opts['lazy_pages'] or opts['remote_lazy_pages'] or opts['lazy_migrate']:
uffd = criu.check("uffd")
uffd_noncoop = criu.check("uffd-noncoop")
if not uffd:
......@@ -1810,7 +1837,7 @@ def run_tests(opts):
launcher.skip(t, "samens test in the same namespace")
continue
if opts['lazy_pages'] or opts['remote_lazy_pages']:
if opts['lazy_pages'] or opts['remote_lazy_pages'] or opts['lazy_migrate']:
if test_flag(tdesc, 'nolazy'):
launcher.skip(t, "lazy pages are not supported")
continue
......@@ -2055,6 +2082,7 @@ rp.add_argument("--report", help = "Generate summary report in directory")
rp.add_argument("--keep-going", help = "Keep running tests in spite of failures", action = 'store_true')
rp.add_argument("--ignore-taint", help = "Don't care about a non-zero kernel taint flag", action = 'store_true')
rp.add_argument("--lazy-pages", help = "restore pages on demand", action = 'store_true')
rp.add_argument("--lazy-migrate", help = "restore pages on demand", action = 'store_true')
rp.add_argument("--remote-lazy-pages", help = "simulate lazy migration", action = 'store_true')
rp.add_argument("--title", help = "A test suite title", default = "criu")
rp.add_argument("--show-stats", help = "Show criu statistics", action = 'store_true')
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment