test_lvector2.py 1.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091
  1. from math import floor, ceil
  2. from panda3d.core import Vec2, Vec3, Vec4, Vec2F, Vec2D
  3. import pytest
  4. def test_round():
  5. original_vector = Vec2(2.3, -2.6)
  6. rounded_vector = round(original_vector)
  7. assert rounded_vector.x == 2
  8. assert rounded_vector.y == -3
  9. def test_floor():
  10. original_vector = Vec2(2.3, -2.6)
  11. rounded_vector = floor(original_vector)
  12. assert rounded_vector.x == 2
  13. assert rounded_vector.y == -3
  14. def test_ceil():
  15. original_vector = Vec2(2.3, -2.6)
  16. rounded_vector = ceil(original_vector)
  17. assert rounded_vector.x == 3
  18. assert rounded_vector.y == -2
  19. def test_vec2_creation():
  20. assert Vec2(x=1, y=2) == Vec2(1, 2) == Vec2((1, 2))
  21. def test_vec2_getter_setter():
  22. original_vector = Vec2(2, 3)
  23. assert original_vector.x == 2
  24. assert original_vector.y == 3
  25. original_vector.x = 1
  26. original_vector.y = 3
  27. assert original_vector == Vec2(1, 3)
  28. original_vector[0] = 3
  29. original_vector[1] = 1
  30. assert original_vector == Vec2(3, 1)
  31. original_vector.set_x(-8)
  32. original_vector.set_y(6)
  33. assert original_vector.x == -8
  34. assert original_vector.y == 6
  35. def test_vec2_sum():
  36. original_vector = Vec2(2, 3)
  37. assert original_vector + original_vector == Vec2(4, 6)
  38. assert original_vector + 3 == Vec2(5, 6)
  39. def test_vec2_power():
  40. assert Vec2(2, -3) ** 2 == Vec2(4, 9)
  41. def test_vec2_len():
  42. assert len(Vec2(2, -3)) == 2
  43. def test_vec2_swizzle_mask():
  44. original_vector = Vec2(3, 5)
  45. assert original_vector.yx == Vec2(5, 3)
  46. assert original_vector.xy == original_vector
  47. def test_vec2_str():
  48. assert str(Vec2F(2, 3)) == "LVector2f(2, 3)"
  49. assert str(Vec2D(2, 3)) == "LVector2d(2, 3)"
  50. def test_vec2_compare():
  51. assert Vec2(1, 2).compare_to(Vec2(1, 2)) == 0
  52. assert Vec2(1, 0).compare_to(Vec2(1, 0)) == 0
  53. assert Vec2(1, 0).compare_to(Vec2(0, 1)) == 1
  54. assert Vec2(0, 1).compare_to(Vec2(1, 0)) == -1
  55. assert Vec2(0, 1).compare_to(Vec2(0, 1)) == 0