test_ivec2.h 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204
  1. /*
  2. * Copyright (c), Recep Aslantas.
  3. *
  4. * MIT License (MIT), http://opensource.org/licenses/MIT
  5. * Full license can be found in the LICENSE file
  6. */
  7. #include "test_common.h"
  8. TEST_IMPL(GLM_PREFIX, ivec2) {
  9. ivec4 v4 = {2, 3, 5, 7};
  10. ivec3 v3 = {11, 13, 17};
  11. ivec2 v2;
  12. GLM(ivec2)(v4, v2);
  13. ASSERT(v2[0] == 2)
  14. ASSERT(v2[1] == 3)
  15. GLM(ivec2)(v3, v2);
  16. ASSERT(v2[0] == 11)
  17. ASSERT(v2[1] == 13)
  18. TEST_SUCCESS
  19. }
  20. TEST_IMPL(GLM_PREFIX, ivec2_copy) {
  21. ivec2 src = {7, 5};
  22. ivec2 dst = {99, 99};
  23. GLM(ivec2_copy)(src, dst);
  24. ASSERT(dst[0] == 7)
  25. ASSERT(dst[1] == 5)
  26. TEST_SUCCESS
  27. }
  28. TEST_IMPL(GLM_PREFIX, ivec2_zero) {
  29. ivec2 v = {2, 3};
  30. GLM(ivec2_zero)(v);
  31. ASSERT(v[0] == 0)
  32. ASSERT(v[1] == 0)
  33. TEST_SUCCESS
  34. }
  35. TEST_IMPL(GLM_PREFIX, ivec2_one) {
  36. ivec2 v = {-2, 9};
  37. GLM(ivec2_one)(v);
  38. ASSERT(v[0] == 1)
  39. ASSERT(v[1] == 1)
  40. TEST_SUCCESS
  41. }
  42. TEST_IMPL(GLM_PREFIX, ivec2_add) {
  43. ivec2 a = {14, 3};
  44. ivec2 b = {-3, 2};
  45. ivec2 v = {99, 99};
  46. GLM(ivec2_add)(a, b, v);
  47. ASSERT(v[0] == 11)
  48. ASSERT(v[1] == 5)
  49. TEST_SUCCESS
  50. }
  51. TEST_IMPL(GLM_PREFIX, ivec2_adds) {
  52. ivec2 a = {-3, 1};
  53. ivec2 v = {99, 99};
  54. int s = 2;
  55. GLM(ivec2_adds)(a, s, v);
  56. ASSERT(v[0] == -1)
  57. ASSERT(v[1] == 3)
  58. TEST_SUCCESS
  59. }
  60. TEST_IMPL(GLM_PREFIX, ivec2_sub) {
  61. ivec2 a = {-2, 9};
  62. ivec2 b = {3, 2};
  63. ivec2 v = {99, 99};
  64. GLM(ivec2_sub)(a, b, v);
  65. ASSERT(v[0] == -5)
  66. ASSERT(v[1] == 7)
  67. TEST_SUCCESS
  68. }
  69. TEST_IMPL(GLM_PREFIX, ivec2_subs) {
  70. ivec2 a = {5, -2};
  71. ivec2 v = {99, 99};
  72. int s = -3;
  73. GLM(ivec2_subs)(a, s, v);
  74. ASSERT(v[0] == 8)
  75. ASSERT(v[1] == 1)
  76. TEST_SUCCESS
  77. }
  78. TEST_IMPL(GLM_PREFIX, ivec2_mul) {
  79. ivec2 a = {3, 4};
  80. ivec2 b = {-2, 3};
  81. ivec2 v = {99, 99};
  82. GLM(ivec2_mul)(a, b, v);
  83. ASSERT(v[0] == -6)
  84. ASSERT(v[1] == 12)
  85. TEST_SUCCESS
  86. }
  87. TEST_IMPL(GLM_PREFIX, ivec2_scale) {
  88. ivec2 a = {-9, 2};
  89. ivec2 v = {99, 99};
  90. int s = -2;
  91. GLM(ivec2_scale)(a, s, v);
  92. ASSERT(v[0] == 18)
  93. ASSERT(v[1] == -4)
  94. TEST_SUCCESS
  95. }
  96. TEST_IMPL(GLM_PREFIX, ivec2_distance2) {
  97. ivec2 a = {-1, 3};
  98. ivec2 b = {5, 4};
  99. int v;
  100. v = GLM(ivec2_distance2)(a, b);
  101. ASSERT(v == 37)
  102. TEST_SUCCESS
  103. }
  104. TEST_IMPL(GLM_PREFIX, ivec2_distance) {
  105. ivec2 a = {3, 2};
  106. ivec2 b = {-2, 5};
  107. float v;
  108. v = GLM(ivec2_distance)(a, b);
  109. ASSERT(test_eq(v, 5.8309518948f))
  110. TEST_SUCCESS
  111. }
  112. TEST_IMPL(GLM_PREFIX, ivec2_maxv) {
  113. ivec2 a = {9, -20};
  114. ivec2 b = {8, -1};
  115. ivec2 v = {99, 99};
  116. GLM(ivec2_maxv)(a, b, v);
  117. ASSERT(v[0] == 9)
  118. ASSERT(v[1] == -1)
  119. TEST_SUCCESS
  120. }
  121. TEST_IMPL(GLM_PREFIX, ivec2_minv) {
  122. ivec2 a = {16, 0};
  123. ivec2 b = {-15, 10};
  124. ivec2 v = {99, 99};
  125. GLM(ivec2_minv)(a, b, v);
  126. ASSERT(v[0] == -15)
  127. ASSERT(v[1] == 0)
  128. TEST_SUCCESS
  129. }
  130. TEST_IMPL(GLM_PREFIX, ivec2_clamp) {
  131. ivec2 v = {3, -1};
  132. GLM(ivec2_clamp)(v, -2, 4);
  133. ASSERT(v[0] == 3)
  134. ASSERT(v[1] == -1)
  135. v[0] = -15;
  136. v[1] = 4;
  137. GLM(ivec2_clamp)(v, -9, 3);
  138. ASSERT(v[0] == -9)
  139. ASSERT(v[1] == 3)
  140. TEST_SUCCESS
  141. }
  142. TEST_IMPL(GLM_PREFIX, ivec2_abs) {
  143. ivec2 v1 = {2, -3}, v2 = {-12, -31};
  144. ivec2 v3, v4;
  145. GLM(ivec2_abs)(v1, v3);
  146. GLM(ivec2_abs)(v2, v4);
  147. ASSERT(v3[0] == 2)
  148. ASSERT(v3[1] == 3)
  149. ASSERT(v4[0] == 12)
  150. ASSERT(v4[1] == 31)
  151. TEST_SUCCESS
  152. }