2
0

test_lvector4.py 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163
  1. from math import floor, ceil
  2. import sys
  3. from panda3d.core import Vec2, Vec3, Vec4, Vec4F, Vec4D
  4. from panda3d import core
  5. import pytest
  6. def test_vec4_creation():
  7. assert Vec4(x=1, y=2, z=1, w=7) == Vec4(1, 2, 1, 7) == Vec4((1, 2, 1, 7))
  8. def test_vec4_getter_setter():
  9. original_vector = Vec4(2, 3, 7, 9)
  10. assert original_vector.x == 2
  11. assert original_vector.y == 3
  12. assert original_vector.z == 7
  13. assert original_vector.w == 9
  14. original_vector.x = 1
  15. original_vector.y = 3
  16. original_vector.z = 5
  17. original_vector.w = -8
  18. assert original_vector == Vec4(1, 3, 5, -8)
  19. original_vector[0] = 3
  20. original_vector[1] = 1
  21. original_vector[2] = 1
  22. original_vector[3] = -2
  23. assert original_vector == Vec4(3, 1, 1, -2)
  24. original_vector.set_x(-8)
  25. original_vector.set_y(6)
  26. original_vector.set_z(10)
  27. original_vector.set_w(30)
  28. assert original_vector.x == -8
  29. assert original_vector.y == 6
  30. assert original_vector.z == 10
  31. assert original_vector.w == 30
  32. def test_vec4_sum():
  33. original_vector = Vec4(2, 3, -2, 1)
  34. assert original_vector + original_vector == Vec4(4, 6, -4, 2)
  35. assert original_vector + 3 == Vec4(5, 6, 1, 4)
  36. def test_vec4_power():
  37. assert Vec4(2, -3, 2, -1) ** 2 == Vec4(4, 9, 4, 1)
  38. def test_vec4_len():
  39. assert len(Vec4(2, -3, 10, 30)) == 4
  40. def test_vec4_swizzle_mask():
  41. original_vector = Vec4(3, 5, 1, 0)
  42. assert original_vector.xy == Vec2(3, 5)
  43. assert original_vector.zxy == Vec3(1, 3, 5)
  44. assert original_vector.zxyw == Vec4(1, 3, 5, 0)
  45. def test_vec4_str():
  46. assert str(Vec4F(2, 3, 1, 9)) == "LVector4f(2, 3, 1, 9)"
  47. assert str(Vec4D(2, 3, 1, 9)) == "LVector4d(2, 3, 1, 9)"
  48. def test_vec4_compare():
  49. assert Vec4(1, 2, 3, 4).compare_to(Vec4(1, 2, 3, 4)) == 0
  50. assert Vec4(1, 0, 0, 0).compare_to(Vec4(1, 0, 0, 0)) == 0
  51. assert Vec4(1, 0, 0, 0).compare_to(Vec4(0, 1, 0, 0)) == 1
  52. assert Vec4(1, 0, 0, 0).compare_to(Vec4(0, 0, 1, 0)) == 1
  53. assert Vec4(1, 0, 0, 0).compare_to(Vec4(0, 0, 0, 1)) == 1
  54. assert Vec4(0, 1, 0, 0).compare_to(Vec4(1, 0, 0, 0)) == -1
  55. assert Vec4(0, 1, 0, 0).compare_to(Vec4(0, 1, 0, 0)) == 0
  56. assert Vec4(0, 1, 0, 0).compare_to(Vec4(0, 0, 1, 0)) == 1
  57. assert Vec4(0, 1, 0, 0).compare_to(Vec4(0, 0, 0, 1)) == 1
  58. assert Vec4(0, 0, 1, 0).compare_to(Vec4(1, 0, 0, 0)) == -1
  59. assert Vec4(0, 0, 1, 0).compare_to(Vec4(0, 1, 0, 0)) == -1
  60. assert Vec4(0, 0, 1, 0).compare_to(Vec4(0, 0, 1, 0)) == 0
  61. assert Vec4(0, 0, 1, 0).compare_to(Vec4(0, 0, 0, 1)) == 1
  62. assert Vec4(0, 0, 0, 1).compare_to(Vec4(1, 0, 0, 0)) == -1
  63. assert Vec4(0, 0, 0, 1).compare_to(Vec4(0, 1, 0, 0)) == -1
  64. assert Vec4(0, 0, 0, 1).compare_to(Vec4(0, 0, 1, 0)) == -1
  65. assert Vec4(0, 0, 0, 1).compare_to(Vec4(0, 0, 0, 1)) == 0
  66. def test_vec4_round():
  67. original_vector = Vec4(2.3, -2.6, 3.5, 1)
  68. rounded_vector = round(original_vector)
  69. assert rounded_vector.x == 2
  70. assert rounded_vector.y == -3
  71. assert rounded_vector.z == 4
  72. assert rounded_vector.w == 1
  73. def test_vec4_floor():
  74. original_vector = Vec4(2.3, -2.6, 3.5, 1)
  75. rounded_vector = floor(original_vector)
  76. assert rounded_vector.x == 2
  77. assert rounded_vector.y == -3
  78. assert rounded_vector.z == 3
  79. assert rounded_vector.w == 1
  80. def test_vec4_ceil():
  81. original_vector = Vec4(2.3, -2.6, 3.5, 1)
  82. rounded_vector = ceil(original_vector)
  83. assert rounded_vector.x == 3
  84. assert rounded_vector.y == -2
  85. assert rounded_vector.z == 4
  86. assert rounded_vector.w == 1
  87. def test_vec4_rmul():
  88. assert 2 * Vec4(0, 3, -4, 0.5) == Vec4(0, 6, -8, 1)
  89. @pytest.mark.xfail(sys.platform == "win32", reason="unknown precision issue")
  90. @pytest.mark.parametrize("type", (core.LVecBase4f, core.LVecBase4d, core.LVecBase4i))
  91. def test_vec4_floordiv(type):
  92. with pytest.raises(ZeroDivisionError):
  93. type(1, 2, 3, 4) // 0
  94. for i in range(-11, 11):
  95. for j in range(1, 11):
  96. assert (type(i) // j).x == i // j
  97. assert (type(i) // -j).x == i // -j
  98. v = type(i)
  99. v //= j
  100. assert v.x == i // j
  101. v = type(i)
  102. v //= -j
  103. assert v.x == i // -j
  104. def test_vec4_repr():
  105. assert repr(Vec4F(0.1, 0.2, 0.3, 0.4)) == "LVector4f(0.1, 0.2, 0.3, 0.4)"
  106. assert repr(Vec4F(-0.9999999403953552, 1.000001, 1e-8, 0.0)) == "LVector4f(-0.99999994, 1.000001, 1e-8, 0)"
  107. assert repr(Vec4D(0.1, 0.2, 0.3, 0.4)) == "LVector4d(0.1, 0.2, 0.3, 0.4)"
  108. assert repr(Vec4D(-0.9999999403953552, 1.00000001, 1e-8, 0.0)) == "LVector4d(-0.9999999403953552, 1.00000001, 1e-8, 0)"
  109. def test_vec4_buffer():
  110. v = Vec4(0, 0.5, 2.0, -4.0)
  111. m = memoryview(v)
  112. assert len(m) == 4
  113. assert m[0] == 0
  114. assert m[1] == 0.5
  115. assert m[2] == 2.0
  116. assert m[3] == -4.0