test_lvector3.py 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142
  1. from math import floor, ceil
  2. import sys
  3. from panda3d.core import Vec2, Vec3, Vec3F, Vec3D
  4. from panda3d import core
  5. import pytest
  6. def test_vec3_creation():
  7. assert Vec3(x=1, y=2, z=1) == Vec3(1, 2, 1) == Vec3((1, 2, 1))
  8. def test_vec3_getter_setter():
  9. original_vector = Vec3(2, 3, 7)
  10. assert original_vector.x == 2
  11. assert original_vector.y == 3
  12. assert original_vector.z == 7
  13. original_vector.x = 1
  14. original_vector.y = 3
  15. original_vector.z = 5
  16. assert original_vector == Vec3(1, 3, 5)
  17. original_vector[0] = 3
  18. original_vector[1] = 1
  19. original_vector[2] = 1
  20. assert original_vector == Vec3(3, 1, 1)
  21. original_vector.set_x(-8)
  22. original_vector.set_y(6)
  23. original_vector.set_z(10)
  24. assert original_vector.x == -8
  25. assert original_vector.y == 6
  26. assert original_vector.z == 10
  27. def test_vec3_sum():
  28. original_vector = Vec3(2, 3, -2)
  29. assert original_vector + original_vector == Vec3(4, 6, -4)
  30. assert original_vector + 3 == Vec3(5, 6, 1)
  31. def test_vec3_power():
  32. assert Vec3(2, -3, 2) ** 2 == Vec3(4, 9, 4)
  33. def test_vec3_len():
  34. assert len(Vec3(2, -3, 10)) == 3
  35. def test_vec3_swizzle_mask():
  36. original_vector = Vec3(3, 5, 1)
  37. assert original_vector.xy == Vec2(3, 5)
  38. assert original_vector.zxy == Vec3(1, 3, 5)
  39. def test_vec3_str():
  40. assert str(Vec3F(2, 3, 1)) == "LVector3f(2, 3, 1)"
  41. assert str(Vec3D(2, 3, 1)) == "LVector3d(2, 3, 1)"
  42. def test_vec3_compare():
  43. assert Vec3(1, 2, 3).compare_to(Vec3(1, 2, 3)) == 0
  44. assert Vec3(1, 0, 0).compare_to(Vec3(1, 0, 0)) == 0
  45. assert Vec3(1, 0, 0).compare_to(Vec3(0, 1, 0)) == 1
  46. assert Vec3(1, 0, 0).compare_to(Vec3(0, 0, 1)) == 1
  47. assert Vec3(0, 1, 0).compare_to(Vec3(1, 0, 0)) == -1
  48. assert Vec3(0, 1, 0).compare_to(Vec3(0, 1, 0)) == 0
  49. assert Vec3(0, 1, 0).compare_to(Vec3(0, 0, 1)) == 1
  50. assert Vec3(0, 0, 1).compare_to(Vec3(1, 0, 0)) == -1
  51. assert Vec3(0, 0, 1).compare_to(Vec3(0, 1, 0)) == -1
  52. assert Vec3(0, 0, 1).compare_to(Vec3(0, 0, 1)) == 0
  53. @pytest.mark.skipif(sys.version_info < (3, 0), reason="requires Python 3")
  54. def test_vec3_round():
  55. original_vector = Vec3(2.3, -2.6, 3.5)
  56. rounded_vector = round(original_vector)
  57. assert rounded_vector.x == 2
  58. assert rounded_vector.y == -3
  59. assert rounded_vector.z == 4
  60. @pytest.mark.skipif(sys.version_info < (3, 0), reason="requires Python 3")
  61. def test_vec3_floor():
  62. original_vector = Vec3(2.3, -2.6, 3.5)
  63. rounded_vector = floor(original_vector)
  64. assert rounded_vector.x == 2
  65. assert rounded_vector.y == -3
  66. assert rounded_vector.z == 3
  67. @pytest.mark.skipif(sys.version_info < (3, 0), reason="requires Python 3")
  68. def test_vec3_ceil():
  69. original_vector = Vec3(2.3, -2.6, 3.5)
  70. rounded_vector = ceil(original_vector)
  71. assert rounded_vector.x == 3
  72. assert rounded_vector.y == -2
  73. assert rounded_vector.z == 4
  74. @pytest.mark.xfail(sys.platform == "win32", reason="unknown precision issue")
  75. @pytest.mark.parametrize("type", (core.LVecBase3f, core.LVecBase3d, core.LVecBase3i))
  76. def test_vec3_floordiv(type):
  77. with pytest.raises(ZeroDivisionError):
  78. type(1, 2, 3) // 0
  79. for i in range(-11, 11):
  80. for j in range(1, 11):
  81. assert (type(i) // j).x == i // j
  82. assert (type(i) // -j).x == i // -j
  83. v = type(i)
  84. v //= j
  85. assert v.x == i // j
  86. v = type(i)
  87. v //= -j
  88. assert v.x == i // -j
  89. def test_vec3_repr():
  90. assert repr(Vec3F(0.1, 0.2, 0.3)) == "LVector3f(0.1, 0.2, 0.3)"
  91. assert repr(Vec3F(-0.9999999403953552, 1.00000001, 1)) == "LVector3f(-0.99999994, 1, 1)"
  92. assert repr(Vec3F(-9.451235e29, 9.451234e-19, 1e-11)) == "LVector3f(-9.451235e29, 9.451234e-19, 1e-11)"
  93. assert repr(Vec3F(0.001, 0.0001, 0.00001)) == "LVector3f(0.001, 0.0001, 0.00001)"
  94. assert repr(Vec3F(-0.001, -0.0001, -0.00001)) == "LVector3f(-0.001, -0.0001, -0.00001)"
  95. assert repr(Vec3D(0.1, 0.2, 0.3)) == "LVector3d(0.1, 0.2, 0.3)"
  96. assert repr(Vec3D(-0.9999999403953552, 1.00000001, 1)) == "LVector3d(-0.9999999403953552, 1.00000001, 1)"
  97. assert repr(Vec3D(-9.451235e29, 9.451234e-19, 1e-11)) == "LVector3d(-9.451235e29, 9.451234e-19, 1e-11)"
  98. assert repr(Vec3D(0.001, 0.0001, 0.00001)) == "LVector3d(0.001, 0.0001, 0.00001)"
  99. assert repr(Vec3D(-0.001, -0.0001, -0.00001)) == "LVector3d(-0.001, -0.0001, -0.00001)"