+#include <gtest/gtest.h>
+#include "lottieanimation.h"
+
+class AnimationTest : public ::testing::Test {
+public:
+ void SetUp()
+ {
+ animationInvalid = lottie::Animation::loadFromFile("wrong_file.json");
+ std::string filePath = DEMO_DIR;
+ filePath +="mask.json";
+ animation = lottie::Animation::loadFromFile(filePath);
+
+ }
+ void TearDown()
+ {
+
+ }
+public:
+ std::unique_ptr<lottie::Animation> animationInvalid;
+ std::unique_ptr<lottie::Animation> animation;
+};
+
+TEST_F(AnimationTest, loadFromFile_N) {
+ ASSERT_FALSE(animationInvalid);
+}
+
+TEST_F(AnimationTest, loadFromFile) {
+ ASSERT_TRUE(animation);
+ ASSERT_EQ(animation->totalFrame(), 29);
+ size_t width, height;
+ animation->size(width, height);
+ ASSERT_EQ(width, 500);
+ ASSERT_EQ(height, 500);
+}
--- /dev/null
+#include <gtest/gtest.h>
+#include "lottieanimation_capi.h"
+
+class AnimationCApiTest : public ::testing::Test {
+public:
+ void SetUp()
+ {
+ animationInvalid = lottie_animation_from_file("wrong_file.json");
+ std::string filePath = DEMO_DIR;
+ filePath +="mask.json";
+ animation = lottie_animation_from_file(filePath.c_str());
+
+ }
+ void TearDown()
+ {
+ if (animation) lottie_animation_destroy(animation);
+ }
+public:
+ Lottie_Animation *animationInvalid;
+ Lottie_Animation *animation;
+};
+
+TEST_F(AnimationCApiTest, loadFromFile_N) {
+ ASSERT_FALSE(animationInvalid);
+}
+
+TEST_F(AnimationCApiTest, loadFromFile) {
+ ASSERT_TRUE(animation);
+ ASSERT_EQ(lottie_animation_get_totalframe(animation), 29);
+ size_t width, height;
+ lottie_animation_get_size(animation, &width, &height);
+ ASSERT_EQ(width, 500);
+ ASSERT_EQ(height, 500);
+}
pathOval.addOval({0,0,100,50});
pathOvalCircle.addOval({0,0,100,100});
pathCircle.addCircle(0, 0, 100);
+ pathCircleZeroRadius.addCircle(10, 10, 0);
pathPolygon.addPolygon(10, 50, 5, 0, 0, 0);
+ pathPolystar.addPolystar(10, 50, 100, 7, 14, 0, 0, 0);
+ pathPolygonZero.addPolygon(10, 50, 0, 0, 0, 0);
+ pathPolystarZero.addPolystar(10, 50, 100, 0, 0, 0, 0, 0);
}
void TearDown()
{
VPath pathOval;
VPath pathOvalCircle;
VPath pathCircle;
+ VPath pathCircleZeroRadius;
VPath pathPolygon;
+ VPath pathPolystar;
+ VPath pathPolygonZero;
+ VPath pathPolystarZero;
};
TEST_F(VPathTest, emptyPath) {
ASSERT_EQ(pathCircle.points().capacity() , pathCircle.points().size());
}
+TEST_F(VPathTest, addCircleZeroRadius) {
+ ASSERT_TRUE(pathCircleZeroRadius.empty());
+ ASSERT_EQ(pathCircleZeroRadius.segments() , 0);
+}
+
+TEST_F(VPathTest, length) {
+ ASSERT_EQ(pathRect.length(), 400);
+}
+
+TEST_F(VPathTest, lengthEmptyPath) {
+ ASSERT_EQ(pathEmpty.length(), 0);
+}
+
TEST_F(VPathTest, addPolygon) {
ASSERT_FALSE(pathPolygon.empty());
ASSERT_EQ(pathPolygon.segments() , 1);
ASSERT_EQ(pathPolygon.elements().size() , pathPolygon.elements().capacity());
ASSERT_EQ(pathPolygon.points().size() , pathPolygon.points().capacity());
}
+
+TEST_F(VPathTest, addPolygonZeroRoundness) {
+ ASSERT_FALSE(pathPolygonZero.empty());
+ ASSERT_EQ(pathPolygonZero.segments() , 1);
+ ASSERT_EQ(pathPolygonZero.elements().size() , pathPolygonZero.elements().capacity());
+ ASSERT_EQ(pathPolygonZero.points().size() , pathPolygonZero.points().capacity());
+}
+
+TEST_F(VPathTest, addPolystar) {
+ ASSERT_FALSE(pathPolystar.empty());
+ ASSERT_EQ(pathPolystar.segments() , 1);
+ ASSERT_EQ(pathPolystar.elements().size() , pathPolystar.elements().capacity());
+ ASSERT_EQ(pathPolystar.points().size() , pathPolystar.points().capacity());
+}
+
+TEST_F(VPathTest, addPolystarZeroRoundness) {
+ ASSERT_FALSE(pathPolystarZero.empty());
+ ASSERT_EQ(pathPolystarZero.segments() , 1);
+ ASSERT_EQ(pathPolystarZero.elements().size() , pathPolystarZero.elements().capacity());
+ ASSERT_EQ(pathPolystarZero.points().size() , pathPolystarZero.points().capacity());
+}