]> arthur.barton.de Git - bup.git/blobdiff - lib/bup/t/tvint.py
Check saved_errors before and after every test
[bup.git] / lib / bup / t / tvint.py
index 0fc41bd1358c6d1dcd41381d70bec38851c5965c..283e179f51af2d56b65e40e26e578833279f068d 100644 (file)
@@ -3,6 +3,7 @@ from io import BytesIO
 from wvtest import *
 
 from bup import vint
+from buptest import no_lingering_errors
 
 
 def encode_and_decode_vuint(x):
@@ -13,10 +14,11 @@ def encode_and_decode_vuint(x):
 
 @wvtest
 def test_vuint():
-    for x in (0, 1, 42, 128, 10**16):
-        WVPASSEQ(encode_and_decode_vuint(x), x)
-    WVEXCEPT(Exception, vint.write_vuint, BytesIO(), -1)
-    WVEXCEPT(EOFError, vint.read_vuint, BytesIO())
+    with no_lingering_errors():
+        for x in (0, 1, 42, 128, 10**16):
+            WVPASSEQ(encode_and_decode_vuint(x), x)
+        WVEXCEPT(Exception, vint.write_vuint, BytesIO(), -1)
+        WVEXCEPT(EOFError, vint.read_vuint, BytesIO())
 
 
 def encode_and_decode_vint(x):
@@ -27,12 +29,13 @@ def encode_and_decode_vint(x):
 
 @wvtest
 def test_vint():
-    values = (0, 1, 42, 64, 10**16)
-    for x in values:
-        WVPASSEQ(encode_and_decode_vint(x), x)
-    for x in [-x for x in values]:
-        WVPASSEQ(encode_and_decode_vint(x), x)
-    WVEXCEPT(EOFError, vint.read_vint, BytesIO())
+    with no_lingering_errors():
+        values = (0, 1, 42, 64, 10**16)
+        for x in values:
+            WVPASSEQ(encode_and_decode_vint(x), x)
+        for x in [-x for x in values]:
+            WVPASSEQ(encode_and_decode_vint(x), x)
+        WVEXCEPT(EOFError, vint.read_vint, BytesIO())
 
 
 def encode_and_decode_bvec(x):
@@ -43,18 +46,19 @@ def encode_and_decode_bvec(x):
 
 @wvtest
 def test_bvec():
-    values = ('', 'x', 'foo', '\0', '\0foo', 'foo\0bar\0')
-    for x in values:
-        WVPASSEQ(encode_and_decode_bvec(x), x)
-    WVEXCEPT(EOFError, vint.read_bvec, BytesIO())
-    outf = BytesIO()
-    for x in ('foo', 'bar', 'baz', 'bax'):
-        vint.write_bvec(outf, x)
-    inf = BytesIO(outf.getvalue())
-    WVPASSEQ(vint.read_bvec(inf), 'foo')
-    WVPASSEQ(vint.read_bvec(inf), 'bar')
-    vint.skip_bvec(inf)
-    WVPASSEQ(vint.read_bvec(inf), 'bax')
+    with no_lingering_errors():
+        values = ('', 'x', 'foo', '\0', '\0foo', 'foo\0bar\0')
+        for x in values:
+            WVPASSEQ(encode_and_decode_bvec(x), x)
+        WVEXCEPT(EOFError, vint.read_bvec, BytesIO())
+        outf = BytesIO()
+        for x in ('foo', 'bar', 'baz', 'bax'):
+            vint.write_bvec(outf, x)
+        inf = BytesIO(outf.getvalue())
+        WVPASSEQ(vint.read_bvec(inf), 'foo')
+        WVPASSEQ(vint.read_bvec(inf), 'bar')
+        vint.skip_bvec(inf)
+        WVPASSEQ(vint.read_bvec(inf), 'bax')
 
 
 def pack_and_unpack(types, *values):
@@ -64,24 +68,25 @@ def pack_and_unpack(types, *values):
 
 @wvtest
 def test_pack_and_unpack():
-    tests = [('', []),
-             ('s', ['foo']),
-             ('ss', ['foo', 'bar']),
-             ('sV', ['foo', 0]),
-             ('sv', ['foo', -1]),
-             ('V', [0]),
-             ('Vs', [0, 'foo']),
-             ('VV', [0, 1]),
-             ('Vv', [0, -1]),
-             ('v', [0]),
-             ('vs', [0, 'foo']),
-             ('vV', [0, 1]),
-             ('vv', [0, -1])]
-    for test in tests:
-        (types, values) = test
-        WVPASSEQ(pack_and_unpack(types, *values), values)
-    WVEXCEPT(Exception, vint.pack, 's')
-    WVEXCEPT(Exception, vint.pack, 's', 'foo', 'bar')
-    WVEXCEPT(Exception, vint.pack, 'x', 1)
-    WVEXCEPT(Exception, vint.unpack, 's', '')
-    WVEXCEPT(Exception, vint.unpack, 'x', '')
+    with no_lingering_errors():
+        tests = [('', []),
+                 ('s', ['foo']),
+                 ('ss', ['foo', 'bar']),
+                 ('sV', ['foo', 0]),
+                 ('sv', ['foo', -1]),
+                 ('V', [0]),
+                 ('Vs', [0, 'foo']),
+                 ('VV', [0, 1]),
+                 ('Vv', [0, -1]),
+                 ('v', [0]),
+                 ('vs', [0, 'foo']),
+                 ('vV', [0, 1]),
+                 ('vv', [0, -1])]
+        for test in tests:
+            (types, values) = test
+            WVPASSEQ(pack_and_unpack(types, *values), values)
+        WVEXCEPT(Exception, vint.pack, 's')
+        WVEXCEPT(Exception, vint.pack, 's', 'foo', 'bar')
+        WVEXCEPT(Exception, vint.pack, 'x', 1)
+        WVEXCEPT(Exception, vint.unpack, 's', '')
+        WVEXCEPT(Exception, vint.unpack, 'x', '')