2
0

test_lvector2.py 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164
  1. from math import floor, ceil
  2. import sys
  3. from panda3d.core import Vec2, Vec3, Vec4, Vec2F, Vec2D
  4. from panda3d import core
  5. import pytest
  6. def test_vec2_creation():
  7. assert Vec2(x=1, y=2) == Vec2(1, 2) == Vec2((1, 2))
  8. def test_vec2_getter_setter():
  9. original_vector = Vec2(2, 3)
  10. assert original_vector.x == 2
  11. assert original_vector.y == 3
  12. original_vector.x = 1
  13. original_vector.y = 3
  14. assert original_vector == Vec2(1, 3)
  15. original_vector[0] = 3
  16. original_vector[1] = 1
  17. assert original_vector == Vec2(3, 1)
  18. original_vector.set_x(-8)
  19. original_vector.set_y(6)
  20. assert original_vector.x == -8
  21. assert original_vector.y == 6
  22. def test_vec2_sum():
  23. original_vector = Vec2(2, 3)
  24. assert original_vector + original_vector == Vec2(4, 6)
  25. assert original_vector + 3 == Vec2(5, 6)
  26. def test_vec2_power():
  27. assert Vec2(2, -3) ** 2 == Vec2(4, 9)
  28. def test_vec2_len():
  29. assert len(Vec2(2, -3)) == 2
  30. def test_vec2_swizzle_mask():
  31. original_vector = Vec2(3, 5)
  32. assert original_vector.yx == Vec2(5, 3)
  33. assert original_vector.xy == original_vector
  34. def test_vec2_str():
  35. assert str(Vec2F(2, 3)) == "LVector2f(2, 3)"
  36. assert str(Vec2D(2, 3)) == "LVector2d(2, 3)"
  37. def test_vec2_compare():
  38. assert Vec2(1, 2).compare_to(Vec2(1, 2)) == 0
  39. assert Vec2(1, 0).compare_to(Vec2(1, 0)) == 0
  40. assert Vec2(1, 0).compare_to(Vec2(0, 1)) == 1
  41. assert Vec2(0, 1).compare_to(Vec2(1, 0)) == -1
  42. assert Vec2(0, 1).compare_to(Vec2(0, 1)) == 0
  43. def test_vec2_nan():
  44. nan = float("nan")
  45. inf = float("inf")
  46. assert not Vec2F(0, 0).is_nan()
  47. assert not Vec2F(1, 0).is_nan()
  48. assert Vec2F(nan, 0).is_nan()
  49. assert Vec2F(0, nan).is_nan()
  50. assert Vec2F(nan, nan).is_nan()
  51. assert Vec2F(-nan, 0).is_nan()
  52. assert Vec2F(-nan, nan).is_nan()
  53. assert Vec2F(inf, nan).is_nan()
  54. assert not Vec2F(inf, 0).is_nan()
  55. assert not Vec2F(inf, inf).is_nan()
  56. assert not Vec2F(-inf, 0).is_nan()
  57. assert not Vec2D(0, 0).is_nan()
  58. assert not Vec2D(1, 0).is_nan()
  59. assert Vec2D(nan, 0).is_nan()
  60. assert Vec2D(0, nan).is_nan()
  61. assert Vec2D(nan, nan).is_nan()
  62. assert Vec2D(-nan, 0).is_nan()
  63. assert Vec2D(-nan, nan).is_nan()
  64. assert Vec2D(inf, nan).is_nan()
  65. assert not Vec2D(inf, 0).is_nan()
  66. assert not Vec2D(inf, inf).is_nan()
  67. assert not Vec2D(-inf, 0).is_nan()
  68. def test_vec2_round():
  69. original_vector = Vec2(2.3, -2.6)
  70. rounded_vector = round(original_vector)
  71. assert rounded_vector.x == 2
  72. assert rounded_vector.y == -3
  73. def test_vec2_floor():
  74. original_vector = Vec2(2.3, -2.6)
  75. rounded_vector = floor(original_vector)
  76. assert rounded_vector.x == 2
  77. assert rounded_vector.y == -3
  78. def test_vec2_ceil():
  79. original_vector = Vec2(2.3, -2.6)
  80. rounded_vector = ceil(original_vector)
  81. assert rounded_vector.x == 3
  82. assert rounded_vector.y == -2
  83. def test_vec2_rmul():
  84. assert 2 * Vec2(3, -4) == Vec2(6, -8)
  85. @pytest.mark.xfail(sys.platform == "win32", reason="unknown precision issue")
  86. @pytest.mark.parametrize("type", (core.LVecBase2f, core.LVecBase2d, core.LVecBase2i))
  87. def test_vec2_floordiv(type):
  88. with pytest.raises(ZeroDivisionError):
  89. type(1, 2) // 0
  90. for i in range(-11, 11):
  91. for j in range(1, 11):
  92. assert (type(i) // j).x == i // j
  93. assert (type(i) // -j).x == i // -j
  94. v = type(i)
  95. v //= j
  96. assert v.x == i // j
  97. v = type(i)
  98. v //= -j
  99. assert v.x == i // -j
  100. def test_vec2_repr():
  101. assert repr(Vec2F(0.1, 0.2)) == "LVector2f(0.1, 0.2)"
  102. assert repr(Vec2F(0.3, 0.4)) == "LVector2f(0.3, 0.4)"
  103. assert repr(Vec2F(-0.9999999403953552, 1.00000001)) == "LVector2f(-0.99999994, 1)"
  104. assert repr(Vec2F(0.00000001, 0.0)) == "LVector2f(1e-8, 0)"
  105. assert repr(Vec2D(0.1, 0.2)) == "LVector2d(0.1, 0.2)"
  106. assert repr(Vec2D(0.3, 0.4)) == "LVector2d(0.3, 0.4)"
  107. assert repr(Vec2D(-0.9999999403953552, 1.00000001)) == "LVector2d(-0.9999999403953552, 1.00000001)"
  108. assert repr(Vec2D(0.00000001, 0.0)) == "LVector2d(1e-8, 0)"
  109. def test_vec2_buffer():
  110. v = Vec2(1.5, -10.0)
  111. m = memoryview(v)
  112. assert len(m) == 2
  113. assert m[0] == 1.5
  114. assert m[1] == -10.0