--- /dev/null
+#include <Evas.h>\r
+#include <Ecore.h>\r
+#include <Ecore_Evas.h>\r
+#include <Eina.h>\r
+\r
+#include <check.h>\r
+\r
+#include <math.h>\r
+#include <float.h>\r
+\r
+#define WIDTH 800\r
+#define HEIGHT 600\r
+\r
+static Ecore_Evas *ee = NULL;\r
+\r
+/**\r
+ * @addtogroup evas_vg\r
+ * @{\r
+ * @defgroup evas_vg_shape\r
+ *\r
+ *\r
+ * @precondition\r
+ * @step 1 Initialize ecore-evas with ecore_evas_init()\r
+ * @step 2 Create a new Ecore_Evas and show\r
+ */\r
+static void\r
+setup(void)\r
+{\r
+ printf(" ============ Startup ============ \n");\r
+ ecore_evas_init();\r
+ ee = ecore_evas_new(NULL, 0, 0, WIDTH, HEIGHT, NULL);\r
+ if (!ee)\r
+ {\r
+ ck_abort_msg("[TEST_FAIL]:: %s[%d] : Test has failed", __FILE__, __LINE__);\r
+ return;\r
+ }\r
+ ecore_evas_show(ee);\r
+\r
+}\r
+\r
+static void\r
+teardown(void)\r
+{\r
+ printf(" ============ Cleanup ============ \n");\r
+ if (ee)\r
+ {\r
+ ecore_evas_free(ee);\r
+ }\r
+ ecore_evas_shutdown();\r
+}\r
+\r
+/**\r
+ * @addtogroup utc_evas_vg_gradient_spread_set_get\r
+ * @{\r
+ * @objective Positive test case checks if function sets/gets the spread method that should be used for gradient color object\r
+ * and without segmentation fault.\r
+ *\r
+ * @n Input Data:\r
+ * @li the given canvas\r
+ *\r
+ * @procedure\r
+ * @step 1 Call evas_object_vg_add function to create a new vector object\r
+ * and check on not NULL\r
+ * @step 2 Show vector object\r
+ * @step 3 Call evas_vg_container_add function to create a new vector container object\r
+ * @step 4 Create a gradient linear color object and check on not NULL\r
+ * @step 5 Set the spread method EVAS_VG_GRADIENT_SPREAD_REFLECT for gradient color object\r
+ * @step 6 Get the spread method from gradient color object and check on EVAS_VG_GRADIENT_SPREAD_REFLECT\r
+ * @step 7 Set the spread method EVAS_VG_GRADIENT_SPREAD_REPEAT for gradient color object\r
+ * @step 8 Get the spread method from gradient color object and check on EVAS_VG_GRADIENT_SPREAD_REPEAT\r
+ *\r
+ * @passcondition Function should set/get the spread method that should be used for gradient color object,\r
+ * and without segmentation fault.\r
+ * @}\r
+ * @}\r
+ */\r
+START_TEST(utc_evas_vg_gradient_spread_set_get_p)\r
+{\r
+ Efl_VG *vg, *container, *linear_gradient;\r
+\r
+ vg = evas_object_vg_add(ecore_evas_get(ee));\r
+ if (!vg)\r
+ {\r
+ ck_abort_msg("[TEST_FAIL]:: %s[%d] : Test has failed", __FILE__, __LINE__);\r
+ return;\r
+ }\r
+\r
+ evas_object_resize(vg, WIDTH, HEIGHT);\r
+ evas_object_show(vg);\r
+\r
+ container = evas_vg_container_add(vg);\r
+\r
+ linear_gradient = evas_vg_gradient_linear_add(container);\r
+ if (!linear_gradient)\r
+ {\r
+ ck_abort_msg("[TEST_FAIL]:: %s[%d] : Test has failed", __FILE__, __LINE__);\r
+ return;\r
+ }\r
+\r
+ evas_vg_gradient_spread_set(linear_gradient, EVAS_VG_GRADIENT_SPREAD_REFLECT);\r
+ if (evas_vg_gradient_spread_get(linear_gradient) != EVAS_VG_GRADIENT_SPREAD_REFLECT)\r
+ {\r
+ ck_abort_msg("[TEST_FAIL]:: %s[%d] : Test has failed", __FILE__, __LINE__);\r
+ return;\r
+ }\r
+\r
+ evas_vg_gradient_spread_set(linear_gradient, EVAS_VG_GRADIENT_SPREAD_REPEAT);\r
+ if (evas_vg_gradient_spread_get(linear_gradient) != EVAS_VG_GRADIENT_SPREAD_REPEAT)\r
+ {\r
+ ck_abort_msg("[TEST_FAIL]:: %s[%d] : Test has failed", __FILE__, __LINE__);\r
+ return;\r
+ }\r
+\r
+ printf("[TEST_PASS]:: %s[%d] : Test has passed..\n", __FILE__, __LINE__);\r
+}\r
+END_TEST\r
+\r
+/**\r
+ * @addtogroup utc_evas_vg_gradient_spread_set_get\r
+ * @{\r
+ * @objective Negative Test case checks if calling function with invalid value won't cause segmentation fault\r
+ * @n Input Data:\r
+ * @li NULL, gradient value\r
+ *\r
+ * @procedure\r
+ * @step 1 Call testing function with NULL as a gradient value\r
+ *\r
+ * @passcondition There is no segmentation fault\r
+ * @}\r
+ */\r
+START_TEST(utc_evas_vg_gradient_spread_set_get_n)\r
+{\r
+ evas_vg_gradient_spread_set(NULL, EVAS_VG_GRADIENT_SPREAD_REFLECT);\r
+ evas_vg_gradient_spread_get(NULL);\r
+\r
+ printf("[TEST_PASS]:: %s[%d] : Test has passed..\n", __FILE__, __LINE__);\r
+}\r
+END_TEST\r
+\r
+TCase * _utc_evas_vg_gradient_spread_set_get()\r
+{\r
+ TCase *tcase = tcase_create("utc_evas_vg_gradient_spread_set_get");\r
+ tcase_set_timeout(tcase, 30);\r
+ tcase_add_checked_fixture(tcase, setup, teardown);\r
+ tcase_add_test(tcase, utc_evas_vg_gradient_spread_set_get_p);\r
+ tcase_add_test(tcase, utc_evas_vg_gradient_spread_set_get_n);\r
+\r
+ return tcase;\r
+}\r
+\r