Point2Tests.cs 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356
  1. //using System.Collections.Generic;
  2. //using System.Globalization;
  3. //using Microsoft.Xna.Framework;
  4. //using Xunit;
  5. //namespace MonoGame.Extended.Tests.Primitives
  6. //{
  7. //
  8. // public class Point2Tests
  9. // {
  10. // public IEnumerable<TestCaseData> ConstructorTestCases
  11. // {
  12. // get
  13. // {
  14. // yield return
  15. // new TestCaseData(0, 0).SetName(
  16. // "The zero point has the expected coordinates.");
  17. // yield return
  18. // new TestCaseData(float.MinValue, float.MaxValue).SetName
  19. // (
  20. // "A non-zero point has the expected coordinates.");
  21. // }
  22. // }
  23. // [Fact]
  24. // [TestCaseSource(nameof(ConstructorTestCases))]
  25. // public void Constructor(float x, float y)
  26. // {
  27. // var point = new Point2(x, y);
  28. // Assert.Equal(x, point.X);
  29. // Assert.Equal(y, point.Y);
  30. // }
  31. // public IEnumerable<TestCaseData> CoordinatesTestCases
  32. // {
  33. // get
  34. // {
  35. // yield return
  36. // new TestCaseData(new Point2(), 0, 0).SetName(
  37. // "The zero point has the expected coordinates.");
  38. // yield return
  39. // new TestCaseData(new Point2(float.MinValue, float.MaxValue), float.MinValue, float.MaxValue).SetName
  40. // (
  41. // "A non-zero point has the expected coordinates.");
  42. // }
  43. // }
  44. // [Fact]
  45. // [TestCaseSource(nameof(CoordinatesTestCases))]
  46. // public void Coordinates(Point2 point, float expectedX, float expecetedY)
  47. // {
  48. // Assert.Equal(expectedX, point.X);
  49. // Assert.Equal(expecetedY, point.Y);
  50. // point.X = 10;
  51. // Assert.Equal(10, point.X);
  52. // point.Y = -10.123f;
  53. // Assert.Equal(-10.123f, point.Y);
  54. // }
  55. // public IEnumerable<TestCaseData> VectorAdditionTestCases
  56. // {
  57. // get
  58. // {
  59. // yield return
  60. // new TestCaseData(new Point2(), new Vector2(), new Point2()).SetName(
  61. // "The addition of the zero point and the zero vector is the zero point.");
  62. // yield return
  63. // new TestCaseData(new Point2(5, 5), new Vector2(15, 15), new Point2(20, 20)).SetName(
  64. // "The addition of a non-zero point and a non-zero vector is the expected point.");
  65. // }
  66. // }
  67. // [Fact]
  68. // [TestCaseSource(nameof(VectorAdditionTestCases))]
  69. // public void VectorAddition(Point2 point, Vector2 vector, Point2 expectedPoint)
  70. // {
  71. // Assert.Equal(expectedPoint, point + vector);
  72. // Assert.Equal(expectedPoint, Point2.Add(point, vector));
  73. // }
  74. // public IEnumerable<TestCaseData> VectorSubtractionTestCases
  75. // {
  76. // get
  77. // {
  78. // yield return
  79. // new TestCaseData(new Point2(), new Vector2(), new Point2()).SetName(
  80. // "The vector subtraction of two zero points is the zero vector.");
  81. // yield return
  82. // new TestCaseData(new Point2(5, 5), new Vector2(15, 15), new Point2(-10, -10)).SetName(
  83. // "The vector subtraction of two non-zero points is the expected vector.");
  84. // }
  85. // }
  86. // [Fact]
  87. // [TestCaseSource(nameof(VectorSubtractionTestCases))]
  88. // public void VectorSubtraction(Point2 point, Vector2 vector, Point2 expectedPoint)
  89. // {
  90. // Assert.Equal(expectedPoint, point - vector);
  91. // Assert.Equal(expectedPoint, Point2.Subtract(point, vector));
  92. // }
  93. // public IEnumerable<TestCaseData> DisplacementTestCases
  94. // {
  95. // get
  96. // {
  97. // yield return
  98. // new TestCaseData(new Point2(), new Point2(), new Vector2()).SetName(
  99. // "The displacement between two zero points is the zero vector.");
  100. // yield return
  101. // new TestCaseData(new Point2(5, 5), new Point2(15, 15), new Vector2(10, 10)).SetName(
  102. // "The displacement between two non-zero points is the expected vector.");
  103. // }
  104. // }
  105. // [Fact]
  106. // [TestCaseSource(nameof(DisplacementTestCases))]
  107. // public void Displacement(Point2 point1, Point2 point2, Vector2 expectedVector)
  108. // {
  109. // Assert.Equal(expectedVector, point2 - point1);
  110. // Assert.Equal(expectedVector, Point2.Displacement(point2, point1));
  111. // }
  112. // public IEnumerable<TestCaseData> SizeAdditionTestCases
  113. // {
  114. // get
  115. // {
  116. // yield return
  117. // new TestCaseData(new Point2(), new Size2(), new Point2()).SetName(
  118. // "The size addition of the zero point with the empty size is the zero point.");
  119. // yield return
  120. // new TestCaseData(new Point2(5, 5), new Size2(15, 15), new Point2(20, 20)).SetName(
  121. // "The size addition of a non-zero point with a non-empty size is the expected point.");
  122. // }
  123. // }
  124. // [Fact]
  125. // [TestCaseSource(nameof(SizeAdditionTestCases))]
  126. // public void SizeAdditon(Point2 point, Size2 size, Point2 expectedPoint)
  127. // {
  128. // Assert.Equal(expectedPoint, point + size);
  129. // Assert.Equal(expectedPoint, Point2.Add(point, size));
  130. // }
  131. // public IEnumerable<TestCaseData> SizeSubtractionTestCases
  132. // {
  133. // get
  134. // {
  135. // yield return
  136. // new TestCaseData(new Point2(), new Size2(), new Point2()).SetName(
  137. // "The size substraction of the zero point with the empty size is the zero point.");
  138. // yield return
  139. // new TestCaseData(new Point2(5, 5), new Size2(15, 15), new Point2(-10, -10)).SetName(
  140. // "The size subscration of a non-zero point with a non-empty size is the expected point.");
  141. // }
  142. // }
  143. // [Fact]
  144. // [TestCaseSource(nameof(SizeSubtractionTestCases))]
  145. // public void SizeSubtraction(Point2 point, Size2 size, Point2 expectedPoint)
  146. // {
  147. // Assert.Equal(expectedPoint, point - size);
  148. // Assert.Equal(expectedPoint, Point2.Subtract(point, size));
  149. // }
  150. // public IEnumerable<TestCaseData> MinimumTestCases
  151. // {
  152. // get
  153. // {
  154. // yield return
  155. // new TestCaseData(new Point2(), new Point2(), new Point2()).SetName(
  156. // "The minimum coordinates of two zero points is the coordinates of the zero point.");
  157. // yield return
  158. // new TestCaseData(new Point2(float.MaxValue, float.MinValue), new Point2(int.MaxValue, int.MinValue),
  159. // new Point2(int.MaxValue, float.MinValue)).SetName(
  160. // "The minimum coordaintes of two non-zero points is the expected coordinates.");
  161. // }
  162. // }
  163. // [Fact]
  164. // [TestCaseSource(nameof(MinimumTestCases))]
  165. // public void Minimum(Point2 point1, Point2 point2, Point2 expectedPoint)
  166. // {
  167. // var actualPoint = Point2.Minimum(point1, point2);
  168. // Assert.Equal(expectedPoint, actualPoint);
  169. // }
  170. // public IEnumerable<TestCaseData> MaximumTestCases
  171. // {
  172. // get
  173. // {
  174. // yield return
  175. // new TestCaseData(new Point2(), new Point2(), new Point2()).SetName(
  176. // "The maximum coordinates of two zero points is the coordinates of the zero point.");
  177. // yield return
  178. // new TestCaseData(new Point2(float.MaxValue, float.MinValue), new Point2(int.MaxValue, int.MinValue),
  179. // new Point2(float.MaxValue, int.MinValue)).SetName(
  180. // "The maximum coordaintes of two non-zero points is the expected coordinates.");
  181. // }
  182. // }
  183. // [Fact]
  184. // [TestCaseSource(nameof(MaximumTestCases))]
  185. // public void Maximum(Point2 point1, Point2 point2, Point2 expectedPoint)
  186. // {
  187. // var actualPoint = Point2.Maximum(point1, point2);
  188. // Assert.Equal(expectedPoint, actualPoint);
  189. // }
  190. // public IEnumerable<TestCaseData> EqualityTestCases
  191. // {
  192. // get
  193. // {
  194. // yield return
  195. // new TestCaseData(new Point2(), new Point2(), true).SetName("Two zero points are equal.");
  196. // yield return
  197. // new TestCaseData(new Point2(float.MinValue, float.MaxValue),
  198. // new Point2(float.MaxValue, float.MinValue), false).SetName(
  199. // "Two different non-zero points are not equal.");
  200. // yield return
  201. // new TestCaseData(
  202. // new Point2(float.MinValue, float.MaxValue), new Point2(float.MinValue, float.MaxValue), true)
  203. // .SetName(
  204. // "Two identical non-zero points are equal.");
  205. // }
  206. // }
  207. // [Fact]
  208. // [TestCaseSource(nameof(EqualityTestCases))]
  209. // public void Equality(Point2 point1, Point2 point2, bool expectedToBeEqual)
  210. // {
  211. // Assert.IsTrue(Equals(point1, point2) == expectedToBeEqual);
  212. // Assert.IsTrue(point1 == point2 == expectedToBeEqual);
  213. // Assert.IsFalse(point1 == point2 != expectedToBeEqual);
  214. // Assert.IsTrue(point1.Equals(point2) == expectedToBeEqual);
  215. // if (expectedToBeEqual)
  216. // Assert.Equal(point1.GetHashCode(), point2.GetHashCode());
  217. // }
  218. // public IEnumerable<TestCaseData> InequalityTestCases
  219. // {
  220. // get
  221. // {
  222. // yield return
  223. // new TestCaseData(new Point2(), null, false).SetName("A point is not equal to a null object.");
  224. // yield return
  225. // new TestCaseData(new Point2(), new object(), false).SetName(
  226. // "A point is not equal to an instantiated object.");
  227. // }
  228. // }
  229. // [Fact]
  230. // [TestCaseSource(nameof(InequalityTestCases))]
  231. // public void Inequality(Point2 point, object obj, bool expectedToBeEqual)
  232. // {
  233. // Assert.IsTrue(point.Equals(obj) == expectedToBeEqual);
  234. // }
  235. // public IEnumerable<TestCaseData> HashCodeTestCases
  236. // {
  237. // get
  238. // {
  239. // yield return
  240. // new TestCaseData(new Point2(), new Point2(), true).SetName(
  241. // "Two zero points have the same hash code.");
  242. // yield return
  243. // new TestCaseData(new Point2(50, 50), new Point2(50, 50), true).SetName(
  244. // "Two indentical non-zero points have the same hash code.");
  245. // yield return
  246. // new TestCaseData(new Point2(0, 0), new Point2(50, 50), false).SetName(
  247. // "Two different non-zero points do not have the same hash code.");
  248. // }
  249. // }
  250. // [Fact]
  251. // [TestCaseSource(nameof(HashCodeTestCases))]
  252. // public void HashCode(Point2 point1, Point2 point2, bool expectedThatHashCodesAreEqual)
  253. // {
  254. // var hashCode1 = point1.GetHashCode();
  255. // var hashCode2 = point2.GetHashCode();
  256. // if (expectedThatHashCodesAreEqual)
  257. // Assert.Equal(hashCode1, hashCode2);
  258. // else
  259. // Assert.AreNotEqual(hashCode1, hashCode2);
  260. // }
  261. // public IEnumerable<TestCaseData> ToVectorTestCases
  262. // {
  263. // get
  264. // {
  265. // yield return
  266. // new TestCaseData(new Point2(), new Vector2()).SetName(
  267. // "The zero point converted to a vector is the zero vector.");
  268. // yield return
  269. // new TestCaseData(new Point2(float.MinValue, float.MaxValue),
  270. // new Vector2(float.MinValue, float.MaxValue)).SetName(
  271. // "A non-zero point converted to a vector is the expected vector.");
  272. // }
  273. // }
  274. // [Fact]
  275. // [TestCaseSource(nameof(ToVectorTestCases))]
  276. // public void ToVector(Point2 point, Vector2 expectedVector)
  277. // {
  278. // var actualVector = (Vector2)point;
  279. // Assert.Equal(expectedVector, actualVector);
  280. // }
  281. // public IEnumerable<TestCaseData> FromVectorTestCases
  282. // {
  283. // get
  284. // {
  285. // yield return
  286. // new TestCaseData(new Vector2(), new Point2()).SetName(
  287. // "The zero vector converted to a point is the zero point.");
  288. // yield return
  289. // new TestCaseData(new Vector2(float.MinValue, float.MaxValue),
  290. // new Point2(float.MinValue, float.MaxValue)).SetName(
  291. // "A non-zero vector converted to a point is the expected point.");
  292. // }
  293. // }
  294. // [Fact]
  295. // [TestCaseSource(nameof(FromVectorTestCases))]
  296. // public void FromVector(Vector2 vector, Point2 expectedPoint)
  297. // {
  298. // var actualPoint = (Point2)vector;
  299. // Assert.Equal(expectedPoint, actualPoint);
  300. // }
  301. // public IEnumerable<TestCaseData> StringCases
  302. // {
  303. // get
  304. // {
  305. // yield return
  306. // new TestCaseData(new Point2(),
  307. // string.Format(CultureInfo.CurrentCulture, "({0}, {1})", 0, 0)).SetName(
  308. // "The zero point has the expected string representation using the current culture.");
  309. // yield return new TestCaseData(new Point2(5.1f, -5.123f),
  310. // string.Format(CultureInfo.CurrentCulture, "({0}, {1})", 5.1f, -5.123f)).SetName(
  311. // "A non-zero point has the expected string representation using the current culture.");
  312. // }
  313. // }
  314. // [Fact]
  315. // [TestCaseSource(nameof(StringCases))]
  316. // public void String(Point2 point, string expectedString)
  317. // {
  318. // var actualString = point.ToString();
  319. // Assert.Equal(expectedString, actualString);
  320. // }
  321. // }
  322. //}