mirror of
https://github.com/pybind/pybind11.git
synced 2026-04-20 06:49:25 +00:00
Fix /= operator under Python 3
The Python method for /= was set as `__idiv__`, which should be `__itruediv__` under Python 3. This wasn't totally broken in that without it defined, Python constructs a new object by calling __truediv__. The operator tests, however, didn't actually test the /= operator: when I added it, I saw an extra construction, leading to the problem. This commit also includes tests for the previously untested *= operator, and adds some element-wise vector multiplication and division operators.
This commit is contained in:
@@ -16,10 +16,21 @@ def test_operator_overloading():
|
||||
assert str(8 + v1) == "[9.000000, 10.000000]"
|
||||
assert str(8 * v1) == "[8.000000, 16.000000]"
|
||||
assert str(8 / v1) == "[8.000000, 4.000000]"
|
||||
assert str(v1 * v2) == "[3.000000, -2.000000]"
|
||||
assert str(v2 / v1) == "[3.000000, -0.500000]"
|
||||
|
||||
v1 += v2
|
||||
v1 += 2 * v2
|
||||
assert str(v1) == "[7.000000, 0.000000]"
|
||||
v1 -= v2
|
||||
assert str(v1) == "[4.000000, 1.000000]"
|
||||
v1 *= 2
|
||||
assert str(v1) == "[8.000000, 2.000000]"
|
||||
v1 /= 16
|
||||
assert str(v1) == "[0.500000, 0.125000]"
|
||||
v1 *= v2
|
||||
assert str(v1) == "[1.500000, -0.125000]"
|
||||
v2 /= v1
|
||||
assert str(v2) == "[2.000000, 8.000000]"
|
||||
|
||||
cstats = ConstructorStats.get(Vector2)
|
||||
assert cstats.alive() == 2
|
||||
@@ -32,7 +43,9 @@ def test_operator_overloading():
|
||||
'[-7.000000, -6.000000]', '[9.000000, 10.000000]',
|
||||
'[8.000000, 16.000000]', '[0.125000, 0.250000]',
|
||||
'[7.000000, 6.000000]', '[9.000000, 10.000000]',
|
||||
'[8.000000, 16.000000]', '[8.000000, 4.000000]']
|
||||
'[8.000000, 16.000000]', '[8.000000, 4.000000]',
|
||||
'[3.000000, -2.000000]', '[3.000000, -0.500000]',
|
||||
'[6.000000, -2.000000]']
|
||||
assert cstats.default_constructions == 0
|
||||
assert cstats.copy_constructions == 0
|
||||
assert cstats.move_constructions >= 10
|
||||
|
||||
Reference in New Issue
Block a user