test_lvector2.py 2.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990
  1. from math import floor, ceil
  2. import sys
  3. from panda3d.core import Vec2, Vec3, Vec4, Vec2F, Vec2D
  4. import pytest
  5. reason = '''Rounding in Python 2.7 expects to return a float value, since it returns a Vector it
  6. does not work. When Python 2.7 gets deprecated, remove this check.'''
  7. @pytest.mark.skipif(sys.version_info < (3, 5), reason=reason)
  8. def test_round():
  9. original_vector = Vec2(2.3, -2.6)
  10. rounded_vector = round(original_vector)
  11. assert rounded_vector.x == 2
  12. assert rounded_vector.y == -3
  13. @pytest.mark.skipif(sys.version_info < (3, 5), reason=reason)
  14. def test_floor():
  15. original_vector = Vec2(2.3, -2.6)
  16. rounded_vector = floor(original_vector)
  17. assert rounded_vector.x == 2
  18. assert rounded_vector.y == -3
  19. @pytest.mark.skipif(sys.version_info < (3, 5), reason=reason)
  20. def test_ceil():
  21. original_vector = Vec2(2.3, -2.6)
  22. rounded_vector = ceil(original_vector)
  23. assert rounded_vector.x == 3
  24. assert rounded_vector.y == -2
  25. def test_vec2_creation():
  26. assert Vec2(x=1, y=2) == Vec2(1, 2) == Vec2((1, 2))
  27. def test_vec2_getter_setter():
  28. original_vector = Vec2(2, 3)
  29. assert original_vector.x == 2
  30. assert original_vector.y == 3
  31. original_vector.x = 1
  32. original_vector.y = 3
  33. assert original_vector == Vec2(1, 3)
  34. original_vector[0] = 3
  35. original_vector[1] = 1
  36. assert original_vector == Vec2(3, 1)
  37. original_vector.set_x(-8)
  38. original_vector.set_y(6)
  39. assert original_vector.x == -8
  40. assert original_vector.y == 6
  41. def test_vec2_sum():
  42. original_vector = Vec2(2, 3)
  43. assert original_vector + original_vector == Vec2(4, 6)
  44. assert original_vector + 3 == Vec2(5, 6)
  45. def test_vec2_power():
  46. assert Vec2(2, -3) ** 2 == Vec2(4, 9)
  47. def test_vec2_len():
  48. assert len(Vec2(2, -3)) == 2
  49. def test_vec2_swizzle_mask():
  50. original_vector = Vec2(3, 5)
  51. assert original_vector.yx == Vec2(5, 3)
  52. assert original_vector.xy == original_vector
  53. def test_vec2_str():
  54. assert str(Vec2F(2, 3)) == "LVector2f(2, 3)"
  55. assert str(Vec2D(2, 3)) == "LVector2d(2, 3)"