/*
* 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>
#define LOG_FILE "c:\\logs\\dbus_message_data_slot1_log1.txt"
#include "std_log_result.h"
#define LOG_FILENAME_LINE __FILE__, __LINE__
int data_free_flag = FALSE;
typedef struct
{
int num;
char* str;
}TestData;
void Free_Test_Data(void* data)
{
TestData* test_data;
test_data = (TestData*)data;
free(test_data->str);
data_free_flag = TRUE;
}
void create_xml(int result)
{
if(result)
assert_failed = 1;
testResultXml("dbus_message_data_slot1");
close_log_file();
}
int main()
{
DBusMessage* msg;
dbus_int32_t data_slot = -1;
TestData data;
TestData* data1;
DBusFreeFunction free_data;
//_LIT(KOOM, "Out of Memory");
//_LIT(KFreeFail, "Free Function is not called");
//_LIT(KDataFail, "Fail to retrieve data");
msg = dbus_message_new(DBUS_MESSAGE_TYPE_METHOD_CALL);
if(!dbus_message_allocate_data_slot(&data_slot))
{
std_log(LOG_FILENAME_LINE,"Out of Memory");
create_xml(1);
return 1;
}
data.num = 20;
data.str = (char*)malloc(data.num);
data_free_flag = FALSE;
strcpy(data.str, "CheckDBus");
free_data = Free_Test_Data;
if(!dbus_message_set_data(msg, data_slot, (void*)&data, free_data))
{
std_log(LOG_FILENAME_LINE,"Out of Memory");
create_xml(1);
return 1;
}
data1 = (TestData*)dbus_message_get_data(msg, data_slot);
if(!data1)
{
std_log(LOG_FILENAME_LINE,"Fail to retrieve data");
create_xml(1);
return 1;
}
std_log(LOG_FILENAME_LINE,"Data :: \n\tInteger value(20) = %d\n\tString value(CheckDBus) = %s", data1->num, data1->str);
data.num = 30;
data.str = (char*)malloc(data.num);
data_free_flag = FALSE;
strcpy(data.str, "CheckDBusFree");
free_data = Free_Test_Data;
if(!dbus_message_set_data(msg, data_slot, (void*)&data, free_data))
{
std_log(LOG_FILENAME_LINE,"Out of Memory");
create_xml(1);
return 1;
}
if(!data_free_flag)
{
std_log(LOG_FILENAME_LINE,"Free Function is not called");
create_xml(1);
return 1;
}
dbus_message_free_data_slot(&data_slot);
std_log(LOG_FILENAME_LINE,"Test Successful");
create_xml(0);
return 0;
}