test_sequences_and_iterators.py
Go to the documentation of this file.
1 import pytest
2 from pytest import approx # noqa: PT013
3 
4 from pybind11_tests import ConstructorStats
5 from pybind11_tests import sequences_and_iterators as m
6 
7 
9  assert m.make_forward_slice_size_t() == slice(0, -1, 1)
10  assert m.make_reversed_slice_object() == slice(None, None, -1)
11 
12 
13 @pytest.mark.skipif(not m.has_optional, reason="no <optional>")
15  assert m.make_reversed_slice_size_t_optional() == slice(None, None, -1)
16  assert m.make_reversed_slice_size_t_optional_verbose() == slice(None, None, -1)
17 
18 
20  assert list(m.IntPairs([(1, 2), (3, 4), (0, 5)]).nonzero()) == [(1, 2), (3, 4)]
21  assert list(m.IntPairs([(1, 2), (2, 0), (0, 3), (4, 5)]).nonzero()) == [(1, 2)]
22  assert list(m.IntPairs([(0, 3), (1, 2), (3, 4)]).nonzero()) == []
23 
24  assert list(m.IntPairs([(1, 2), (3, 4), (0, 5)]).nonzero_keys()) == [1, 3]
25  assert list(m.IntPairs([(1, 2), (2, 0), (0, 3), (4, 5)]).nonzero_keys()) == [1]
26  assert list(m.IntPairs([(0, 3), (1, 2), (3, 4)]).nonzero_keys()) == []
27 
28  assert list(m.IntPairs([(1, 2), (3, 4), (0, 5)]).nonzero_values()) == [2, 4]
29  assert list(m.IntPairs([(1, 2), (2, 0), (0, 3), (4, 5)]).nonzero_values()) == [2]
30  assert list(m.IntPairs([(0, 3), (1, 2), (3, 4)]).nonzero_values()) == []
31 
32  # __next__ must continue to raise StopIteration
33  it = m.IntPairs([(0, 0)]).nonzero()
34  for _ in range(3):
35  with pytest.raises(StopIteration):
36  next(it)
37 
38  it = m.IntPairs([(0, 0)]).nonzero_keys()
39  for _ in range(3):
40  with pytest.raises(StopIteration):
41  next(it)
42 
43 
45  pairs = m.IntPairs([(1, 2), (3, 4), (0, 5)])
46  assert list(pairs.nonref()) == [(1, 2), (3, 4), (0, 5)]
47  assert list(pairs.nonref_keys()) == [1, 3, 0]
48  assert list(pairs.nonref_values()) == [2, 4, 5]
49 
50 
52  assert list(m.IntPairs([(1, 2), (3, 4), (0, 5)]).simple_iterator()) == [
53  (1, 2),
54  (3, 4),
55  (0, 5),
56  ]
57  assert list(m.IntPairs([(1, 2), (3, 4), (0, 5)]).simple_keys()) == [1, 3, 0]
58  assert list(m.IntPairs([(1, 2), (3, 4), (0, 5)]).simple_values()) == [2, 4, 5]
59 
60 
62  """Test that iterators reference rather than copy their referents."""
63  vec = m.VectorNonCopyableInt()
64  vec.append(3)
65  vec.append(5)
66  assert [int(x) for x in vec] == [3, 5]
67  # Increment everything to make sure the referents can be mutated
68  for x in vec:
69  x.set(int(x) + 1)
70  assert [int(x) for x in vec] == [4, 6]
71 
72  vec = m.VectorNonCopyableIntPair()
73  vec.append([3, 4])
74  vec.append([5, 7])
75  assert [int(x) for x in vec.keys()] == [3, 5]
76  assert [int(x) for x in vec.values()] == [4, 7]
77  for x in vec.keys():
78  x.set(int(x) + 1)
79  for x in vec.values():
80  x.set(int(x) + 10)
81  assert [int(x) for x in vec.keys()] == [4, 6]
82  assert [int(x) for x in vec.values()] == [14, 17]
83 
84 
86  sliceable = m.Sliceable(100)
87  assert sliceable[::] == (0, 100, 1)
88  assert sliceable[10::] == (10, 100, 1)
89  assert sliceable[:10:] == (0, 10, 1)
90  assert sliceable[::10] == (0, 100, 10)
91  assert sliceable[-10::] == (90, 100, 1)
92  assert sliceable[:-10:] == (0, 90, 1)
93  assert sliceable[::-10] == (99, -1, -10)
94  assert sliceable[50:60:1] == (50, 60, 1)
95  assert sliceable[50:60:-1] == (50, 60, -1)
96 
97 
99  cstats = ConstructorStats.get(m.Sequence)
100 
101  s = m.Sequence(5)
102  assert cstats.values() == ["of size", "5"]
103 
104  assert "Sequence" in repr(s)
105  assert len(s) == 5
106  assert s[0] == 0
107  assert s[3] == 0
108  assert 12.34 not in s
109  s[0], s[3] = 12.34, 56.78
110  assert 12.34 in s
111  assert s[0] == approx(12.34, rel=1e-05)
112  assert s[3] == approx(56.78, rel=1e-05)
113 
114  rev = reversed(s)
115  assert cstats.values() == ["of size", "5"]
116 
117  rev2 = s[::-1]
118  assert cstats.values() == ["of size", "5"]
119 
120  it = iter(m.Sequence(0))
121  for _ in range(3): # __next__ must continue to raise StopIteration
122  with pytest.raises(StopIteration):
123  next(it)
124  assert cstats.values() == ["of size", "0"]
125 
126  expected = [0, 56.78, 0, 0, 12.34]
127  assert rev == approx(expected, rel=1e-05)
128  assert rev2 == approx(expected, rel=1e-05)
129  assert rev == rev2
130 
131  rev[0::2] = m.Sequence([2.0, 2.0, 2.0])
132  assert cstats.values() == ["of size", "3", "from std::vector"]
133 
134  assert rev == approx([2, 56.78, 2, 0, 2], rel=1e-05)
135 
136  assert cstats.alive() == 4
137  del it
138  assert cstats.alive() == 3
139  del s
140  assert cstats.alive() == 2
141  del rev
142  assert cstats.alive() == 1
143  del rev2
144  assert cstats.alive() == 0
145 
146  assert cstats.values() == []
147  assert cstats.default_constructions == 0
148  assert cstats.copy_constructions == 0
149  assert cstats.move_constructions >= 1
150  assert cstats.copy_assignments == 0
151  assert cstats.move_assignments == 0
152 
153 
155  """#2076: Exception raised by len(arg) should be propagated"""
156 
157  class BadLen(RuntimeError):
158  pass
159 
160  class SequenceLike:
161  def __getitem__(self, i):
162  return None
163 
164  def __len__(self):
165  raise BadLen()
166 
167  with pytest.raises(BadLen):
168  m.sequence_length(SequenceLike())
169 
170  assert m.sequence_length([1, 2, 3]) == 3
171  assert m.sequence_length("hello") == 5
172 
173 
175  sm = m.StringMap({"hi": "bye", "black": "white"})
176  assert sm["hi"] == "bye"
177  assert len(sm) == 2
178  assert sm["black"] == "white"
179 
180  with pytest.raises(KeyError):
181  assert sm["orange"]
182  sm["orange"] = "banana"
183  assert sm["orange"] == "banana"
184 
185  expected = {"hi": "bye", "black": "white", "orange": "banana"}
186  for k in sm:
187  assert sm[k] == expected[k]
188  for k, v in sm.items():
189  assert v == expected[k]
190  assert list(sm.values()) == [expected[k] for k in sm]
191 
192  it = iter(m.StringMap({}))
193  for _ in range(3): # __next__ must continue to raise StopIteration
194  with pytest.raises(StopIteration):
195  next(it)
196 
197 
199  t = (1, 2, 3)
200  assert m.object_to_list(t) == [1, 2, 3]
201  assert m.object_to_list(iter(t)) == [1, 2, 3]
202  assert m.iterator_to_list(iter(t)) == [1, 2, 3]
203 
204  with pytest.raises(TypeError) as excinfo:
205  m.object_to_list(1)
206  assert "object is not iterable" in str(excinfo.value)
207 
208  with pytest.raises(TypeError) as excinfo:
209  m.iterator_to_list(1)
210  assert "incompatible function arguments" in str(excinfo.value)
211 
212  def bad_next_call():
213  raise RuntimeError("py::iterator::advance() should propagate errors")
214 
215  with pytest.raises(RuntimeError) as excinfo:
216  m.iterator_to_list(iter(bad_next_call, None))
217  assert str(excinfo.value) == "py::iterator::advance() should propagate errors"
218 
219  lst = [1, None, 0, None]
220  assert m.count_none(lst) == 2
221  assert m.find_none(lst) is True
222  assert m.count_nonzeros({"a": 0, "b": 1, "c": 2}) == 2
223 
224  r = range(5)
225  assert all(m.tuple_iterator(tuple(r)))
226  assert all(m.list_iterator(list(r)))
227  assert all(m.sequence_iterator(r))
228 
229 
231  """#181: iterator passthrough did not compile"""
232  from pybind11_tests.sequences_and_iterators import iterator_passthrough
233 
234  values = [3, 5, 7, 9, 11, 13, 15]
235  assert list(iterator_passthrough(iter(values))) == values
236 
237 
239  """#388: Can't make iterators via make_iterator() with different r/v policies"""
240  import pybind11_tests.sequences_and_iterators as m
241 
242  assert list(m.make_iterator_1()) == [1, 2, 3]
243  assert list(m.make_iterator_2()) == [1, 2, 3]
244  assert not isinstance(m.make_iterator_1(), type(m.make_iterator_2()))
245 
246 
248  """#4100: Check for proper iterator overload with C-Arrays"""
249  args_gt = [float(i) for i in range(3)]
250  arr_h = m.CArrayHolder(*args_gt)
251  args = list(arr_h)
252  assert args_gt == args
gtsam.examples.DogLegOptimizerExample.int
int
Definition: DogLegOptimizerExample.py:111
test_sequences_and_iterators.test_iterator_referencing
def test_iterator_referencing()
Definition: test_sequences_and_iterators.py:61
test_sequences_and_iterators.test_slice_constructors_explicit_optional
def test_slice_constructors_explicit_optional()
Definition: test_sequences_and_iterators.py:14
list
Definition: pytypes.h:2124
test_sequences_and_iterators.test_python_iterator_in_cpp
def test_python_iterator_in_cpp()
Definition: test_sequences_and_iterators.py:198
test_sequences_and_iterators.test_sequence_length
def test_sequence_length()
Definition: test_sequences_and_iterators.py:154
test_sequences_and_iterators.test_generalized_iterators_simple
def test_generalized_iterators_simple()
Definition: test_sequences_and_iterators.py:51
type
Definition: pytypes.h:1491
test_sequences_and_iterators.test_sliceable
def test_sliceable()
Definition: test_sequences_and_iterators.py:85
gtsam::range
Double_ range(const Point2_ &p, const Point2_ &q)
Definition: slam/expressions.h:30
test_sequences_and_iterators.test_nonref_iterators
def test_nonref_iterators()
Definition: test_sequences_and_iterators.py:44
slice
Definition: pytypes.h:1867
test_sequences_and_iterators.test_sequence
def test_sequence()
Definition: test_sequences_and_iterators.py:98
isinstance
bool isinstance(handle obj)
Definition: pytypes.h:825
Eigen::all
static const Eigen::internal::all_t all
Definition: IndexedViewHelper.h:171
test_sequences_and_iterators.test_slice_constructors
def test_slice_constructors()
Definition: test_sequences_and_iterators.py:8
test_sequences_and_iterators.test_map_iterator
def test_map_iterator()
Definition: test_sequences_and_iterators.py:174
test_sequences_and_iterators.test_carray_iterator
def test_carray_iterator()
Definition: test_sequences_and_iterators.py:247
str
Definition: pytypes.h:1524
test_sequences_and_iterators.test_iterator_passthrough
def test_iterator_passthrough()
Definition: test_sequences_and_iterators.py:230
iter
iterator iter(handle obj)
Definition: pytypes.h:2428
ConstructorStats::get
static ConstructorStats & get(std::type_index type)
Definition: constructor_stats.h:163
tuple
Definition: pytypes.h:2035
gtsam.examples.DogLegOptimizerExample.float
float
Definition: DogLegOptimizerExample.py:113
len
size_t len(handle h)
Get the length of a Python object.
Definition: pytypes.h:2399
test_sequences_and_iterators.test_generalized_iterators
def test_generalized_iterators()
Definition: test_sequences_and_iterators.py:19
test_sequences_and_iterators.test_iterator_rvp
def test_iterator_rvp()
Definition: test_sequences_and_iterators.py:238
repr
str repr(handle h)
Definition: pytypes.h:2420


gtsam
Author(s):
autogenerated on Tue Jun 25 2024 03:05:31