mirror of
https://github.com/Relintai/gdnative_python.git
synced 2025-01-06 15:19:40 +01:00
231 lines
5.8 KiB
Python
231 lines
5.8 KiB
Python
import pytest
|
|
from enum import IntEnum
|
|
|
|
from pandemonium import Vector3
|
|
|
|
|
|
def test_base():
|
|
v = Vector3()
|
|
assert isinstance(v, Vector3)
|
|
v2 = Vector3(1, -2, 5)
|
|
assert isinstance(v2, Vector3)
|
|
assert v2 == Vector3(1, -2, 5)
|
|
assert v != v2
|
|
|
|
|
|
def test_repr():
|
|
v = Vector3(1, 2, 3)
|
|
assert repr(v) == "<Vector3(x=1.0, y=2.0, z=3.0)>"
|
|
|
|
|
|
def test_instantiate():
|
|
# Can build it with int or float or nothing
|
|
for args, expected_x, expected_y, expected_z in (
|
|
[(), 0, 0, 0],
|
|
[(0.5, 0.5, 0.5), 0.5, 0.5, 0.5],
|
|
[(1,), 1, 0, 0],
|
|
[(1, 1), 1, 1, 0],
|
|
[(1, 2, 3), 1, 2, 3],
|
|
):
|
|
v = Vector3(*args)
|
|
assert v.x == expected_x
|
|
assert v.y == expected_y
|
|
assert v.z == expected_z
|
|
with pytest.raises(TypeError):
|
|
Vector3("a", 2, 3)
|
|
with pytest.raises(TypeError):
|
|
Vector3("a", 2)
|
|
with pytest.raises(TypeError):
|
|
Vector3(1, "b", 5)
|
|
with pytest.raises(TypeError):
|
|
Vector3(None, 2, "c")
|
|
|
|
|
|
@pytest.mark.parametrize(
|
|
"field,ret_type,params",
|
|
[
|
|
["abs", Vector3, ()],
|
|
["angle_to", float, (Vector3(),)],
|
|
["ceil", Vector3, ()],
|
|
["cross", Vector3, (Vector3(),)],
|
|
["cubic_interpolate", Vector3, (Vector3(), Vector3(), Vector3(), 0.5)],
|
|
["distance_squared_to", float, (Vector3(),)],
|
|
["distance_to", float, (Vector3(),)],
|
|
["dot", float, (Vector3(),)],
|
|
["floor", Vector3, ()],
|
|
["inverse", Vector3, ()],
|
|
["length", float, ()],
|
|
["length_squared", float, ()],
|
|
["linear_interpolate", Vector3, (Vector3(), 0.5)],
|
|
["max_axis", int, ()],
|
|
["min_axis", int, ()],
|
|
["normalized", Vector3, ()],
|
|
["reflect", Vector3, (Vector3(),)],
|
|
["rotated", Vector3, (Vector3(), 0.5)],
|
|
["slide", Vector3, (Vector3(),)],
|
|
["snapped", Vector3, (Vector3(),)],
|
|
],
|
|
ids=lambda x: x[0],
|
|
)
|
|
def test_methods(field, ret_type, params):
|
|
v = Vector3()
|
|
# Don't test methods' validity but bindings one
|
|
assert hasattr(v, field)
|
|
method = getattr(v, field)
|
|
assert callable(method)
|
|
ret = method(*params)
|
|
assert isinstance(ret, ret_type)
|
|
|
|
|
|
@pytest.mark.parametrize(
|
|
"field,type", [("x", float), ("y", float), ("z", float)], ids=lambda x: x[0]
|
|
)
|
|
def test_properties(field, type):
|
|
v = Vector3()
|
|
field_val = getattr(v, field)
|
|
assert isinstance(field_val, type)
|
|
val = 10.0
|
|
setattr(v, field, val)
|
|
field_val = getattr(v, field)
|
|
assert field_val == val
|
|
|
|
|
|
@pytest.mark.parametrize(
|
|
"field,bad_value",
|
|
[("x", "NaN"), ("y", "NaN"), ("z", "NaN"), ("x", None), ("y", None), ("z", None)],
|
|
ids=lambda x: x[0],
|
|
)
|
|
def test_bad_properties(field, bad_value):
|
|
v = Vector3()
|
|
with pytest.raises(TypeError):
|
|
setattr(v, field, bad_value)
|
|
|
|
|
|
@pytest.mark.parametrize(
|
|
"param,result",
|
|
[
|
|
(0, Vector3(0, 0, 0)),
|
|
(1, Vector3(2, 3, 4)),
|
|
(2.5, Vector3(5, 7.5, 10)),
|
|
(Vector3(1, 1, 1), Vector3(2, 3, 4)),
|
|
(Vector3(2, 3, 4), Vector3(4, 9, 16)),
|
|
],
|
|
ids=lambda x: x[0],
|
|
)
|
|
def test_mult(param, result):
|
|
calc = Vector3(2, 3, 4) * param
|
|
assert calc == result
|
|
|
|
|
|
@pytest.mark.parametrize(
|
|
"param,result",
|
|
[
|
|
(1, Vector3(2, 3, 4)),
|
|
(0.5, Vector3(4, 6, 8)),
|
|
(2, Vector3(1, 1.5, 2)),
|
|
(Vector3(1, 1, 1), Vector3(2, 3, 4)),
|
|
(Vector3(2, 3, 4), Vector3(1, 1, 1)),
|
|
],
|
|
ids=lambda x: x[0],
|
|
)
|
|
def test_div(param, result):
|
|
calc = Vector3(2, 3, 4) / param
|
|
assert calc == result
|
|
|
|
|
|
@pytest.mark.parametrize(
|
|
"param,result",
|
|
[
|
|
(Vector3(0, 0, 0), Vector3(2, 3, 4)),
|
|
(Vector3(3, 2, 1), Vector3(5, 5, 5)),
|
|
(Vector3(-1, -4, -2), Vector3(1, -1, 2)),
|
|
],
|
|
ids=lambda x: x[0],
|
|
)
|
|
def test_add(param, result):
|
|
calc = Vector3(2, 3, 4) + param
|
|
assert calc == result
|
|
|
|
|
|
@pytest.mark.parametrize(
|
|
"param,result",
|
|
[
|
|
(Vector3(0, 0, 0), Vector3(2, 3, 4)),
|
|
(Vector3(3, 2, 1), Vector3(-1, 1, 3)),
|
|
(Vector3(-1, -1, -1), Vector3(3, 4, 5)),
|
|
],
|
|
ids=lambda x: x[0],
|
|
)
|
|
def test_sub(param, result):
|
|
calc = Vector3(2, 3, 4) - param
|
|
assert calc == result
|
|
|
|
|
|
@pytest.mark.parametrize("arg", [None, 1, "dummy"], ids=lambda x: x[0])
|
|
def test_bad_add(arg):
|
|
with pytest.raises(TypeError):
|
|
Vector3(2, 3, 4) + arg
|
|
|
|
|
|
@pytest.mark.parametrize("arg", [None, 1, "dummy"], ids=lambda x: x[0])
|
|
def test_bad_sub(arg):
|
|
with pytest.raises(TypeError):
|
|
Vector3(2, 3, 4) - arg
|
|
|
|
|
|
@pytest.mark.parametrize("arg", [None, "dummy"], ids=lambda x: x[0])
|
|
def test_bad_div(arg):
|
|
with pytest.raises(TypeError):
|
|
Vector3(2, 3, 4) / arg
|
|
|
|
|
|
@pytest.mark.parametrize(
|
|
"arg",
|
|
[0, Vector3(0, 1, 1), Vector3(1, 0, 1), Vector3(1, 1, 0), Vector3(0, 0, 0)],
|
|
ids=lambda x: x[0],
|
|
)
|
|
def test_zero_div(arg):
|
|
with pytest.raises(ZeroDivisionError):
|
|
Vector3(2, 3, 4) / arg
|
|
|
|
|
|
@pytest.mark.parametrize("arg", [None, "dummy"], ids=lambda x: x[0])
|
|
def test_bad_mult(arg):
|
|
with pytest.raises(TypeError):
|
|
Vector3(2, 3, 4) * arg
|
|
|
|
|
|
def test_equal():
|
|
arr = Vector3(1, 2, 3)
|
|
other = Vector3(1, 2, 3)
|
|
assert arr == other
|
|
bad = Vector3(1, 2, 4)
|
|
assert not arr == bad # Force use of __eq__
|
|
|
|
|
|
@pytest.mark.parametrize("arg", [None, 0, "foo", Vector3(1, 2, 4)])
|
|
def test_bad_equal(arg):
|
|
arr = Vector3(1, 2, 3)
|
|
assert arr != arg
|
|
|
|
|
|
@pytest.mark.parametrize(
|
|
"field,type",
|
|
[
|
|
("ZERO", Vector3),
|
|
("ONE", Vector3),
|
|
("INF", Vector3),
|
|
("LEFT", Vector3),
|
|
("RIGHT", Vector3),
|
|
("UP", Vector3),
|
|
("DOWN", Vector3),
|
|
("FORWARD", Vector3),
|
|
("BACK", Vector3),
|
|
("AXIS", type(IntEnum)),
|
|
],
|
|
ids=lambda x: x[0],
|
|
)
|
|
def test_contants(field, type):
|
|
field_val = getattr(Vector3, field)
|
|
assert isinstance(field_val, type)
|