test_lvector3.py 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104
  1. from math import floor, ceil
  2. from panda3d.core import Vec2, Vec3, Vec3F, Vec3D
  3. import pytest
  4. def test_round():
  5. original_vector = Vec3(2.3, -2.6, 3.5)
  6. rounded_vector = round(original_vector)
  7. assert rounded_vector.x == 2
  8. assert rounded_vector.y == -3
  9. assert rounded_vector.z == 4
  10. def test_floor():
  11. original_vector = Vec3(2.3, -2.6, 3.5)
  12. rounded_vector = floor(original_vector)
  13. assert rounded_vector.x == 2
  14. assert rounded_vector.y == -3
  15. assert rounded_vector.z == 3
  16. def test_ceil():
  17. original_vector = Vec3(2.3, -2.6, 3.5)
  18. rounded_vector = ceil(original_vector)
  19. assert rounded_vector.x == 3
  20. assert rounded_vector.y == -2
  21. assert rounded_vector.z == 4
  22. def test_vec3_creation():
  23. assert Vec3(x=1, y=2, z=1) == Vec3(1, 2, 1) == Vec3((1, 2, 1))
  24. def test_vec3_getter_setter():
  25. original_vector = Vec3(2, 3, 7)
  26. assert original_vector.x == 2
  27. assert original_vector.y == 3
  28. assert original_vector.z == 7
  29. original_vector.x = 1
  30. original_vector.y = 3
  31. original_vector.z = 5
  32. assert original_vector == Vec3(1, 3, 5)
  33. original_vector[0] = 3
  34. original_vector[1] = 1
  35. original_vector[2] = 1
  36. assert original_vector == Vec3(3, 1, 1)
  37. original_vector.set_x(-8)
  38. original_vector.set_y(6)
  39. original_vector.set_z(10)
  40. assert original_vector.x == -8
  41. assert original_vector.y == 6
  42. assert original_vector.z == 10
  43. def test_vec3_sum():
  44. original_vector = Vec3(2, 3, -2)
  45. assert original_vector + original_vector == Vec3(4, 6, -4)
  46. assert original_vector + 3 == Vec3(5, 6, 1)
  47. def test_vec3_power():
  48. assert Vec3(2, -3, 2) ** 2 == Vec3(4, 9, 4)
  49. def test_vec3_len():
  50. assert len(Vec3(2, -3, 10)) == 3
  51. def test_vec3_swizzle_mask():
  52. original_vector = Vec3(3, 5, 1)
  53. assert original_vector.xy == Vec2(3, 5)
  54. assert original_vector.zxy == Vec3(1, 3, 5)
  55. def test_vec3_str():
  56. assert str(Vec3F(2, 3, 1)) == "LVector3f(2, 3, 1)"
  57. assert str(Vec3D(2, 3, 1)) == "LVector3d(2, 3, 1)"
  58. def test_vec3_compare():
  59. assert Vec3(1, 2, 3).compare_to(Vec3(1, 2, 3)) == 0
  60. assert Vec3(1, 0, 0).compare_to(Vec3(1, 0, 0)) == 0
  61. assert Vec3(1, 0, 0).compare_to(Vec3(0, 1, 0)) == 1
  62. assert Vec3(1, 0, 0).compare_to(Vec3(0, 0, 1)) == 1
  63. assert Vec3(0, 1, 0).compare_to(Vec3(1, 0, 0)) == -1
  64. assert Vec3(0, 1, 0).compare_to(Vec3(0, 1, 0)) == 0
  65. assert Vec3(0, 1, 0).compare_to(Vec3(0, 0, 1)) == 1
  66. assert Vec3(0, 0, 1).compare_to(Vec3(1, 0, 0)) == -1
  67. assert Vec3(0, 0, 1).compare_to(Vec3(0, 1, 0)) == -1
  68. assert Vec3(0, 0, 1).compare_to(Vec3(0, 0, 1)) == 0