sl@0: /* Portion Copyright © 2008 Nokia Corporation and/or its subsidiary(-ies). All rights reserved.*/ sl@0: #include sl@0: #include sl@0: #define DBUS_COMPILATION sl@0: #ifndef __SYMBIAN32__ sl@0: #include sl@0: #include sl@0: #include sl@0: #include sl@0: #include sl@0: #else sl@0: #include "dbus-internals.h" sl@0: #include "dbus-list.h" sl@0: #include "dbus-shell.h" sl@0: #include "dbus-string.h" sl@0: #include "dbus-sysdeps.h" sl@0: #endif //__SYMBAIN32__ sl@0: #include sl@0: sl@0: #define LOG_FILE "c:\\logs\\shell_test_log1.txt" sl@0: #include "std_log_result.h" sl@0: #define LOG_FILENAME_LINE __FILE__, __LINE__ sl@0: sl@0: void create_xml(int result) sl@0: { sl@0: if(result) sl@0: assert_failed = 1; sl@0: sl@0: testResultXml("shell_test"); sl@0: close_log_file(); sl@0: } sl@0: sl@0: sl@0: static dbus_bool_t sl@0: test_command_line (const char *arg1, ...) sl@0: { sl@0: int i, original_argc, shell_argc; sl@0: char **shell_argv; sl@0: char **original_argv; sl@0: char *command_line, *tmp; sl@0: DBusString str; sl@0: DBusList *list = NULL, *node; sl@0: va_list var_args; sl@0: DBusError error; sl@0: sl@0: va_start (var_args, arg1); sl@0: _dbus_list_append (&list, (char *)arg1); sl@0: do sl@0: { sl@0: tmp = va_arg (var_args, char *); sl@0: if (!tmp) sl@0: break; sl@0: _dbus_list_append (&list, tmp); sl@0: } while (tmp); sl@0: va_end (var_args); sl@0: sl@0: original_argc = _dbus_list_get_length (&list); sl@0: original_argv = dbus_new (char *, original_argc); sl@0: _dbus_string_init (&str); sl@0: for (i = 0, node = _dbus_list_get_first_link (&list); i < original_argc && node; sl@0: i++, node = _dbus_list_get_next_link (&list, node)) sl@0: { sl@0: original_argv[i] = node->data; sl@0: if (i > 0) sl@0: _dbus_string_append_byte (&str, ' '); sl@0: _dbus_string_append (&str, original_argv[i]); sl@0: } sl@0: sl@0: _dbus_list_clear (&list); sl@0: command_line = _dbus_string_get_data (&str); sl@0: printf ("\n\nTesting command line '%s'\n", command_line); sl@0: std_log(LOG_FILENAME_LINE, "\n\nTesting command line '%s'\n", command_line); sl@0: sl@0: dbus_error_init (&error); sl@0: if (!_dbus_shell_parse_argv (command_line, &shell_argc, &shell_argv, &error)) sl@0: { sl@0: fprintf (stderr, "Error parsing command line: %s\n", error.message ? error.message : ""); sl@0: std_log(LOG_FILENAME_LINE, "Error parsing command line: %s\n", error.message ? error.message : ""); sl@0: return FALSE; sl@0: } sl@0: else sl@0: { sl@0: if (shell_argc != original_argc) sl@0: { sl@0: printf ("Number of arguments returned (%d) don't match original (%d)\n", sl@0: shell_argc, original_argc); sl@0: std_log(LOG_FILENAME_LINE, "Number of arguments returned (%d) don't match original (%d)\n", sl@0: shell_argc, original_argc); sl@0: return FALSE; sl@0: } sl@0: printf ("Number of arguments: %d\n", shell_argc); sl@0: std_log(LOG_FILENAME_LINE, "Number of arguments: %d\n", shell_argc); sl@0: for (i = 0; i < shell_argc; i++) sl@0: { sl@0: char *unquoted; sl@0: sl@0: unquoted = _dbus_shell_unquote (original_argv[i]); sl@0: if (strcmp (unquoted ? unquoted : "", sl@0: shell_argv[i] ? shell_argv[i] : "")) sl@0: { sl@0: printf ("Position %d, returned argument (%s) does not match original (%s)\n", sl@0: i, shell_argv[i], unquoted); sl@0: std_log(LOG_FILENAME_LINE, "Position %d, returned argument (%s) does not match original (%s)\n", sl@0: i, shell_argv[i], unquoted); sl@0: dbus_free (unquoted); sl@0: return FALSE; sl@0: } sl@0: dbus_free (unquoted); sl@0: if (shell_argv[i]) sl@0: { sl@0: printf ("Argument %d = %s\n", i, shell_argv[i]); sl@0: std_log(LOG_FILENAME_LINE, "Argument %d = %s\n", i, shell_argv[i]); sl@0: } sl@0: } sl@0: sl@0: dbus_free_string_array (shell_argv); sl@0: } sl@0: sl@0: _dbus_string_free (&str); sl@0: sl@0: return TRUE; sl@0: } sl@0: sl@0: int sl@0: main () sl@0: { sl@0: if (!test_command_line ("command", "-s", "--force-shutdown", "\"a string\"", "123", NULL) sl@0: || !test_command_line ("command", "-s", NULL) sl@0: || !test_command_line ("/opt/gnome/bin/service-start", NULL) sl@0: || !test_command_line ("grep", "-l", "-r", "-i", "'whatever'", "files*.c", NULL) sl@0: || !test_command_line ("/home/boston/johnp/devel-local/dbus/test/test-segfault", NULL) sl@0: || !test_command_line ("ls", "-l", "-a", "--colors", _dbus_get_tmpdir(), NULL) sl@0: || !test_command_line ("rsync-to-server", NULL) sl@0: || !test_command_line ("test-segfault", "--no-segfault", NULL) sl@0: || !test_command_line ("evolution", "mailto:pepe@cuco.com", NULL) sl@0: || !test_command_line ("run", "\"a \n multiline\"", NULL) sl@0: || test_command_line ("ls", "\"a wrong string'", NULL) /* invalid command line */ ) sl@0: { sl@0: create_xml(1); sl@0: return -1; sl@0: } sl@0: sl@0: std_log(LOG_FILENAME_LINE, "Test Successful."); sl@0: create_xml(0); sl@0: return 0; sl@0: }