tizen 2.3.1 release
[framework/appfw/alarm-manager.git] / TC / unit / utc_ApplicationFW_alarmmgr_set_cb_func.c
1 /*
2  *  alarm-manager
3  *
4  * Copyright (c) 2000 - 2011 Samsung Electronics Co., Ltd. All rights reserved.
5  *
6  * Contact: Venkatesha Sarpangala <sarpangala.v@samsung.com>, Jayoun Lee <airjany@samsung.com>,
7  * Sewook Park <sewook7.park@samsung.com>, Jaeho Lee <jaeho81.lee@samsung.com>
8  *
9  * Licensed under the Apache License, Version 2.0 (the "License");
10  * you may not use this file except in compliance with the License.
11  * You may obtain a copy of the License at
12  *
13  * http://www.apache.org/licenses/LICENSE-2.0
14  *
15  * Unless required by applicable law or agreed to in writing, software
16  * distributed under the License is distributed on an "AS IS" BASIS,
17  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
18  * See the License for the specific language governing permissions and
19  * limitations under the License.
20  *
21  */
22 #include <stdio.h>
23 #include <stdlib.h>
24 #include <time.h>
25 #include <tet_api.h>
26 #include <sys/types.h>
27 #include <unistd.h>
28
29 #include "alarm.h"
30
31 static void startup(void);
32 static void cleanup(void);
33
34 void (*tet_startup)(void) = startup;
35 void (*tet_cleanup)(void) = cleanup;
36
37 static void utc_ApplicationFW_alarmmgr_set_cb_func_01(void);
38 static void utc_ApplicationFW_alarmmgr_set_cb_func_02(void);
39
40 enum {
41         POSITIVE_TC_IDX = 0x01,
42         NEGATIVE_TC_IDX,
43 };
44
45 struct tet_testlist tet_testlist[] = {
46         { utc_ApplicationFW_alarmmgr_set_cb_func_01, POSITIVE_TC_IDX },
47         { utc_ApplicationFW_alarmmgr_set_cb_func_02, NEGATIVE_TC_IDX },
48         { NULL , 0 }
49 };
50
51 static int pid;
52
53 static void startup(void)
54 {
55 }
56
57 static void cleanup(void)
58 {
59 }
60
61 /* Call back function */
62
63 int callback(alarm_id_t alarm_id,void* user_param)
64 {
65         time_t current_time;
66         time(&current_time);
67
68         printf("Alarm[%d] has expired at %s\n", alarm_id, ctime(&current_time));
69
70         return 0;
71
72 }
73
74 /**
75  * @ alarmmgr_set_cb :Successfull  : return 0 : ALARMMGR_RESULT_SUCCESS
76  */
77 static void utc_ApplicationFW_alarmmgr_set_cb_func_01(void)
78 {
79         int ret_val = ALARMMGR_RESULT_SUCCESS;
80         void *user_param = NULL;
81
82         ret_val = alarmmgr_set_cb( callback, user_param);
83         if(ret_val == ALARMMGR_RESULT_SUCCESS)
84         {
85                  tet_infoline("\nAlarm Manager : call to alarmmgr_set_cb() is successful \n");
86                  tet_result(TET_PASS);
87         }
88         else
89         {
90                  tet_infoline("\nAlarm Manager : call to alarmmgr_set_cb () failed \n");
91                  tet_result(TET_FAIL);
92         }
93 }
94
95 /**
96  * @brief Negative test case of ug_init alarmmgr_set_cb()
97  */
98 static void utc_ApplicationFW_alarmmgr_set_cb_func_02(void)
99 {
100         int ret_val = ALARMMGR_RESULT_SUCCESS;
101         void *user_param = NULL;
102         
103         ret_val =alarmmgr_set_cb( NULL, user_param) ;
104         if(ret_val == ERR_ALARM_INVALID_PARAM)
105         {
106                  tet_infoline("\nAlarm Manager : call to alarmmgr_set_cb() with invalid parameter is successful \n");
107                  tet_result(TET_PASS);
108         }
109         else
110         {
111                  tet_infoline("\nAlarm Manager : call to alarmmgr_set_cb() failed \n");
112                  tet_result(TET_FAIL);
113         }
114 }