Add test for error and magic.
authorcedric <cedric>
Fri, 1 Aug 2008 14:27:01 +0000 (14:27 +0000)
committercedric <cedric@7cbeb6ba-43b4-40fd-8cce-4c39aea84d33>
Fri, 1 Aug 2008 14:27:01 +0000 (14:27 +0000)
git-svn-id: http://svn.enlightenment.org/svn/e/trunk/e17/proto/eina@35301 7cbeb6ba-43b4-40fd-8cce-4c39aea84d33

src/tests/Makefile.am
src/tests/eina_suite.c
src/tests/eina_suite.h
src/tests/eina_test_error.c [new file with mode: 0644]
src/tests/eina_test_magic.c [new file with mode: 0644]

index 682011b..397e571 100644 (file)
@@ -10,7 +10,12 @@ if EINA_ENABLE_TESTS
 
 check_PROGRAMS = eina_suite
 
-eina_suite_SOURCES = eina_suite.c eina_test_stringshare.c eina_test_array.c
+eina_suite_SOURCES = \
+eina_suite.c \
+eina_test_stringshare.c \
+eina_test_array.c \
+eina_test_error.c \
+eina_test_magic.c
 eina_suite_LDADD = @CHECK_LIBS@ $(top_builddir)/src/lib/libeina.la
 
 EXTRA_DIST = eina_suite.h
index a12e239..b98ec2b 100644 (file)
@@ -10,6 +10,8 @@ struct _Eina_Test_Case
 static const Eina_Test_Case etc[] = {
   { "Array", eina_test_array },
   { "String Share", eina_test_stringshare },
+  { "Error", eina_test_error },
+  { "Magic", eina_test_magic },
   { NULL, NULL }
 };
 
index 9d1b044..5712bf6 100644 (file)
@@ -9,5 +9,7 @@
 
 void eina_test_stringshare(TCase *tc);
 void eina_test_array(TCase *tc);
+void eina_test_error(TCase *tc);
+void eina_test_magic(TCase *tc);
 
 #endif /* EINA_SUITE_H_ */
diff --git a/src/tests/eina_test_error.c b/src/tests/eina_test_error.c
new file mode 100644 (file)
index 0000000..3a8c854
--- /dev/null
@@ -0,0 +1,55 @@
+#include "eina_suite.h"
+#include "eina_error.h"
+
+START_TEST(eina_error_init_shutdown)
+{
+   eina_error_init();
+    eina_error_init();
+    eina_error_shutdown();
+    eina_error_init();
+     eina_error_init();
+     eina_error_shutdown();
+    eina_error_shutdown();
+   eina_error_shutdown();
+}
+END_TEST
+
+#define TEST_TEXT "The big test\n"
+
+#include <stdio.h>
+
+START_TEST(eina_error_errno)
+{
+   int test;
+
+   eina_error_init();
+
+   test = eina_error_register(TEST_TEXT);
+   fail_if(!eina_error_msg_get(test));
+   fail_if(strcmp(eina_error_msg_get(test), TEST_TEXT) != 0);
+
+   eina_error_set(test);
+   fail_if(eina_error_get() != test);
+
+   eina_error_shutdown();
+}
+END_TEST
+
+START_TEST(eina_error_macro)
+{
+   eina_error_log_level_set(EINA_ERROR_LEVEL_DBG);
+
+   EINA_ERROR_PERR("An error\n");
+   EINA_ERROR_PINFO("An info\n");
+   EINA_ERROR_PWARN("A warning\n");
+   EINA_ERROR_PDBG("A debug\n");
+}
+END_TEST
+
+void
+eina_test_error(TCase *tc)
+{
+   tcase_add_test(tc, eina_error_init_shutdown);
+   tcase_add_test(tc, eina_error_errno);
+   tcase_add_test(tc, eina_error_macro);
+}
diff --git a/src/tests/eina_test_magic.c b/src/tests/eina_test_magic.c
new file mode 100644 (file)
index 0000000..601ddfa
--- /dev/null
@@ -0,0 +1,67 @@
+#include <stdlib.h>
+
+#include "eina_suite.h"
+#include "eina_magic.h"
+
+START_TEST(eina_magic_string_init_shutdown)
+{
+   eina_magic_string_init();
+    eina_magic_string_init();
+    eina_magic_string_shutdown();
+    eina_magic_string_init();
+     eina_magic_string_init();
+     eina_magic_string_shutdown();
+    eina_magic_string_shutdown();
+   eina_magic_string_shutdown();
+}
+END_TEST
+
+#define EINA_MAGIC_TEST 0x7781fee7
+#define EINA_MAGIC_TEST2 0x42241664
+#define EINA_MAGIC_STRING "Eina Magic Test"
+
+typedef struct _Eina_Magic_Struct Eina_Magic_Struct;
+struct _Eina_Magic_Struct
+{
+   EINA_MAGIC
+};
+
+START_TEST(eina_magic_simple)
+{
+   Eina_Magic_Struct *ems = NULL;
+
+   eina_magic_string_init();
+
+   eina_magic_string_set(EINA_MAGIC_TEST, EINA_MAGIC_STRING);
+   eina_magic_string_set(EINA_MAGIC_TEST2, NULL);
+   eina_magic_string_set(EINA_MAGIC_TEST2, NULL);
+   eina_magic_string_set(EINA_MAGIC_TEST2, EINA_MAGIC_STRING);
+
+   fail_if(eina_magic_string_get(EINA_MAGIC_TEST) == NULL);
+   fail_if(strcmp(eina_magic_string_get(EINA_MAGIC_TEST), EINA_MAGIC_STRING) != 0);
+
+   fail_if(EINA_MAGIC_CHECK(ems, EINA_MAGIC_TEST));
+   EINA_MAGIC_FAIL(ems, EINA_MAGIC_TEST);
+
+   ems = malloc(sizeof (Eina_Magic_Struct));
+   fail_if(!ems);
+   EINA_MAGIC_SET(ems, EINA_MAGIC_TEST);
+
+   fail_if(!EINA_MAGIC_CHECK(ems, EINA_MAGIC_TEST));
+
+   EINA_MAGIC_SET(ems, EINA_MAGIC_NONE);
+   EINA_MAGIC_FAIL(ems, EINA_MAGIC_TEST);
+
+   EINA_MAGIC_SET(ems, 42424242);
+   EINA_MAGIC_FAIL(ems, EINA_MAGIC_TEST);
+
+   eina_magic_string_shutdown();
+}
+END_TEST
+
+void eina_test_magic(TCase *tc)
+{
+   tcase_add_test(tc, eina_magic_string_init_shutdown);
+   tcase_add_test(tc, eina_magic_simple);
+}
+