From 6140fe834e23603be47a4ff7a382c07c9e6aedf0 2012-04-06 21:34:59 From: MinRK Date: 2012-04-06 21:34:59 Subject: [PATCH] fix dangling `buffer` in IPython.parallel.util Prevented numpy arrays from being passed as arguments to view.apply. Previously failing test included. --- diff --git a/IPython/parallel/tests/test_view.py b/IPython/parallel/tests/test_view.py index fa0a9c1..1de8318 100644 --- a/IPython/parallel/tests/test_view.py +++ b/IPython/parallel/tests/test_view.py @@ -234,6 +234,19 @@ class TestView(ClusterTestCase): b = view.gather('a', block=True) assert_array_equal(b, a) + @skip_without('numpy') + def test_apply_numpy(self): + """view.apply(f, ndarray)""" + import numpy + from numpy.testing.utils import assert_array_equal, assert_array_almost_equal + + A = numpy.random.random((100,100)) + view = self.client[-1] + for dt in [ 'int32', 'uint8', 'float32', 'float64' ]: + B = A.astype(dt) + C = view.apply_sync(lambda x:x, B) + assert_array_equal(B,C) + def test_map(self): view = self.client[:] def f(x): diff --git a/IPython/parallel/util.py b/IPython/parallel/util.py index f5f389e..6d6fa55 100644 --- a/IPython/parallel/util.py +++ b/IPython/parallel/util.py @@ -41,10 +41,14 @@ from zmq.log import handlers # IPython imports from IPython.config.application import Application +from IPython.utils import py3compat from IPython.utils.pickleutil import can, uncan, canSequence, uncanSequence from IPython.utils.newserialized import serialize, unserialize from IPython.zmq.log import EnginePUBHandler +if py3compat.PY3: + buffer = memoryview + #----------------------------------------------------------------------------- # Classes #-----------------------------------------------------------------------------