ofdbus/dbus/bus/test-main.c
changeset 0 e4d67989cc36
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/ofdbus/dbus/bus/test-main.c	Tue Feb 02 02:01:42 2010 +0200
@@ -0,0 +1,233 @@
+/* -*- mode: C; c-file-style: "gnu" -*- */
+/* test-main.c  main() for make check
+ *
+ * Copyright (C) 2003 Red Hat, Inc.
+ * Portion Copyright © 2008 Nokia Corporation and/or its subsidiary(-ies). All rights reserved.
+ * Licensed under the Academic Free License version 2.1
+ * 
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation; either version 2 of the License, or
+ * (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ * GNU General Public License for more details.
+ * 
+ * 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
+ *
+ */
+
+#include "test.h"
+#include <stdio.h>
+#include <stdlib.h>
+#ifndef __SYMBIAN32__
+#include <dbus/dbus-string.h>
+#include <dbus/dbus-sysdeps.h>
+#include <dbus/dbus-internals.h>
+#else
+#include "dbus-string.h"
+#include "dbus-sysdeps.h"
+#include "dbus-internals.h"
+#endif //__SYMBIAN32__
+#include "selinux.h"
+
+#ifdef __SYMBIAN32__
+#include <libxml2_xmlreader.h>
+#include <libxml2_parser.h>
+#include <libxml2_globals.h>
+#include <libxml2_xmlexports.h>
+#include <libxml2_xmlmemory.h>
+
+#else
+#include <libxml/xmlreader.h>
+#include <libxml/parser.h>
+#include <libxml/globals.h>
+#include <libxml/xmlmemory.h>
+#endif
+
+
+#ifdef __SYMBIAN32__
+#define LOG_FILE "c:\\logs\\dbus_daemon_test_main_log1.txt"
+#include "std_log_result.h"
+#define LOG_FILENAME_LINE __FILE__, __LINE__
+
+void create_xml(int result)
+	{
+	if(result)
+		assert_failed = 1;
+	
+	testResultXml("dbus_daemon_test_main");
+    close_log_file();
+	}
+#endif
+
+#ifdef DBUS_BUILD_TESTS
+static void
+die (const char *failure)
+{
+  fprintf (stderr, "Unit test failed: %s\n", failure);
+  #ifdef __SYMBIAN32__
+  std_log(LOG_FILENAME_LINE, "Unit test failed: %s\n", failure);
+  
+  create_xml(1);
+  #endif
+  exit (1);
+}
+
+static void
+check_memleaks (const char *name)
+{
+  dbus_shutdown ();
+  
+  printf ("%s: checking for memleaks\n", name);
+  #ifdef __SYMBIAN32__
+  std_log(LOG_FILENAME_LINE, "%s: checking for memleaks\n", name);
+  #endif
+  if (_dbus_get_malloc_blocks_outstanding () != 0)
+    {
+      _dbus_warn ("%d dbus_malloc blocks were not freed\n",
+                  _dbus_get_malloc_blocks_outstanding ());
+		#ifdef __SYMBIAN32__
+		std_log(LOG_FILENAME_LINE, "%d dbus_malloc blocks were not freed\n",
+                  _dbus_get_malloc_blocks_outstanding ());
+		#endif
+      die ("memleaks");
+    }
+}
+#endif /* DBUS_BUILD_TESTS */
+
+static void
+test_pre_hook (void)
+{
+  
+  if (_dbus_getenv ("DBUS_TEST_SELINUX")
+      && (!bus_selinux_pre_init ()
+	  || !bus_selinux_full_init ()))
+    die ("could not init selinux support");
+}
+
+static char *progname = "";
+static void
+test_post_hook (void)
+{
+  if (_dbus_getenv ("DBUS_TEST_SELINUX"))
+    bus_selinux_shutdown ();
+  check_memleaks (progname);
+}
+
+int
+main (int argc, char **argv)
+{
+#ifdef DBUS_BUILD_TESTS
+  const char *dir;
+  DBusString test_data_dir;
+
+  progname = argv[0];
+
+  if (argc > 1)
+    dir = argv[1];
+  else
+    dir = _dbus_getenv ("DBUS_TEST_DATA");
+
+  dir = "c:\\data\\dbus";
+  
+  if (dir == NULL)
+    {
+      fprintf (stderr, "Must specify test data directory as argv[1] or in DBUS_TEST_DATA env variable\n");
+	  #ifdef __SYMBIAN32__
+	  std_log(LOG_FILENAME_LINE, "Must specify test data directory as argv[1] or in DBUS_TEST_DATA env variable\n");
+	  #endif
+      return 1;
+    }
+
+  _dbus_string_init_const (&test_data_dir, dir);
+
+  if (!_dbus_threads_init_debug ())
+    die ("initializing debug threads");
+ 
+  test_pre_hook ();
+  printf ("%s: Running expire list test\n", argv[0]);
+  #ifdef __SYMBIAN32__
+  std_log(LOG_FILENAME_LINE, "%s: Running expire list test\n", argv[0]);
+  #endif
+  if (!bus_expire_list_test (&test_data_dir))
+    die ("expire list");
+  test_post_hook ();
+ 
+  test_pre_hook ();
+  printf ("%s: Running config file parser test\n", argv[0]);
+  #ifdef __SYMBIAN32__
+  std_log(LOG_FILENAME_LINE, "%s: Running config file parser test\n", argv[0]);
+  #endif
+  if (!bus_config_parser_test (&test_data_dir))
+    die ("parser");
+  test_post_hook ();
+
+  test_pre_hook ();
+  printf ("%s: Running policy test\n", argv[0]);
+  #ifdef __SYMBIAN32__
+  std_log(LOG_FILENAME_LINE, "%s: Running policy test\n", argv[0]);
+  #endif
+  if (!bus_policy_test (&test_data_dir))
+    die ("policy");
+  test_post_hook ();
+
+  test_pre_hook ();
+  printf ("%s: Running signals test\n", argv[0]);
+  #ifdef __SYMBIAN32__
+  std_log(LOG_FILENAME_LINE, "%s: Running signals test\n", argv[0]);
+  #endif
+  if (!bus_signals_test (&test_data_dir))
+    die ("signals");
+  test_post_hook ();
+
+  test_pre_hook ();
+  printf ("%s: Running SHA1 connection test\n", argv[0]);
+  #ifdef __SYMBIAN32__
+  std_log(LOG_FILENAME_LINE, "%s: Running SHA1 connection test\n", argv[0]);
+  #endif
+  if (!bus_dispatch_sha1_test (&test_data_dir))
+    die ("sha1");
+  test_post_hook ();
+
+
+  test_pre_hook ();
+  printf ("%s: Running service files reloading test\n", argv[0]);
+  #ifdef __SYMBIAN32__
+  std_log(LOG_FILENAME_LINE, "%s: Running service files reloading test\n", argv[0]);
+  #endif
+  if (!bus_activation_service_reload_test (&test_data_dir))
+    die ("service reload");
+  test_post_hook ();
+
+  #ifdef __SYMBIAN32__
+  std_log(LOG_FILENAME_LINE, "%s: Running message dispatch test\n", argv[0]);
+  #endif
+  	
+  test_pre_hook ();
+  printf ("%s: Running message dispatch test\n", argv[0]);
+  #ifdef __SYMBIAN32__
+  std_log(LOG_FILENAME_LINE, "%s: Running message dispatch test\n", argv[0]);
+  #endif
+  if (!bus_dispatch_test (&test_data_dir)) 
+    die ("dispatch");
+  /*2 bytes of memory leak to be investigated*/
+  //test_post_hook ();	
+  printf ("%s: Success\n", argv[0]);
+  #ifdef __SYMBIAN32__
+	std_log(LOG_FILENAME_LINE, "%s: Success\n", argv[0]);
+	
+	create_xml(0);
+  #endif
+  return 0;
+#else /* DBUS_BUILD_TESTS */
+
+  printf ("Not compiled with test support\n");
+  
+  return 0;
+#endif
+}