test_vpath.cpp 7.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190
  1. #include <gtest/gtest.h>
  2. #include "vpath.h"
  3. class VPathTest : public ::testing::Test {
  4. public:
  5. void SetUp()
  6. {
  7. pathRect.addRect({-10, -20, 100, 100});
  8. pathRoundRect.addRoundRect({0, 0, 100, 100}, 5, 5);
  9. pathRoundRectZeroCorner.addRoundRect({0, 0, 100, 100}, 0, 0);
  10. pathRoundRectHalfCircle.addRoundRect({0, 0, 100, 100}, 60, 60);
  11. pathOval.addOval({0,0,100,50});
  12. pathOvalCircle.addOval({0,0,100,100});
  13. pathCircle.addCircle(0, 0, 100);
  14. pathCircleZeroRadius.addCircle(10, 10, 0);
  15. pathPolygon.addPolygon(10, 50, 5, 0, 0, 0);
  16. pathPolystar.addPolystar(10, 50, 100, 7, 14, 0, 0, 0);
  17. pathPolygonZero.addPolygon(10, 50, 0, 0, 0, 0);
  18. pathPolystarZero.addPolystar(10, 50, 100, 0, 0, 0, 0, 0);
  19. }
  20. void TearDown()
  21. {
  22. }
  23. public:
  24. VPath pathEmpty;
  25. VPath pathRect;
  26. VPath pathRoundRect;
  27. VPath pathRoundRectZeroCorner;
  28. VPath pathRoundRectHalfCircle;
  29. VPath pathOval;
  30. VPath pathOvalCircle;
  31. VPath pathCircle;
  32. VPath pathCircleZeroRadius;
  33. VPath pathPolygon;
  34. VPath pathPolystar;
  35. VPath pathPolygonZero;
  36. VPath pathPolystarZero;
  37. };
  38. TEST_F(VPathTest, emptyPath) {
  39. ASSERT_EQ(sizeof(pathEmpty), sizeof(void *));
  40. ASSERT_TRUE(pathEmpty.empty());
  41. ASSERT_FALSE(pathEmpty.segments());
  42. ASSERT_EQ(pathEmpty.segments() , 0);
  43. ASSERT_EQ(pathEmpty.elements().size() , 0);
  44. ASSERT_EQ(pathEmpty.elements().capacity() , pathEmpty.elements().size());
  45. ASSERT_EQ(pathEmpty.points().size() , 0);
  46. ASSERT_EQ(pathEmpty.points().capacity() , pathEmpty.points().size());
  47. }
  48. TEST_F(VPathTest, reset) {
  49. pathRect.reset();
  50. ASSERT_TRUE(pathRect.empty());
  51. ASSERT_EQ(pathRect.segments() , 0);
  52. ASSERT_GE(pathRect.points().capacity(), 1);
  53. ASSERT_GE(pathRect.elements().capacity(), 1);
  54. }
  55. TEST_F(VPathTest, reserve) {
  56. pathEmpty.reserve(10, 10);
  57. ASSERT_EQ(pathEmpty.points().capacity(), 10);
  58. ASSERT_GE(pathEmpty.elements().capacity(), 10);
  59. ASSERT_EQ(pathEmpty.segments() , 0);
  60. ASSERT_EQ(pathEmpty.points().size(), 0);
  61. ASSERT_GE(pathEmpty.elements().size(), 0);
  62. }
  63. TEST_F(VPathTest, clone) {
  64. VPath pathClone;
  65. pathClone.clone(pathOval);
  66. ASSERT_TRUE(pathClone.unique());
  67. ASSERT_EQ(pathClone.segments(), pathOval.segments());
  68. ASSERT_EQ(pathClone.points().size(), pathOval.points().size());
  69. ASSERT_NE(pathClone.points().data(), pathOval.points().data());
  70. ASSERT_EQ(pathClone.elements().size(), pathOval.elements().size());
  71. ASSERT_NE(pathClone.elements().data(), pathOval.elements().data());
  72. }
  73. TEST_F(VPathTest, copyOnWrite) {
  74. VPath pathCopy;
  75. pathCopy = pathOval;
  76. ASSERT_EQ(pathCopy.segments(), pathOval.segments());
  77. ASSERT_EQ(pathCopy.points().size(), pathOval.points().size());
  78. ASSERT_EQ(pathCopy.points().data(), pathOval.points().data());
  79. ASSERT_EQ(pathCopy.elements().size(), pathOval.elements().size());
  80. ASSERT_EQ(pathCopy.elements().data(), pathOval.elements().data());
  81. }
  82. TEST_F(VPathTest, addRect) {
  83. ASSERT_FALSE(pathRect.empty());
  84. ASSERT_EQ(pathRect.segments() , 1);
  85. ASSERT_EQ(pathRect.elements().capacity() , pathRect.elements().size());
  86. ASSERT_EQ(pathRect.points().capacity() , pathRect.points().size());
  87. }
  88. TEST_F(VPathTest, addRect_N) {
  89. pathEmpty.addRect({});
  90. ASSERT_TRUE(pathEmpty.empty());
  91. ASSERT_EQ(pathEmpty.segments() , 0);
  92. }
  93. TEST_F(VPathTest, addRoundRect) {
  94. ASSERT_FALSE(pathRoundRect.empty());
  95. ASSERT_EQ(pathRoundRect.segments() , 1);
  96. ASSERT_EQ(pathRoundRect.elements().capacity() , pathRoundRect.elements().size());
  97. ASSERT_EQ(pathRoundRect.points().capacity() , pathRoundRect.points().size());
  98. }
  99. TEST_F(VPathTest, addRoundRectZeoCorner) {
  100. ASSERT_FALSE(pathRoundRectZeroCorner.empty());
  101. ASSERT_EQ(pathRoundRectZeroCorner.segments() , 1);
  102. ASSERT_EQ(pathRoundRectZeroCorner.elements().size() , pathRect.elements().size());
  103. ASSERT_EQ(pathRoundRectZeroCorner.elements().capacity() , pathRoundRectZeroCorner.elements().size());
  104. ASSERT_EQ(pathRoundRectZeroCorner.points().size() , pathRect.points().size());
  105. ASSERT_EQ(pathRoundRectZeroCorner.points().capacity() , pathRoundRectZeroCorner.points().size());
  106. }
  107. TEST_F(VPathTest, addRoundRectHalfCircle) {
  108. ASSERT_FALSE(pathRoundRectHalfCircle.empty());
  109. ASSERT_EQ(pathRoundRectHalfCircle.segments() , 1);
  110. ASSERT_EQ(pathRoundRectHalfCircle.elements().capacity() , pathRoundRectHalfCircle.elements().size());
  111. ASSERT_EQ(pathRoundRectHalfCircle.points().capacity() , pathRoundRectHalfCircle.points().size());
  112. }
  113. TEST_F(VPathTest, addOval) {
  114. ASSERT_FALSE(pathOval.empty());
  115. ASSERT_EQ(pathOval.segments() , 1);
  116. ASSERT_EQ(pathOval.elements().capacity() , pathOval.elements().size());
  117. ASSERT_EQ(pathOval.points().capacity() , pathOval.points().size());
  118. }
  119. TEST_F(VPathTest, addOvalCircle) {
  120. ASSERT_FALSE(pathOvalCircle.empty());
  121. ASSERT_EQ(pathOvalCircle.segments() , 1);
  122. ASSERT_EQ(pathOvalCircle.elements().size() , pathOval.elements().size());
  123. ASSERT_EQ(pathOvalCircle.elements().capacity() , pathOvalCircle.elements().size());
  124. ASSERT_EQ(pathOvalCircle.points().size() , pathOval.points().size());
  125. ASSERT_EQ(pathOvalCircle.points().capacity() , pathOvalCircle.points().size());
  126. }
  127. TEST_F(VPathTest, addCircle) {
  128. ASSERT_FALSE(pathCircle.empty());
  129. ASSERT_EQ(pathCircle.segments() , 1);
  130. ASSERT_EQ(pathCircle.elements().size() , pathOval.elements().size());
  131. ASSERT_EQ(pathCircle.elements().capacity() , pathCircle.elements().size());
  132. ASSERT_EQ(pathCircle.points().size() , pathOval.points().size());
  133. ASSERT_EQ(pathCircle.points().capacity() , pathCircle.points().size());
  134. }
  135. TEST_F(VPathTest, addCircleZeroRadius) {
  136. ASSERT_TRUE(pathCircleZeroRadius.empty());
  137. ASSERT_EQ(pathCircleZeroRadius.segments() , 0);
  138. }
  139. TEST_F(VPathTest, length) {
  140. ASSERT_EQ(pathRect.length(), 400);
  141. }
  142. TEST_F(VPathTest, lengthEmptyPath) {
  143. ASSERT_EQ(pathEmpty.length(), 0);
  144. }
  145. TEST_F(VPathTest, addPolygon) {
  146. ASSERT_FALSE(pathPolygon.empty());
  147. ASSERT_EQ(pathPolygon.segments() , 1);
  148. ASSERT_EQ(pathPolygon.elements().size() , pathPolygon.elements().capacity());
  149. ASSERT_EQ(pathPolygon.points().size() , pathPolygon.points().capacity());
  150. }
  151. TEST_F(VPathTest, addPolygonZeroRoundness) {
  152. ASSERT_FALSE(pathPolygonZero.empty());
  153. ASSERT_EQ(pathPolygonZero.segments() , 1);
  154. ASSERT_EQ(pathPolygonZero.elements().size() , pathPolygonZero.elements().capacity());
  155. ASSERT_EQ(pathPolygonZero.points().size() , pathPolygonZero.points().capacity());
  156. }
  157. TEST_F(VPathTest, addPolystar) {
  158. ASSERT_FALSE(pathPolystar.empty());
  159. ASSERT_EQ(pathPolystar.segments() , 1);
  160. ASSERT_EQ(pathPolystar.elements().size() , pathPolystar.elements().capacity());
  161. ASSERT_EQ(pathPolystar.points().size() , pathPolystar.points().capacity());
  162. }
  163. TEST_F(VPathTest, addPolystarZeroRoundness) {
  164. ASSERT_FALSE(pathPolystarZero.empty());
  165. ASSERT_EQ(pathPolystarZero.segments() , 1);
  166. ASSERT_EQ(pathPolystarZero.elements().size() , pathPolystarZero.elements().capacity());
  167. ASSERT_EQ(pathPolystarZero.points().size() , pathPolystarZero.points().capacity());
  168. }