ofdbus/dbus/tsrc/testapps/exes1/src/dbus_bus_request_name0.c
author William Roberts <williamr@symbian.org>
Thu, 22 Jul 2010 16:48:56 +0100
branchGCC_SURGE
changeset 45 4b03adbd26ca
parent 18 47c74d1534e1
parent 31 ce057bb09d0b
permissions -rw-r--r--
Catchup to latest Symbian^4

/*
* Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies).
* All rights reserved.
* This component and the accompanying materials are made available
* under the terms of "Eclipse Public License v1.0"
* which accompanies this distribution, and is available
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
*
* Initial Contributors:
* Nokia Corporation - initial contribution.
*
* Contributors:
*
* Description: 
*
*/


#include<stdio.h> 
#include <dbus/dbus.h>
#include <stdlib.h>
#include <string.h>
#include <fcntl.h>
#include <unistd.h>
#include <sys/stat.h>

#define LOG_FILE "c:\\logs\\dbus_bus_request_name0_log1.txt"
#include "std_log_result.h"
#define LOG_FILENAME_LINE __FILE__, __LINE__

int CheckConnection(DBusConnection* conn, DBusError* error)
	{
		if(!conn)
		{
			std_log(LOG_FILENAME_LINE,"Failed to get connection with error :: %s\n%s", error->name, error->message);
	    	
	    	dbus_error_free(error);
	    	return FALSE;
		}
		
		return TRUE;
	}

void create_xml(int result)
{
	if(result)
		assert_failed = 1;
	
	testResultXml("dbus_bus_request_name0");
	close_log_file();
}

int main()
{

	DBusConnection* connection;
	DBusError error;
	DBusError error1;
	int result;

	FILE* fp;
	char buf[20];
	const char* fifopath = "C:\\mkfifo2.file";
	int err;
	int fd;
	
	dbus_error_init(&error);
	dbus_error_init(&error1);
	connection = dbus_bus_get_private(DBUS_BUS_SESSION, &error);
	if(!CheckConnection(connection, &error))
	{
		std_log(LOG_FILENAME_LINE,"Failed to Open the connection with Error :: %s", error.name);
		std_log(LOG_FILENAME_LINE,"Test Fail");
		create_xml(1);
		return 1;
	}
	
	result = dbus_bus_request_name(connection, "Test.Method.Call", DBUS_NAME_FLAG_ALLOW_REPLACEMENT, &error1);
	if(result == -1)
		std_log(LOG_FILENAME_LINE,"Error Set :: %s\n%s", error1.name,error1.message);
	if(result != DBUS_REQUEST_NAME_REPLY_PRIMARY_OWNER )
	{
		std_log(LOG_FILENAME_LINE,"Test Fail");
		create_xml(1);
		return 1;
	}
		
	result = dbus_bus_request_name(connection, "Test.Method.Call2", DBUS_NAME_FLAG_REPLACE_EXISTING, &error1);
	if(result == -1)
		std_log(LOG_FILENAME_LINE,"Error Set :: %s\n%s", error1.name,error1.message);
	if(result != DBUS_REQUEST_NAME_REPLY_PRIMARY_OWNER )
	{
		std_log(LOG_FILENAME_LINE,"Test Fail");
		create_xml(1);
		return 1;
	}
	
	result = dbus_bus_request_name(connection, "Test.Method.Call2", DBUS_NAME_FLAG_REPLACE_EXISTING, &error1);
	if(result == -1)
		std_log(LOG_FILENAME_LINE,"Error Set :: %s\n%s", error1.name,error1.message);
	if(result != DBUS_REQUEST_NAME_REPLY_ALREADY_OWNER )
	{
		std_log(LOG_FILENAME_LINE,"Test Fail");
		create_xml(1);
		return 1;
	}
	
	//for FIFO
	
	err = mkfifo (fifopath, 0666);
	   if(err != 0)
	   {
	       // probably file already exists, delete the file
	       unlink(fifopath); 
	       // try once more..
	       err = mkfifo (fifopath, 0666);
	       if(err != 0)
	       {
				return 1;
	       }
	   }
	
#if defined(__WINSCW__) || defined(__WINS__)
	fp = popen("z:\\sys\\bin\\request_name.exe","r");
#else
	fp = popen("c:\\sys\\bin\\request_name.exe","r");
#endif
	if(!fp)
		{
		std_log(LOG_FILENAME_LINE,"fp is NULL.");
		create_xml(1);
		return 1;
		}	

	fd = open(fifopath, O_RDONLY);
	if(fd > 0)
	{
		err = read (fd, buf, 20); 
		if(!strcmp("Error Occured", buf))
			{
			std_log(LOG_FILENAME_LINE,"Error while requesting name in request_name.exe.");
			create_xml(1);
			return 1;
			}
		close(fd);
	}
	else
		{
		std_log(LOG_FILENAME_LINE,"Error in FIFO open().");
		create_xml(1);
		return 1;
		}
	unlink(fifopath);
	if(strcmp("done", buf))
	{
	create_xml(1);
	return 1;
	}
	result = dbus_bus_request_name(connection, "Test.Method.Call3", DBUS_NAME_FLAG_DO_NOT_QUEUE , &error1);
	if(result == -1)
		std_log(LOG_FILENAME_LINE,"Error Set :: %s\n%s", error1.name,error1.message);
	if(result != DBUS_REQUEST_NAME_REPLY_EXISTS )
	{
		std_log(LOG_FILENAME_LINE,"Test Fail");
		create_xml(1);
		return 1;
	}	
	
	dbus_connection_close(connection);
	dbus_connection_unref(connection);
	dbus_shutdown();
	
	std_log(LOG_FILENAME_LINE,"Test Successful");
	create_xml(0);
	return 0;

}