blob: f006552bf7257412d5cea0f2ff6f9278d13fec6a [file] [log] [blame]
Bruce Merryfe0cf8b2017-05-17 10:52:33 +02001import struct
Dean Moldovana0c1ccf2016-08-12 13:50:00 +02002import pytest
Jason Rhinelander391c7542017-07-25 16:47:36 -04003from pybind11_tests import buffers as m
4from pybind11_tests import ConstructorStats
Dean Moldovana0c1ccf2016-08-12 13:50:00 +02005
Dean Moldovand47febc2017-03-10 15:42:42 +01006pytestmark = pytest.requires_numpy
7
Dean Moldovana0c1ccf2016-08-12 13:50:00 +02008with pytest.suppress(ImportError):
9 import numpy as np
10
11
Dean Moldovana0c1ccf2016-08-12 13:50:00 +020012def test_from_python():
13 with pytest.raises(RuntimeError) as excinfo:
Jason Rhinelander391c7542017-07-25 16:47:36 -040014 m.Matrix(np.array([1, 2, 3])) # trying to assign a 1D array
Dean Moldovana0c1ccf2016-08-12 13:50:00 +020015 assert str(excinfo.value) == "Incompatible buffer format!"
16
17 m3 = np.array([[1, 2, 3], [4, 5, 6]]).astype(np.float32)
Jason Rhinelander391c7542017-07-25 16:47:36 -040018 m4 = m.Matrix(m3)
Dean Moldovana0c1ccf2016-08-12 13:50:00 +020019
20 for i in range(m4.rows()):
21 for j in range(m4.cols()):
22 assert m3[i, j] == m4[i, j]
23
Jason Rhinelander391c7542017-07-25 16:47:36 -040024 cstats = ConstructorStats.get(m.Matrix)
Dean Moldovana0c1ccf2016-08-12 13:50:00 +020025 assert cstats.alive() == 1
26 del m3, m4
27 assert cstats.alive() == 0
28 assert cstats.values() == ["2x3 matrix"]
29 assert cstats.copy_constructions == 0
30 # assert cstats.move_constructions >= 0 # Don't invoke any
31 assert cstats.copy_assignments == 0
32 assert cstats.move_assignments == 0
Wenzel Jakob1d1f81b2016-12-16 15:00:46 +010033
34
35# PyPy: Memory leak in the "np.array(m, copy=False)" call
36# https://bitbucket.org/pypy/pypy/issues/2444
37@pytest.unsupported_on_pypy
Wenzel Jakob1d1f81b2016-12-16 15:00:46 +010038def test_to_python():
Ansgar Burchardta22dd2d2017-09-21 23:07:48 +020039 mat = m.Matrix(5, 4)
40 assert memoryview(mat).shape == (5, 4)
Wenzel Jakob1d1f81b2016-12-16 15:00:46 +010041
Jason Rhinelander391c7542017-07-25 16:47:36 -040042 assert mat[2, 3] == 0
Ansgar Burchardta22dd2d2017-09-21 23:07:48 +020043 mat[2, 3] = 4.0
44 mat[3, 2] = 7.0
Jason Rhinelander391c7542017-07-25 16:47:36 -040045 assert mat[2, 3] == 4
Ansgar Burchardta22dd2d2017-09-21 23:07:48 +020046 assert mat[3, 2] == 7
47 assert struct.unpack_from('f', mat, (3 * 4 + 2) * 4) == (7, )
48 assert struct.unpack_from('f', mat, (2 * 4 + 3) * 4) == (4, )
Wenzel Jakob1d1f81b2016-12-16 15:00:46 +010049
Jason Rhinelander391c7542017-07-25 16:47:36 -040050 mat2 = np.array(mat, copy=False)
Ansgar Burchardta22dd2d2017-09-21 23:07:48 +020051 assert mat2.shape == (5, 4)
52 assert abs(mat2).sum() == 11
53 assert mat2[2, 3] == 4 and mat2[3, 2] == 7
Jason Rhinelander391c7542017-07-25 16:47:36 -040054 mat2[2, 3] = 5
55 assert mat2[2, 3] == 5
Wenzel Jakob1d1f81b2016-12-16 15:00:46 +010056
Jason Rhinelander391c7542017-07-25 16:47:36 -040057 cstats = ConstructorStats.get(m.Matrix)
Wenzel Jakob1d1f81b2016-12-16 15:00:46 +010058 assert cstats.alive() == 1
Jason Rhinelander391c7542017-07-25 16:47:36 -040059 del mat
Wenzel Jakob1d1f81b2016-12-16 15:00:46 +010060 pytest.gc_collect()
61 assert cstats.alive() == 1
Jason Rhinelander391c7542017-07-25 16:47:36 -040062 del mat2 # holds a mat reference
Wenzel Jakob1d1f81b2016-12-16 15:00:46 +010063 pytest.gc_collect()
64 assert cstats.alive() == 0
Ansgar Burchardta22dd2d2017-09-21 23:07:48 +020065 assert cstats.values() == ["5x4 matrix"]
Wenzel Jakob1d1f81b2016-12-16 15:00:46 +010066 assert cstats.copy_constructions == 0
67 # assert cstats.move_constructions >= 0 # Don't invoke any
68 assert cstats.copy_assignments == 0
69 assert cstats.move_assignments == 0
Bruce Merryfe0cf8b2017-05-17 10:52:33 +020070
71
72@pytest.unsupported_on_pypy
Dean Moldovan427e4af2017-05-28 16:35:02 +020073def test_inherited_protocol():
74 """SquareMatrix is derived from Matrix and inherits the buffer protocol"""
Dean Moldovan427e4af2017-05-28 16:35:02 +020075
Jason Rhinelander391c7542017-07-25 16:47:36 -040076 matrix = m.SquareMatrix(5)
Dean Moldovan427e4af2017-05-28 16:35:02 +020077 assert memoryview(matrix).shape == (5, 5)
78 assert np.asarray(matrix).shape == (5, 5)
79
80
81@pytest.unsupported_on_pypy
Jason Rhinelander391c7542017-07-25 16:47:36 -040082def test_pointer_to_member_fn():
83 for cls in [m.Buffer, m.ConstBuffer, m.DerivedBuffer]:
Bruce Merryfe0cf8b2017-05-17 10:52:33 +020084 buf = cls()
85 buf.value = 0x12345678
86 value = struct.unpack('i', bytearray(buf))[0]
87 assert value == 0x12345678