test_lvector4.py 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687
  1. from panda3d.core import Vec2, Vec3, Vec4, Vec4F, Vec4D
  2. def test_vec4_creation():
  3. assert Vec4(x=1, y=2, z=1, w=7) == Vec4(1, 2, 1, 7) == Vec4((1, 2, 1, 7))
  4. def test_vec4_getter_setter():
  5. original_vector = Vec4(2, 3, 7, 9)
  6. assert original_vector.x == 2
  7. assert original_vector.y == 3
  8. assert original_vector.z == 7
  9. assert original_vector.w == 9
  10. original_vector.x = 1
  11. original_vector.y = 3
  12. original_vector.z = 5
  13. original_vector.w = -8
  14. assert original_vector == Vec4(1, 3, 5, -8)
  15. original_vector[0] = 3
  16. original_vector[1] = 1
  17. original_vector[2] = 1
  18. original_vector[3] = -2
  19. assert original_vector == Vec4(3, 1, 1, -2)
  20. original_vector.set_x(-8)
  21. original_vector.set_y(6)
  22. original_vector.set_z(10)
  23. original_vector.set_w(30)
  24. assert original_vector.x == -8
  25. assert original_vector.y == 6
  26. assert original_vector.z == 10
  27. assert original_vector.w == 30
  28. def test_vec4_sum():
  29. original_vector = Vec4(2, 3, -2, 1)
  30. assert original_vector + original_vector == Vec4(4, 6, -4, 2)
  31. assert original_vector + 3 == Vec4(5, 6, 1, 4)
  32. def test_vec4_power():
  33. assert Vec4(2, -3, 2, -1) ** 2 == Vec4(4, 9, 4, 1)
  34. def test_vec4_len():
  35. assert len(Vec4(2, -3, 10, 30)) == 4
  36. def test_vec4_swizzle_mask():
  37. original_vector = Vec4(3, 5, 1, 0)
  38. assert original_vector.xy == Vec2(3, 5)
  39. assert original_vector.zxy == Vec3(1, 3, 5)
  40. assert original_vector.zxyw == Vec4(1, 3, 5, 0)
  41. def test_vec4_str():
  42. assert str(Vec4F(2, 3, 1, 9)) == "LVector4f(2, 3, 1, 9)"
  43. assert str(Vec4D(2, 3, 1, 9)) == "LVector4d(2, 3, 1, 9)"
  44. def test_vec4_compare():
  45. assert Vec4(1, 2, 3, 4).compare_to(Vec4(1, 2, 3, 4)) == 0
  46. assert Vec4(1, 0, 0, 0).compare_to(Vec4(1, 0, 0, 0)) == 0
  47. assert Vec4(1, 0, 0, 0).compare_to(Vec4(0, 1, 0, 0)) == 1
  48. assert Vec4(1, 0, 0, 0).compare_to(Vec4(0, 0, 1, 0)) == 1
  49. assert Vec4(1, 0, 0, 0).compare_to(Vec4(0, 0, 0, 1)) == 1
  50. assert Vec4(0, 1, 0, 0).compare_to(Vec4(1, 0, 0, 0)) == -1
  51. assert Vec4(0, 1, 0, 0).compare_to(Vec4(0, 1, 0, 0)) == 0
  52. assert Vec4(0, 1, 0, 0).compare_to(Vec4(0, 0, 1, 0)) == 1
  53. assert Vec4(0, 1, 0, 0).compare_to(Vec4(0, 0, 0, 1)) == 1
  54. assert Vec4(0, 0, 1, 0).compare_to(Vec4(1, 0, 0, 0)) == -1
  55. assert Vec4(0, 0, 1, 0).compare_to(Vec4(0, 1, 0, 0)) == -1
  56. assert Vec4(0, 0, 1, 0).compare_to(Vec4(0, 0, 1, 0)) == 0
  57. assert Vec4(0, 0, 1, 0).compare_to(Vec4(0, 0, 0, 1)) == 1
  58. assert Vec4(0, 0, 0, 1).compare_to(Vec4(1, 0, 0, 0)) == -1
  59. assert Vec4(0, 0, 0, 1).compare_to(Vec4(0, 1, 0, 0)) == -1
  60. assert Vec4(0, 0, 0, 1).compare_to(Vec4(0, 0, 1, 0)) == -1
  61. assert Vec4(0, 0, 0, 1).compare_to(Vec4(0, 0, 0, 1)) == 0