blob: 7496d0561cfe163c766e86da29b1427b0da5d6d9 [file] [log] [blame]
Patrick Stewart54679792016-11-08 13:03:34 +00001import pytest
2import sys
Jason Rhinelander391c7542017-07-25 16:47:36 -04003from pybind11_tests import stl_binders as m
Patrick Stewart54679792016-11-08 13:03:34 +00004
5with pytest.suppress(ImportError):
6 import numpy as np
7
8
Dean Moldovana0c1ccf2016-08-12 13:50:00 +02009def test_vector_int():
Jason Rhinelander391c7542017-07-25 16:47:36 -040010 v_int = m.VectorInt([0, 0])
Dean Moldovana0c1ccf2016-08-12 13:50:00 +020011 assert len(v_int) == 2
12 assert bool(v_int) is True
13
Jason Rhinelander391c7542017-07-25 16:47:36 -040014 v_int2 = m.VectorInt([0, 0])
Dean Moldovana0c1ccf2016-08-12 13:50:00 +020015 assert v_int == v_int2
16 v_int2[1] = 1
17 assert v_int != v_int2
18
19 v_int2.append(2)
Dean Moldovana0c1ccf2016-08-12 13:50:00 +020020 v_int2.insert(0, 1)
21 v_int2.insert(0, 2)
22 v_int2.insert(0, 3)
Bruce Merryeee4f4f2017-05-25 15:17:36 +020023 v_int2.insert(6, 3)
Dean Moldovana0c1ccf2016-08-12 13:50:00 +020024 assert str(v_int2) == "VectorInt[3, 2, 1, 0, 1, 2, 3]"
Bruce Merryeee4f4f2017-05-25 15:17:36 +020025 with pytest.raises(IndexError):
26 v_int2.insert(8, 4)
Dean Moldovana0c1ccf2016-08-12 13:50:00 +020027
28 v_int.append(99)
29 v_int2[2:-2] = v_int
Jason Rhinelander391c7542017-07-25 16:47:36 -040030 assert v_int2 == m.VectorInt([3, 2, 0, 0, 99, 2, 3])
Dean Moldovana0c1ccf2016-08-12 13:50:00 +020031 del v_int2[1:3]
Jason Rhinelander391c7542017-07-25 16:47:36 -040032 assert v_int2 == m.VectorInt([3, 0, 99, 2, 3])
Dean Moldovana0c1ccf2016-08-12 13:50:00 +020033 del v_int2[0]
Jason Rhinelander391c7542017-07-25 16:47:36 -040034 assert v_int2 == m.VectorInt([0, 99, 2, 3])
Dean Moldovana0c1ccf2016-08-12 13:50:00 +020035
36
Jason Rhinelander90bac962017-04-14 17:50:44 -040037# related to the PyPy's buffer protocol.
Patrick Stewart54679792016-11-08 13:03:34 +000038@pytest.unsupported_on_pypy
39def test_vector_buffer():
Patrick Stewart54679792016-11-08 13:03:34 +000040 b = bytearray([1, 2, 3, 4])
Jason Rhinelander391c7542017-07-25 16:47:36 -040041 v = m.VectorUChar(b)
Patrick Stewart54679792016-11-08 13:03:34 +000042 assert v[1] == 2
43 v[2] = 5
Jason Rhinelander391c7542017-07-25 16:47:36 -040044 mv = memoryview(v) # We expose the buffer interface
Patrick Stewart54679792016-11-08 13:03:34 +000045 if sys.version_info.major > 2:
Jason Rhinelander391c7542017-07-25 16:47:36 -040046 assert mv[2] == 5
47 mv[2] = 6
Patrick Stewart54679792016-11-08 13:03:34 +000048 else:
Jason Rhinelander391c7542017-07-25 16:47:36 -040049 assert mv[2] == '\x05'
50 mv[2] = '\x06'
Patrick Stewart54679792016-11-08 13:03:34 +000051 assert v[2] == 6
52
Jason Rhinelander391c7542017-07-25 16:47:36 -040053 with pytest.raises(RuntimeError) as excinfo:
54 m.create_undeclstruct() # Undeclared struct contents, no buffer interface
55 assert "NumPy type info missing for " in str(excinfo.value)
Patrick Stewart54679792016-11-08 13:03:34 +000056
57
Jason Rhinelander90bac962017-04-14 17:50:44 -040058@pytest.unsupported_on_pypy
Patrick Stewart54679792016-11-08 13:03:34 +000059@pytest.requires_numpy
60def test_vector_buffer_numpy():
Patrick Stewart54679792016-11-08 13:03:34 +000061 a = np.array([1, 2, 3, 4], dtype=np.int32)
62 with pytest.raises(TypeError):
Jason Rhinelander391c7542017-07-25 16:47:36 -040063 m.VectorInt(a)
Patrick Stewart54679792016-11-08 13:03:34 +000064
65 a = np.array([[1, 2, 3, 4], [5, 6, 7, 8], [9, 10, 11, 12]], dtype=np.uintc)
Jason Rhinelander391c7542017-07-25 16:47:36 -040066 v = m.VectorInt(a[0, :])
Patrick Stewart54679792016-11-08 13:03:34 +000067 assert len(v) == 4
68 assert v[2] == 3
Jason Rhinelander391c7542017-07-25 16:47:36 -040069 ma = np.asarray(v)
70 ma[2] = 5
Patrick Stewart54679792016-11-08 13:03:34 +000071 assert v[2] == 5
72
Jason Rhinelander391c7542017-07-25 16:47:36 -040073 v = m.VectorInt(a[:, 1])
Patrick Stewart54679792016-11-08 13:03:34 +000074 assert len(v) == 3
75 assert v[2] == 10
76
Jason Rhinelander391c7542017-07-25 16:47:36 -040077 v = m.get_vectorstruct()
Patrick Stewart54679792016-11-08 13:03:34 +000078 assert v[0].x == 5
Jason Rhinelander391c7542017-07-25 16:47:36 -040079 ma = np.asarray(v)
80 ma[1]['x'] = 99
Patrick Stewart54679792016-11-08 13:03:34 +000081 assert v[1].x == 99
82
Jason Rhinelander391c7542017-07-25 16:47:36 -040083 v = m.VectorStruct(np.zeros(3, dtype=np.dtype([('w', 'bool'), ('x', 'I'),
84 ('y', 'float64'), ('z', 'bool')], align=True)))
Patrick Stewart0b6d08a2016-11-21 17:40:43 +000085 assert len(v) == 3
86
Patrick Stewart54679792016-11-08 13:03:34 +000087
Dean Moldovana0c1ccf2016-08-12 13:50:00 +020088def test_vector_bool():
Jason Rhinelander391c7542017-07-25 16:47:36 -040089 vv_c = m.VectorBool()
Dean Moldovana0c1ccf2016-08-12 13:50:00 +020090 for i in range(10):
91 vv_c.append(i % 2 == 0)
92 for i in range(10):
93 assert vv_c[i] == (i % 2 == 0)
94 assert str(vv_c) == "VectorBool[1, 0, 1, 0, 1, 0, 1, 0, 1, 0]"
Sergey Lyskov75204182016-08-29 22:50:38 -040095
Dean Moldovanbad17402016-11-20 21:21:54 +010096
Jason Rhinelander391c7542017-07-25 16:47:36 -040097def test_vector_custom():
98 v_a = m.VectorEl()
99 v_a.append(m.El(1))
100 v_a.append(m.El(2))
101 assert str(v_a) == "VectorEl[El{1}, El{2}]"
102
103 vv_a = m.VectorVectorEl()
104 vv_a.append(v_a)
105 vv_b = vv_a[0]
106 assert str(vv_b) == "VectorEl[El{1}, El{2}]"
107
108
Sergey Lyskov75204182016-08-29 22:50:38 -0400109def test_map_string_double():
Jason Rhinelander391c7542017-07-25 16:47:36 -0400110 mm = m.MapStringDouble()
111 mm['a'] = 1
112 mm['b'] = 2.5
Sergey Lyskov75204182016-08-29 22:50:38 -0400113
Jason Rhinelander391c7542017-07-25 16:47:36 -0400114 assert list(mm) == ['a', 'b']
115 assert list(mm.items()) == [('a', 1), ('b', 2.5)]
116 assert str(mm) == "MapStringDouble{a: 1, b: 2.5}"
Sergey Lyskov75204182016-08-29 22:50:38 -0400117
Jason Rhinelander391c7542017-07-25 16:47:36 -0400118 um = m.UnorderedMapStringDouble()
Sergey Lyskov75204182016-08-29 22:50:38 -0400119 um['ua'] = 1.1
120 um['ub'] = 2.6
121
Dean Moldovanbad17402016-11-20 21:21:54 +0100122 assert sorted(list(um)) == ['ua', 'ub']
123 assert sorted(list(um.items())) == [('ua', 1.1), ('ub', 2.6)]
124 assert "UnorderedMapStringDouble" in str(um)
Sergey Lyskov75204182016-08-29 22:50:38 -0400125
126
127def test_map_string_double_const():
Jason Rhinelander391c7542017-07-25 16:47:36 -0400128 mc = m.MapStringDoubleConst()
Sergey Lyskov75204182016-08-29 22:50:38 -0400129 mc['a'] = 10
130 mc['b'] = 20.5
131 assert str(mc) == "MapStringDoubleConst{a: 10, b: 20.5}"
132
Jason Rhinelander391c7542017-07-25 16:47:36 -0400133 umc = m.UnorderedMapStringDoubleConst()
Sergey Lyskov75204182016-08-29 22:50:38 -0400134 umc['a'] = 11
135 umc['b'] = 21.5
136
137 str(umc)
Jason Rhinelander617fbcf2016-11-15 06:30:38 -0500138
Dean Moldovanbad17402016-11-20 21:21:54 +0100139
Jason Rhinelander391c7542017-07-25 16:47:36 -0400140def test_noncopyable_containers():
141 # std::vector
142 vnc = m.get_vnc(5)
Jason Rhinelander617fbcf2016-11-15 06:30:38 -0500143 for i in range(0, 5):
Dean Moldovanbad17402016-11-20 21:21:54 +0100144 assert vnc[i].value == i + 1
Jason Rhinelander617fbcf2016-11-15 06:30:38 -0500145
Dean Moldovanbad17402016-11-20 21:21:54 +0100146 for i, j in enumerate(vnc, start=1):
147 assert j.value == i
148
Jason Rhinelander391c7542017-07-25 16:47:36 -0400149 # std::deque
150 dnc = m.get_dnc(5)
Jason Rhinelander617fbcf2016-11-15 06:30:38 -0500151 for i in range(0, 5):
Dean Moldovanbad17402016-11-20 21:21:54 +0100152 assert dnc[i].value == i + 1
Jason Rhinelander617fbcf2016-11-15 06:30:38 -0500153
154 i = 1
155 for j in dnc:
156 assert(j.value == i)
157 i += 1
158
Jason Rhinelander391c7542017-07-25 16:47:36 -0400159 # std::map
160 mnc = m.get_mnc(5)
Jason Rhinelander617fbcf2016-11-15 06:30:38 -0500161 for i in range(1, 6):
Dean Moldovanbad17402016-11-20 21:21:54 +0100162 assert mnc[i].value == 10 * i
Jason Rhinelander617fbcf2016-11-15 06:30:38 -0500163
Jason Rhinelander617fbcf2016-11-15 06:30:38 -0500164 vsum = 0
165 for k, v in mnc.items():
Dean Moldovanbad17402016-11-20 21:21:54 +0100166 assert v.value == 10 * k
Jason Rhinelander617fbcf2016-11-15 06:30:38 -0500167 vsum += v.value
168
Dean Moldovanbad17402016-11-20 21:21:54 +0100169 assert vsum == 150
170
Jason Rhinelander391c7542017-07-25 16:47:36 -0400171 # std::unordered_map
172 mnc = m.get_umnc(5)
Jason Rhinelander617fbcf2016-11-15 06:30:38 -0500173 for i in range(1, 6):
Dean Moldovanbad17402016-11-20 21:21:54 +0100174 assert mnc[i].value == 10 * i
Jason Rhinelander617fbcf2016-11-15 06:30:38 -0500175
Jason Rhinelander617fbcf2016-11-15 06:30:38 -0500176 vsum = 0
177 for k, v in mnc.items():
Dean Moldovanbad17402016-11-20 21:21:54 +0100178 assert v.value == 10 * k
Jason Rhinelander617fbcf2016-11-15 06:30:38 -0500179 vsum += v.value
180
Dean Moldovanbad17402016-11-20 21:21:54 +0100181 assert vsum == 150