[daemon-fix] Fixed sending daemon match rules for kdbus broadcasts
[platform/upstream/dbus.git] / dbus / dbus-test.c
index 8654d86..b707ee2 100644 (file)
@@ -1,7 +1,7 @@
-/* -*- mode: C; c-file-style: "gnu" -*- */
+/* -*- mode: C; c-file-style: "gnu"; indent-tabs-mode: nil; -*- */
 /* dbus-test.c  Program to run all tests
  *
- * Copyright (C) 2002, 2003  Red Hat Inc.
+ * Copyright (C) 2002, 2003, 2004, 2005  Red Hat Inc.
  *
  * Licensed under the Academic Free License version 2.1
  * 
@@ -17,7 +17,7 @@
  * 
  * You should have received a copy of the GNU General Public License
  * along with this program; if not, write to the Free Software
- * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA
  *
  */
 
@@ -28,7 +28,7 @@
 #include <stdio.h>
 #include <stdlib.h>
 
-#ifdef DBUS_BUILD_TESTS
+#ifdef DBUS_ENABLE_EMBEDDED_TESTS
 static void
 die (const char *failure)
 {
@@ -50,7 +50,41 @@ check_memleaks (void)
     }
 }
 
-#endif /* DBUS_BUILD_TESTS */
+typedef dbus_bool_t (*TestFunc)(void);
+typedef dbus_bool_t (*TestDataFunc)(const char *data);
+
+static void
+run_test (const char             *test_name,
+         const char             *specific_test,
+         TestFunc                test)
+{
+  if (!specific_test || strcmp (specific_test, test_name) == 0)
+    {
+      printf ("%s: running %s tests\n", "dbus-test", test_name);
+      if (!test ())
+       die (test_name);
+
+      check_memleaks ();
+    }
+}
+
+static void
+run_data_test (const char             *test_name,
+              const char             *specific_test,
+              TestDataFunc            test,
+              const char             *test_data_dir)
+{
+  if (!specific_test || strcmp (specific_test, test_name) == 0)
+    {
+      printf ("%s: running %s tests\n", "dbus-test", test_name);
+      if (!test (test_data_dir))
+       die (test_name);
+
+      check_memleaks ();
+    }
+}
+
+#endif /* DBUS_ENABLE_EMBEDDED_TESTS */
 
 /**
  * An exported symbol to be run in order to execute
@@ -60,11 +94,12 @@ check_memleaks (void)
  * (with --enable-tests=no)
  *
  * @param test_data_dir the directory with test data (test/data normally)
+ * @param specific_test run specific test or #NULL to run all tests
  */
 void
-dbus_internal_do_not_use_run_tests (const char *test_data_dir)
+dbus_internal_do_not_use_run_tests (const char *test_data_dir, const char *specific_test)
 {
-#ifdef DBUS_BUILD_TESTS
+#ifdef DBUS_ENABLE_EMBEDDED_TESTS
   if (!_dbus_threads_init_debug ())
     die ("debug threads init");
   
@@ -76,146 +111,63 @@ dbus_internal_do_not_use_run_tests (const char *test_data_dir)
   else
     printf ("No test data!\n");
 
-  printf ("%s: running string tests\n", "dbus-test");
-  if (!_dbus_string_test ())
-    die ("strings");
-
-  check_memleaks ();
+  run_test ("string", specific_test, _dbus_string_test);
   
-  printf ("%s: running sysdeps tests\n", "dbus-test");
-  if (!_dbus_sysdeps_test ())
-    die ("sysdeps");
-
-  check_memleaks ();
-  
-  printf ("%s: running data slot tests\n", "dbus-test");
-  if (!_dbus_data_slot_test ())
-    die ("dataslot");
-
-  check_memleaks ();
+  run_test ("sysdeps", specific_test, _dbus_sysdeps_test);
   
-  printf ("%s: running address parse tests\n", "dbus-test");
-  if (!_dbus_address_test ())
-    die ("address parsing");
-
-  check_memleaks ();
-
-  printf ("%s: running server listen tests\n", "dbus-test");
-  if (!_dbus_server_test ())
-    die ("server listen");
+  run_test ("data-slot", specific_test, _dbus_data_slot_test);
 
-  check_memleaks ();
-
-  printf ("%s: running object tree tests\n", "dbus-test");
-  if (!_dbus_object_tree_test ())
-    die ("object tree");
-  
-  check_memleaks ();
+  run_test ("misc", specific_test, _dbus_misc_test);
   
-  printf ("%s: running marshalling tests\n", "dbus-test");
-  if (!_dbus_marshal_test ())
-    die ("marshalling");
-
-  check_memleaks ();
+  run_test ("address", specific_test, _dbus_address_test);
 
-#if 1
-  printf ("%s: running recursive marshalling tests\n", "dbus-test");
-  if (!_dbus_marshal_recursive_test ())
-    die ("recursive marshal");
+  run_test ("server", specific_test, _dbus_server_test);
 
-  check_memleaks ();
-#else
-  _dbus_warn ("recursive marshal tests disabled\n");
-#endif
+  run_test ("object-tree", specific_test, _dbus_object_tree_test);
 
-  printf ("%s: running memory tests\n", "dbus-test");
-  if (!_dbus_memory_test ())
-    die ("memory");
+  run_test ("signature", specific_test, _dbus_signature_test);
   
-  check_memleaks ();
+  run_test ("marshalling", specific_test, _dbus_marshal_test);
 
-  printf ("%s: running memory pool tests\n", "dbus-test");
-  if (!_dbus_mem_pool_test ())
-    die ("memory pools");
+  run_test ("marshal-recursive", specific_test, _dbus_marshal_recursive_test);
 
-  check_memleaks ();
+  run_test ("byteswap", specific_test, _dbus_marshal_byteswap_test);
   
-  printf ("%s: running linked list tests\n", "dbus-test");
-  if (!_dbus_list_test ())
-    die ("lists");
+  run_test ("memory", specific_test, _dbus_memory_test);
 
-  check_memleaks ();
-
-  printf ("%s: running validation tests\n", "dbus-test");
-  if (!_dbus_marshal_validate_test ())
-    die ("validation");
-
-  check_memleaks ();
-
-  printf ("%s: running header marshal tests\n", "dbus-test");
-  if (!_dbus_marshal_header_test ())
-    die ("header marshal");
-
-  check_memleaks ();
-  
-  printf ("%s: running message tests\n", "dbus-test");
-  if (!_dbus_message_test (test_data_dir))
-    die ("messages");
-
-  check_memleaks ();
+#if 1
+  run_test ("mem-pool", specific_test, _dbus_mem_pool_test);
+#endif
   
-  printf ("%s: running hash table tests\n", "dbus-test");
-  if (!_dbus_hash_test ())
-    die ("hash tables");
+  run_test ("list", specific_test, _dbus_list_test);
 
-  check_memleaks ();
+  run_test ("marshal-validate", specific_test, _dbus_marshal_validate_test);
 
-  printf ("%s: running spawn tests\n", "dbus-test");
-  if (!_dbus_spawn_test (test_data_dir))
-    die ("spawn");
-
-  check_memleaks ();
+  run_data_test ("message", specific_test, _dbus_message_test, test_data_dir);
   
-  printf ("%s: running user database tests\n", "dbus-test");
-  if (!_dbus_userdb_test (test_data_dir))
-    die ("user database");
+  run_test ("hash", specific_test, _dbus_hash_test);
 
-  check_memleaks ();
+#if !defined(DBUS_WINCE)
+  run_data_test ("spawn", specific_test, _dbus_spawn_test, test_data_dir);
+#endif
   
-  printf ("%s: running keyring tests\n", "dbus-test");
-  if (!_dbus_keyring_test ())
-    die ("keyring");
+  run_data_test ("credentials", specific_test, _dbus_credentials_test, test_data_dir);
 
-  check_memleaks ();
-  
-#if 0
-  printf ("%s: running md5 tests\n", "dbus-test");
-  if (!_dbus_md5_test ())
-    die ("md5");
+#ifdef DBUS_UNIX
+  run_data_test ("userdb", specific_test, _dbus_userdb_test, test_data_dir);
 
-  check_memleaks ();
+  run_test ("transport-unix", specific_test, _dbus_transport_unix_test);
 #endif
   
-  printf ("%s: running SHA-1 tests\n", "dbus-test");
-  if (!_dbus_sha_test (test_data_dir))
-    die ("SHA-1");
+  run_test ("keyring", specific_test, _dbus_keyring_test);
 
-  check_memleaks ();
+  run_data_test ("sha", specific_test, _dbus_sha_test, test_data_dir);
   
-  printf ("%s: running auth tests\n", "dbus-test");
-  if (!_dbus_auth_test (test_data_dir))
-    die ("auth");
-
-  check_memleaks ();
-
-  printf ("%s: running pending call tests\n", "dbus-test");
-  if (!_dbus_pending_call_test (test_data_dir))
-    die ("auth");
+  run_data_test ("auth", specific_test, _dbus_auth_test, test_data_dir);
 
-  check_memleaks ();
-  
   printf ("%s: completed successfully\n", "dbus-test");
 #else
   printf ("Not compiled with unit tests, not running any\n");
 #endif
 }
+