test_lvector2.py 2.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192
  1. from panda3d.core import Vec2, Vec3, Vec4, Vec2F, Vec2D
  2. def test_vec2_creation():
  3. assert Vec2(x=1, y=2) == Vec2(1, 2) == Vec2((1, 2))
  4. def test_vec2_getter_setter():
  5. original_vector = Vec2(2, 3)
  6. assert original_vector.x == 2
  7. assert original_vector.y == 3
  8. original_vector.x = 1
  9. original_vector.y = 3
  10. assert original_vector == Vec2(1, 3)
  11. original_vector[0] = 3
  12. original_vector[1] = 1
  13. assert original_vector == Vec2(3, 1)
  14. original_vector.set_x(-8)
  15. original_vector.set_y(6)
  16. assert original_vector.x == -8
  17. assert original_vector.y == 6
  18. def test_vec2_sum():
  19. original_vector = Vec2(2, 3)
  20. assert original_vector + original_vector == Vec2(4, 6)
  21. assert original_vector + 3 == Vec2(5, 6)
  22. def test_vec2_power():
  23. assert Vec2(2, -3) ** 2 == Vec2(4, 9)
  24. def test_vec2_len():
  25. assert len(Vec2(2, -3)) == 2
  26. def test_vec2_swizzle_mask():
  27. original_vector = Vec2(3, 5)
  28. assert original_vector.yx == Vec2(5, 3)
  29. assert original_vector.xy == original_vector
  30. def test_vec2_str():
  31. assert str(Vec2F(2, 3)) == "LVector2f(2, 3)"
  32. assert str(Vec2D(2, 3)) == "LVector2d(2, 3)"
  33. def test_vec2_compare():
  34. assert Vec2(1, 2).compare_to(Vec2(1, 2)) == 0
  35. assert Vec2(1, 0).compare_to(Vec2(1, 0)) == 0
  36. assert Vec2(1, 0).compare_to(Vec2(0, 1)) == 1
  37. assert Vec2(0, 1).compare_to(Vec2(1, 0)) == -1
  38. assert Vec2(0, 1).compare_to(Vec2(0, 1)) == 0
  39. def test_vec2_nan():
  40. nan = float("nan")
  41. inf = float("inf")
  42. assert not Vec2F(0, 0).is_nan()
  43. assert not Vec2F(1, 0).is_nan()
  44. assert Vec2F(nan, 0).is_nan()
  45. assert Vec2F(0, nan).is_nan()
  46. assert Vec2F(nan, nan).is_nan()
  47. assert Vec2F(-nan, 0).is_nan()
  48. assert Vec2F(-nan, nan).is_nan()
  49. assert Vec2F(inf, nan).is_nan()
  50. assert not Vec2F(inf, 0).is_nan()
  51. assert not Vec2F(inf, inf).is_nan()
  52. assert not Vec2F(-inf, 0).is_nan()
  53. assert not Vec2D(0, 0).is_nan()
  54. assert not Vec2D(1, 0).is_nan()
  55. assert Vec2D(nan, 0).is_nan()
  56. assert Vec2D(0, nan).is_nan()
  57. assert Vec2D(nan, nan).is_nan()
  58. assert Vec2D(-nan, 0).is_nan()
  59. assert Vec2D(-nan, nan).is_nan()
  60. assert Vec2D(inf, nan).is_nan()
  61. assert not Vec2D(inf, 0).is_nan()
  62. assert not Vec2D(inf, inf).is_nan()
  63. assert not Vec2D(-inf, 0).is_nan()