[CRIU] [PATCH 5/6] test: make crit-recode.py python2/python3 compatible
Andrei Vagin
avagin at virtuozzo.com
Wed May 30 21:39:38 MSK 2018
Signed-off-by: Andrei Vagin <avagin at virtuozzo.com>
---
test/crit-recode.py | 43 +++++++++++++++++++++++--------------------
1 file changed, 23 insertions(+), 20 deletions(-)
diff --git a/test/crit-recode.py b/test/crit-recode.py
index 0d4b31777..0cb3341d3 100755
--- a/test/crit-recode.py
+++ b/test/crit-recode.py
@@ -1,9 +1,11 @@
-#!/bin/env python2
+#!/usr/bin/env python
+# vim: noet ts=8 sw=8 sts=8
import pycriu
import sys
import os
import subprocess
+import json
find = subprocess.Popen(['find', 'test/dump/', '-size', '+0', '-name', '*.img'],
stdout = subprocess.PIPE)
@@ -14,20 +16,21 @@ def recode_and_check(imgf, o_img, pretty):
try:
pb = pycriu.images.loads(o_img, pretty)
except pycriu.images.MagicException as me:
- print "%s magic %x error" % (imgf, me.magic)
+ print("%s magic %x error" % (imgf, me.magic))
return False
- except:
- print "%s %sdecode fails" % (imgf, pretty and 'pretty ' or '')
+ except Exception as e:
+ print("%s %sdecode fails: %s" % (imgf, pretty and 'pretty ' or '', e))
return False
try:
r_img = pycriu.images.dumps(pb)
- except:
- print "%s %sencode fails" % (imgf, pretty and 'pretty ' or '')
+ except Exception as e:
+ r_img = pycriu.images.dumps(pb)
+ print("%s %s encode fails: %s" % (imgf, pretty and 'pretty ' or '', e))
return False
if o_img != r_img:
- print "%s %srecode mismatch" % (imgf, pretty and 'pretty ' or '')
+ print("%s %s recode mismatch" % (imgf, pretty and 'pretty ' or ''))
return False
return True
@@ -37,28 +40,28 @@ for imgf in find.stdout.readlines():
imgf = imgf.strip()
imgf_b = os.path.basename(imgf)
- if imgf_b.startswith('pages-'):
+ if imgf_b.startswith(b'pages-'):
continue
- if imgf_b.startswith('iptables-'):
+ if imgf_b.startswith(b'iptables-'):
continue
- if imgf_b.startswith('ip6tables-'):
+ if imgf_b.startswith(b'ip6tables-'):
continue
- if imgf_b.startswith('route-'):
+ if imgf_b.startswith(b'route-'):
continue
- if imgf_b.startswith('route6-'):
+ if imgf_b.startswith(b'route6-'):
continue
- if imgf_b.startswith('ifaddr-'):
+ if imgf_b.startswith(b'ifaddr-'):
continue
- if imgf_b.startswith('tmpfs-'):
+ if imgf_b.startswith(b'tmpfs-'):
continue
- if imgf_b.startswith('netns-ct-'):
+ if imgf_b.startswith(b'netns-ct-'):
continue
- if imgf_b.startswith('netns-exp-'):
+ if imgf_b.startswith(b'netns-exp-'):
continue
- if imgf_b.startswith('rule-'):
+ if imgf_b.startswith(b'rule-'):
continue
- o_img = open(imgf).read()
+ o_img = open(imgf.decode(), "rb").read()
if not recode_and_check(imgf, o_img, False):
test_pass = False
if not recode_and_check(imgf, o_img, True):
@@ -67,7 +70,7 @@ for imgf in find.stdout.readlines():
find.wait()
if not test_pass:
- print "FAIL"
+ print("FAIL")
sys.exit(1)
-print "PASS"
+print("PASS")
--
2.14.3
More information about the CRIU
mailing list