ofdbus/tsrc/nft/g_N_Messages/src/g_N_Messages.c
author hgs
Thu, 14 Oct 2010 14:15:50 +0530
changeset 72 403e7f6ed6c5
parent 0 e4d67989cc36
permissions -rw-r--r--
201041

/*
* 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 <string.h>
#include <sys/stat.h>
#include <stdio.h>
#include <stdlib.h>
#include "dbus_glib1-bindings.h"
#include <dbus/dbus-glib-bindings.h>
#include <errno.h>
#include <fcntl.h>
#include <unistd.h>
#include <pthread.h>
#include <unistd.h>


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

typedef struct{
pthread_mutex_t mutex;
pthread_cond_t cond;
DBusGProxy* proxy;
int ret; 
}threadData1;

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


static void* send_msg(void* data)
{
	GError *error;
	static int cnt = 1;
	gint in_num = 5;
	gint out_num = 0;
	FILE *fp;
		
	threadData1* thrData = (threadData1*)data;
	if(!thrData)
		return;
	
	pthread_mutex_lock(&thrData->mutex);
	
	pthread_cond_wait(&thrData->cond,  &thrData->mutex);
	 
	// send message and get a handle for a reply
	  
	  if(!com_example_DBusGlibObject1_simple_method(thrData->proxy, in_num, &out_num, &error))
		{
			thrData->ret = -2;
			return;
		}
	
	   fp = fopen("C:\\glib_messages.txt", "a+");
	   fprintf(fp, "%d\n", out_num);
	   fclose(fp);
	    
	   if(out_num == 9090)
		   {
		   thrData->ret++;
		   }
	   
	   pthread_mutex_unlock(&thrData->mutex); 
}


int main()
{
	DBusGConnection *connection;
	GError *error;
	DBusGProxy *proxy;
	gint in_num = 5; 
	gint out_num = 0;
	
	int cnt;
	pthread_t thread[MAX_THREAD];
	int thrVal[MAX_THREAD]={0};
	void* thrValPtr[MAX_THREAD];
	threadData1 thrData;
	
	for(cnt=0; cnt<MAX_THREAD; cnt++)
		thrValPtr[cnt] = (void*)&thrVal[cnt];


	
	g_type_init ();
	
	error = NULL;
	
	connection = dbus_g_bus_get (DBUS_BUS_SESSION,
	                           &error);
	
	if (connection == NULL)
	{
	  g_printerr ("Failed to open connection to bus: %s\n",
	              error->message);
	  g_error_free (error);
	  exit (1);
	}
	
	proxy = dbus_g_proxy_new_for_name (connection,
	                                 "com.example.DBusGlibObject1",
	                                 "/com/example/DBusGlibObject1",
	                                 "com.example.DBusGlibObject1");


	pthread_mutex_init(&thrData.mutex, NULL);
	pthread_cond_init(&thrData.cond, NULL);
 	thrData.ret = 0;
 	thrData.proxy = proxy;
 	


 	for(cnt=0; cnt<MAX_THREAD; cnt++)
 		pthread_create(&thread[cnt], NULL, &send_msg, &thrData);
	 
	sleep(1);  
	
	pthread_cond_broadcast(&thrData.cond);
	
	for(cnt=0; cnt<MAX_THREAD; cnt++)
		pthread_join(thread[cnt], &thrValPtr[cnt]); 
	 
	if(thrData.ret != MAX_THREAD)
	{ 
		std_log(LOG_FILENAME_LINE, " no. of threads crashed %d",(MAX_THREAD - thrData.ret));
			create_xml(1);
			return 1;
	}
	
	dbus_g_connection_unref(connection);		
	std_log(LOG_FILENAME_LINE, " Success");
	create_xml(0);
	return 0;
}