test_lvector4.py 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140
  1. from math import floor, ceil
  2. from panda3d.core import Vec2, Vec3, Vec4, Vec4F, Vec4D
  3. from panda3d import core
  4. import pytest
  5. def test_round():
  6. original_vector = Vec4(2.3, -2.6, 3.5, 1)
  7. rounded_vector = round(original_vector)
  8. assert rounded_vector.x == 2
  9. assert rounded_vector.y == -3
  10. assert rounded_vector.z == 4
  11. assert rounded_vector.w == 1
  12. def test_floor():
  13. original_vector = Vec4(2.3, -2.6, 3.5, 1)
  14. rounded_vector = floor(original_vector)
  15. assert rounded_vector.x == 2
  16. assert rounded_vector.y == -3
  17. assert rounded_vector.z == 3
  18. assert rounded_vector.w == 1
  19. def test_ceil():
  20. original_vector = Vec4(2.3, -2.6, 3.5, 1)
  21. rounded_vector = ceil(original_vector)
  22. assert rounded_vector.x == 3
  23. assert rounded_vector.y == -2
  24. assert rounded_vector.z == 4
  25. assert rounded_vector.w == 1
  26. def test_vec4_creation():
  27. assert Vec4(x=1, y=2, z=1, w=7) == Vec4(1, 2, 1, 7) == Vec4((1, 2, 1, 7))
  28. def test_vec4_getter_setter():
  29. original_vector = Vec4(2, 3, 7, 9)
  30. assert original_vector.x == 2
  31. assert original_vector.y == 3
  32. assert original_vector.z == 7
  33. assert original_vector.w == 9
  34. original_vector.x = 1
  35. original_vector.y = 3
  36. original_vector.z = 5
  37. original_vector.w = -8
  38. assert original_vector == Vec4(1, 3, 5, -8)
  39. original_vector[0] = 3
  40. original_vector[1] = 1
  41. original_vector[2] = 1
  42. original_vector[3] = -2
  43. assert original_vector == Vec4(3, 1, 1, -2)
  44. original_vector.set_x(-8)
  45. original_vector.set_y(6)
  46. original_vector.set_z(10)
  47. original_vector.set_w(30)
  48. assert original_vector.x == -8
  49. assert original_vector.y == 6
  50. assert original_vector.z == 10
  51. assert original_vector.w == 30
  52. def test_vec4_sum():
  53. original_vector = Vec4(2, 3, -2, 1)
  54. assert original_vector + original_vector == Vec4(4, 6, -4, 2)
  55. assert original_vector + 3 == Vec4(5, 6, 1, 4)
  56. def test_vec4_power():
  57. assert Vec4(2, -3, 2, -1) ** 2 == Vec4(4, 9, 4, 1)
  58. def test_vec4_len():
  59. assert len(Vec4(2, -3, 10, 30)) == 4
  60. def test_vec4_swizzle_mask():
  61. original_vector = Vec4(3, 5, 1, 0)
  62. assert original_vector.xy == Vec2(3, 5)
  63. assert original_vector.zxy == Vec3(1, 3, 5)
  64. assert original_vector.zxyw == Vec4(1, 3, 5, 0)
  65. def test_vec4_str():
  66. assert str(Vec4F(2, 3, 1, 9)) == "LVector4f(2, 3, 1, 9)"
  67. assert str(Vec4D(2, 3, 1, 9)) == "LVector4d(2, 3, 1, 9)"
  68. def test_vec4_compare():
  69. assert Vec4(1, 2, 3, 4).compare_to(Vec4(1, 2, 3, 4)) == 0
  70. assert Vec4(1, 0, 0, 0).compare_to(Vec4(1, 0, 0, 0)) == 0
  71. assert Vec4(1, 0, 0, 0).compare_to(Vec4(0, 1, 0, 0)) == 1
  72. assert Vec4(1, 0, 0, 0).compare_to(Vec4(0, 0, 1, 0)) == 1
  73. assert Vec4(1, 0, 0, 0).compare_to(Vec4(0, 0, 0, 1)) == 1
  74. assert Vec4(0, 1, 0, 0).compare_to(Vec4(1, 0, 0, 0)) == -1
  75. assert Vec4(0, 1, 0, 0).compare_to(Vec4(0, 1, 0, 0)) == 0
  76. assert Vec4(0, 1, 0, 0).compare_to(Vec4(0, 0, 1, 0)) == 1
  77. assert Vec4(0, 1, 0, 0).compare_to(Vec4(0, 0, 0, 1)) == 1
  78. assert Vec4(0, 0, 1, 0).compare_to(Vec4(1, 0, 0, 0)) == -1
  79. assert Vec4(0, 0, 1, 0).compare_to(Vec4(0, 1, 0, 0)) == -1
  80. assert Vec4(0, 0, 1, 0).compare_to(Vec4(0, 0, 1, 0)) == 0
  81. assert Vec4(0, 0, 1, 0).compare_to(Vec4(0, 0, 0, 1)) == 1
  82. assert Vec4(0, 0, 0, 1).compare_to(Vec4(1, 0, 0, 0)) == -1
  83. assert Vec4(0, 0, 0, 1).compare_to(Vec4(0, 1, 0, 0)) == -1
  84. assert Vec4(0, 0, 0, 1).compare_to(Vec4(0, 0, 1, 0)) == -1
  85. assert Vec4(0, 0, 0, 1).compare_to(Vec4(0, 0, 0, 1)) == 0
  86. @pytest.mark.parametrize("type", (core.LVecBase4f, core.LVecBase4d, core.LVecBase4i))
  87. def test_vec4_floordiv(type):
  88. with pytest.raises(ZeroDivisionError):
  89. type(1, 2, 3, 4) // 0
  90. for i in range(-11, 11):
  91. for j in range(1, 11):
  92. assert (type(i) // j).x == i // j
  93. assert (type(i) // -j).x == i // -j
  94. v = type(i)
  95. v //= j
  96. assert v.x == i // j
  97. v = type(i)
  98. v //= -j
  99. assert v.x == i // -j