gdnative_python/tests/bindings/test_vector2.py

257 lines
6.2 KiB
Python
Raw Permalink Normal View History

import pytest
2023-06-02 11:13:10 +02:00
from pandemonium import Vector2
def test_base():
v = Vector2()
assert type(v) == Vector2
v2 = Vector2(1, -2)
assert type(v) == Vector2
assert v2 == Vector2(1, -2)
assert v != v2
def test_repr():
v = Vector2(1, 2)
assert repr(v) == "<Vector2(x=1.0, y=2.0)>"
def test_instantiate():
# Can build it with int or float or nothing
msg_tmpl = "%s vs (expected) %s (args=%s)"
for args, expected_x, expected_y in (
[(), 0, 0],
[(0.5, 0.5), 0.5, 0.5],
[(1, 2), 1, 2],
[(1,), 1, 0],
):
v = Vector2(*args)
assert v.x == expected_x, msg_tmpl % (v.x, expected_x, args)
assert v.y == expected_y, msg_tmpl % (v.y, expected_y, args)
assert v.width == expected_x, msg_tmpl % (v.width, expected_y, args)
assert v.height == expected_y, msg_tmpl % (v.height, expected_x, args)
with pytest.raises(TypeError):
Vector2("a", 2)
with pytest.raises(TypeError):
Vector2("a", 2)
with pytest.raises(TypeError):
Vector2(1, "b")
with pytest.raises(TypeError):
Vector2(None, 2)
@pytest.mark.parametrize(
"field,ret_type,params",
[
["abs", Vector2, ()],
["angle", float, ()],
["angle_to", float, (Vector2(),)],
["angle_to_point", float, (Vector2(),)],
["clamped", Vector2, (0.5,)],
["cubic_interpolate", Vector2, (Vector2(), Vector2(), Vector2(), 0.5)],
["distance_squared_to", float, (Vector2(),)],
["distance_to", float, (Vector2(),)],
["dot", float, (Vector2(),)],
["floor", Vector2, ()],
["aspect", float, ()],
["length", float, ()],
["length_squared", float, ()],
["linear_interpolate", Vector2, (Vector2(), 0.5)],
["normalized", Vector2, ()],
["reflect", Vector2, (Vector2(),)],
["rotated", Vector2, (0.5,)],
["slide", Vector2, (Vector2(),)],
["snapped", Vector2, (Vector2(),)],
["tangent", Vector2, ()],
],
ids=lambda x: x[0],
)
def test_methods(field, ret_type, params):
v = Vector2()
# Don't test methods' validity but bindings one
assert hasattr(v, field)
method = getattr(v, field)
assert callable(method)
ret = method(*params)
assert type(ret) == ret_type
@pytest.mark.parametrize(
"field,ret_type",
[("height", float), ("width", float), ("x", float), ("y", float)],
ids=lambda x: x[0],
)
def test_properties(field, ret_type):
v = Vector2()
assert hasattr(v, field)
field_val = getattr(v, field)
assert type(field_val) == ret_type
for val in (0, 10, 10.0, 42.5):
setattr(v, field, val)
field_val = getattr(v, field)
assert field_val == val
@pytest.mark.parametrize(
"field,bad_value",
[
("height", "NaN"),
("width", "NaN"),
("x", "NaN"),
("y", "NaN"),
("height", None),
("width", None),
("x", None),
("y", None),
],
ids=lambda x: x[0],
)
def test_bad_properties(field, bad_value):
v = Vector2()
with pytest.raises(TypeError):
setattr(v, field, bad_value)
def test_unary():
v = Vector2(1, 2)
v2 = -v
assert v2.x == -1
assert v2.y == -2
v3 = +v
assert v3.x == 1
assert v3.y == 2
v = Vector2(1.5, 2.5)
v2 = -v
assert v2.x == -1.5
assert v2.y == -2.5
v3 = +v
assert v3.x == 1.5
assert v3.y == 2.5
@pytest.mark.parametrize(
"param,result",
[
(Vector2(0, 0), Vector2(2, 3)),
(Vector2(3, 2), Vector2(5, 5)),
(Vector2(-1, -4), Vector2(1, -1)),
],
ids=lambda x: x[0],
)
def test_add(param, result):
calc = Vector2(2, 3) + param
assert calc == result
@pytest.mark.parametrize(
"param,result",
[
(Vector2(0, 0), Vector2(2, 3)),
(Vector2(3, 2), Vector2(-1, 1)),
(Vector2(-1, -1), Vector2(3, 4)),
],
ids=lambda x: x[0],
)
def test_sub(param, result):
calc = Vector2(2, 3) - 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):
Vector2(2, 3) + arg
@pytest.mark.parametrize("arg", [None, 1, "dummy"], ids=lambda x: x[0])
def test_bad_sub(arg):
with pytest.raises(TypeError):
Vector2(2, 3) - arg
@pytest.mark.parametrize("arg", [None, "dummy"], ids=lambda x: x[0])
def test_bad_div(arg):
with pytest.raises(TypeError):
Vector2(2, 3) / arg
@pytest.mark.parametrize(
"arg", [0, Vector2(0, 1), Vector2(1, 0), Vector2(0, 0)], ids=lambda x: x[0]
)
def test_zero_div(arg):
with pytest.raises(ZeroDivisionError):
Vector2(2, 3) / arg
@pytest.mark.parametrize("arg", [None, "dummy"], ids=lambda x: x[0])
def test_bad_mult(arg):
with pytest.raises(TypeError):
Vector2(2, 3) * arg
@pytest.mark.parametrize(
"param,result",
[
(0, Vector2(0, 0)),
(1, Vector2(2, 3)),
(2.5, Vector2(5, 7.5)),
(Vector2(1, 1), Vector2(2, 3)),
(Vector2(2, 3), Vector2(4, 9)),
],
ids=lambda x: x[0],
)
def test_mult(param, result):
calc = Vector2(2, 3) * param
assert calc == result
@pytest.mark.parametrize(
"param,result",
[
(1, Vector2(2, 3)),
(0.5, Vector2(4, 6)),
(2, Vector2(1, 1.5)),
(Vector2(1, 1), Vector2(2, 3)),
(Vector2(2, 3), Vector2(1, 1)),
],
ids=lambda x: x[0],
)
def test_div(param, result):
calc = Vector2(2, 3) / param
assert calc == result
def test_equal():
arr = Vector2(1, 2)
other = Vector2(1, 2)
assert arr == other
bad = Vector2(1, 3)
assert not arr == bad # Force use of __eq__
@pytest.mark.parametrize("arg", [None, 0, "foo", Vector2(1, 3)])
def test_bad_equal(arg):
arr = Vector2(1, 2)
assert arr != arg
@pytest.mark.parametrize(
"field,type",
[
("AXIS_X", int),
("AXIS_Y", int),
("ZERO", Vector2),
("ONE", Vector2),
("INF", Vector2),
("LEFT", Vector2),
("RIGHT", Vector2),
("UP", Vector2),
("DOWN", Vector2),
],
ids=lambda x: x[0],
)
def test_contants(field, type):
field_val = getattr(Vector2, field)
assert isinstance(field_val, type)