dev-python/u-msgpack: tweak tests for big-endian platforms
authorSergei Trofimovich <slyfox@gentoo.org>
Fri, 22 Sep 2017 11:17:50 +0000 (12:17 +0100)
committerSergei Trofimovich <slyfox@gentoo.org>
Fri, 22 Sep 2017 19:40:08 +0000 (20:40 +0100)
Noticed test failures on powerpc and powerpc64.

Sent upstream as: https://github.com/vsergeev/u-msgpack-python/pull/31

Package-Manager: Portage-2.3.10, Repoman-2.3.3

dev-python/u-msgpack/files/u-msgpack-2.4.1-little-endian.patch [new file with mode: 0644]
dev-python/u-msgpack/u-msgpack-2.4.1.ebuild

diff --git a/dev-python/u-msgpack/files/u-msgpack-2.4.1-little-endian.patch b/dev-python/u-msgpack/files/u-msgpack-2.4.1-little-endian.patch
new file mode 100644 (file)
index 0000000..c04aca3
--- /dev/null
@@ -0,0 +1,60 @@
+https://github.com/vsergeev/u-msgpack-python/pull/31
+
+From 003289878812c63ef046dc7090953b8dde784f8c Mon Sep 17 00:00:00 2001
+From: Sergei Trofimovich <slyfox@gentoo.org>
+Date: Fri, 22 Sep 2017 12:09:30 +0100
+Subject: [PATCH] test_umsgpack.py: fix test on big-endian platforms
+
+On powerpc and powerpc64 one test fails as:
+
+```
+  $ py.test -v
+  ...
+  test_umsgpack.py::TestUmsgpack::test_pack_ext_handler FAILED
+  test_umsgpack.py::TestUmsgpack::test_unpack_ext_handler FAILED
+  ...
+
+  self = <test_umsgpack.TestUmsgpack testMethod=test_pack_ext_handler>
+
+    def test_pack_ext_handler(self):
+        for (name, obj, data) in ext_handlers_test_vectors:
+            obj_repr = repr(obj)
+            print("\tTesting %s: object %s" %
+                  (name, obj_repr if len(obj_repr) < 24 else obj_repr[0:24] + "..."))
+            packed = umsgpack.packb(obj, ext_handlers=ext_handlers)
+  >           self.assertEqual(packed, data)
+  E           AssertionError: b'\xd7 ?\x80\x00\x00@\x00\x00\x00' != b'\xd7 \x00\x00\x80?\x00\x00\x00@'
+
+  test_umsgpack.py:484: AssertionError
+```
+
+The problem here is in 'struct.pack' output:
+it uses native endianness format but test hardcodes little-endian output.
+
+The change forces 'struct.pack' into little-endian format.
+That way all tests pass:.
+
+Signed-off-by: Sergei Trofimovich <slyfox@gentoo.org>
+---
+ test_umsgpack.py | 4 ++--
+ 1 file changed, 2 insertions(+), 2 deletions(-)
+
+diff --git a/test_umsgpack.py b/test_umsgpack.py
+index a25b5b8..e500276 100644
+--- a/test_umsgpack.py
++++ b/test_umsgpack.py
+@@ -297,9 +297,9 @@ float_precision_test_vectors = [
+ CustomType = namedtuple('CustomType', ['x', 'y', 'z'])
+ ext_handlers = {
+-    complex: lambda obj: umsgpack.Ext(0x20, struct.pack("ff", obj.real, obj.imag)),
++    complex: lambda obj: umsgpack.Ext(0x20, struct.pack("<ff", obj.real, obj.imag)),
+     CustomType: lambda obj: umsgpack.Ext(0x30, umsgpack.packb(list(obj))),
+-    0x20: lambda ext: complex(*struct.unpack("ff", ext.data)),
++    0x20: lambda ext: complex(*struct.unpack("<ff", ext.data)),
+     0x30: lambda ext: CustomType(*umsgpack.unpackb(ext.data)),
+ }
+-- 
+2.14.1
+
index 7f036ea1609c5a2783b78ff2aa1245654613fcb3..7a4bd01ffa321218035f1426ab10e12de565e8cd 100644 (file)
@@ -24,6 +24,8 @@ DEPEND="${RDEPEND}
 
 S=${WORKDIR}/${MY_P}
 
+PATCHES=("${FILESDIR}"/${P}-little-endian.patch)
+
 python_test() {
        py.test -v || die "Tests fail with ${EPYTHON}"
 }