3 * oFono - Open Source Telephony
5 * Copyright (C) 2008-2011 Intel Corporation. All rights reserved.
7 * This program is free software; you can redistribute it and/or modify
8 * it under the terms of the GNU General Public License version 2 as
9 * published by the Free Software Foundation.
11 * This program is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU General Public License for more details.
16 * You should have received a copy of the GNU General Public License
17 * along with this program; if not, write to the Free Software
18 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
33 #include <netinet/in.h>
34 #include <arpa/inet.h>
37 #include <gatchat/gatserver.h>
39 #include "unit/stk-test-data.h"
41 #define OFONO_SERVICE "org.ofono"
42 #define STKTEST_PATH "/stktest"
43 #define STKTEST_ERROR "org.ofono.stktest.Error"
44 #define OFONO_ERROR "org.ofono.Error"
45 #define OFONO_MANAGER_INTERFACE OFONO_SERVICE ".Manager"
46 #define OFONO_MODEM_INTERFACE OFONO_SERVICE ".Modem"
47 #define OFONO_STK_INTERFACE OFONO_SERVICE ".SimToolkit"
48 #define OFONO_STKAGENT_INTERFACE OFONO_SERVICE ".SimToolkitAgent"
50 #define LISTEN_PORT 12765
53 TEST_STATE_POWERING_UP = 1,
54 TEST_STATE_REGISTERING_AGENT,
56 TEST_STATE_POWERING_DOWN,
60 TEST_RESULT_NOT_RUN = 0,
65 typedef DBusMessage *(*display_text_cb_t)(DBusMessage *msg, const char *text,
66 unsigned char icon_id,
68 typedef DBusMessage *(*get_inkey_cb_t)(DBusMessage *msg, const char *alpha,
69 unsigned char icon_id);
70 typedef DBusMessage *(*get_input_cb_t)(DBusMessage *msg, const char *alpha,
71 unsigned char icon_id,
72 const char *def_input,
73 unsigned char min_chars,
74 unsigned char max_chars,
75 gboolean hide_typing);
76 typedef void (*terminal_response_func)(const unsigned char *pdu,
82 unsigned char *req_pdu;
84 unsigned char *rsp_pdu;
87 terminal_response_func tr_func;
88 enum test_result result;
91 static GMainLoop *main_loop = NULL;
92 static volatile sig_atomic_t __terminated = 0;
93 static GList *tests = NULL;
94 static GList *cur_test = NULL;
97 static DBusConnection *conn;
98 static gboolean ofono_running = FALSE;
99 static guint modem_changed_watch;
100 static enum test_state state;
101 static DBusMessage *pending = NULL;
104 static guint server_watch;
105 static GAtServer *emulator;
107 /* Emulated modem state variables */
108 static int modem_mode = 0;
110 void __stktest_test_next();
111 void __stktest_test_finish(gboolean successful);
112 static gboolean create_tcp(void);
114 #define STKTEST_AGENT_ASSERT(expr) \
117 g_printerr("Assertion Failed %s:%d %s\n", \
118 __FILE__, __LINE__, #expr); \
119 __stktest_test_finish(FALSE); \
120 return stktest_error_failed(msg); \
124 #define STKTEST_RESPONSE_ASSERT(expect_pdu, expect_pdu_len, \
125 got_pdu, got_pdu_len) \
127 if ((expect_pdu_len) != (got_pdu_len)) { \
128 g_printerr("Assertion Failed %s:%d" \
129 " Wrong response len" \
130 " want: %d, got: %d\n", \
131 __FILE__, __LINE__, \
132 expect_pdu_len, got_pdu_len); \
133 __stktest_test_finish(FALSE); \
137 if (memcmp(expect_pdu, got_pdu, expect_pdu_len) != 0) { \
138 g_printerr("Assertion Failed %s:%d" \
139 "Wrong response\n", \
140 __FILE__, __LINE__); \
141 __stktest_test_finish(FALSE); \
146 static const char *to_hex(const unsigned char *data, unsigned int len)
148 static char buf[512+1];
151 for (i = 0; i < len; i++)
152 sprintf(buf + i * 2, "%02hhX", data[i]);
159 static void send_proactive_command(const unsigned char *pdu, unsigned int len)
163 sprintf(buf, "+CUSATP: %s", to_hex(pdu, len));
164 g_at_server_send_unsolicited(emulator, buf);
167 static DBusMessage *stktest_error_invalid_args(DBusMessage *msg)
169 return g_dbus_create_error(msg, STKTEST_ERROR ".InvalidArguments",
170 "Invalid arguments provided");
173 static DBusMessage *stktest_error_failed(DBusMessage *msg)
175 return g_dbus_create_error(msg, STKTEST_ERROR ".Failed",
179 static DBusMessage *stktest_error_end_session(DBusMessage *msg)
181 return g_dbus_create_error(msg, OFONO_ERROR ".EndSession",
182 "End Session Request");
185 static DBusMessage *stktest_error_go_back(DBusMessage *msg)
187 return g_dbus_create_error(msg, OFONO_ERROR ".GoBack",
191 static DBusMessage *stktest_error_busy(DBusMessage *msg)
193 return g_dbus_create_error(msg, OFONO_ERROR ".Busy",
197 static DBusMessage *agent_release(DBusConnection *conn, DBusMessage *msg,
200 g_print("Got Release\n");
203 dbus_message_unref(pending);
207 return dbus_message_new_method_return(msg);
210 static DBusMessage *agent_cancel(DBusConnection *conn, DBusMessage *msg,
214 dbus_message_unref(pending);
221 static DBusMessage *agent_display_text(DBusConnection *conn, DBusMessage *msg,
225 unsigned char icon_id;
228 display_text_cb_t func;
231 if (dbus_message_get_args(msg, NULL, DBUS_TYPE_STRING, &text,
232 DBUS_TYPE_BYTE, &icon_id,
233 DBUS_TYPE_BOOLEAN, &urgent,
234 DBUS_TYPE_INVALID) == FALSE)
235 return stktest_error_invalid_args(msg);
237 if (cur_test == NULL)
238 return stktest_error_failed(msg);
240 test = cur_test->data;
241 func = test->agent_func;
243 if (strcmp(test->method, "DisplayText")) {
244 g_printerr("Wrong method called!\n");
245 __stktest_test_finish(FALSE);
246 return stktest_error_failed(msg);
250 g_printerr("DisplayText not expected to be called");
251 __stktest_test_finish(FALSE);
252 return stktest_error_failed(msg);
255 reply = func(msg, text, icon_id, urgent);
257 pending = dbus_message_ref(msg);
262 #define GET_INKEY_TEMPLATE(func, method_name) \
263 static DBusMessage *func(DBusConnection *conn, DBusMessage *msg, \
267 unsigned char icon_id; \
269 get_inkey_cb_t func; \
270 DBusMessage *reply; \
272 if (dbus_message_get_args(msg, NULL, DBUS_TYPE_STRING, &alpha, \
273 DBUS_TYPE_BYTE, &icon_id, \
274 DBUS_TYPE_INVALID) == FALSE) \
275 return stktest_error_invalid_args(msg); \
277 if (cur_test == NULL) \
278 return stktest_error_failed(msg); \
280 test = cur_test->data; \
281 func = test->agent_func; \
283 if (strcmp(test->method, method_name)) { \
284 g_printerr("Wrong method called!\n"); \
285 __stktest_test_finish(FALSE); \
286 return stktest_error_failed(msg); \
289 if (func == NULL) { \
290 g_printerr(method_name " not expected to be called"); \
291 __stktest_test_finish(FALSE); \
292 return stktest_error_failed(msg); \
295 reply = func(msg, alpha, icon_id); \
297 pending = dbus_message_ref(msg); \
302 GET_INKEY_TEMPLATE(agent_request_key, "RequestKey")
303 GET_INKEY_TEMPLATE(agent_request_digit, "RequestDigit")
304 GET_INKEY_TEMPLATE(agent_request_confirmation, "RequestConfirmation")
306 #define GET_INPUT_TEMPLATE(func, method_name) \
307 static DBusMessage *func(DBusConnection *conn, DBusMessage *msg, \
311 const char *def_input; \
312 unsigned char icon_id; \
313 unsigned char min_chars; \
314 unsigned char max_chars; \
315 gboolean hide_typing; \
317 get_input_cb_t func; \
318 DBusMessage *reply; \
320 if (dbus_message_get_args(msg, NULL, DBUS_TYPE_STRING, &alpha, \
321 DBUS_TYPE_BYTE, &icon_id, \
322 DBUS_TYPE_STRING, &def_input, \
323 DBUS_TYPE_BYTE, &min_chars, \
324 DBUS_TYPE_BYTE, &max_chars, \
327 DBUS_TYPE_INVALID) == FALSE) \
328 return stktest_error_invalid_args(msg); \
330 if (cur_test == NULL) \
331 return stktest_error_failed(msg); \
333 test = cur_test->data; \
334 func = test->agent_func; \
336 if (strcmp(test->method, method_name)) { \
337 g_printerr("Wrong method called!\n"); \
338 __stktest_test_finish(FALSE); \
339 return stktest_error_failed(msg); \
342 if (func == NULL) { \
343 g_printerr(method_name " not expected to be called"); \
344 __stktest_test_finish(FALSE); \
345 return stktest_error_failed(msg); \
348 reply = func(msg, alpha, icon_id, def_input, \
349 min_chars, max_chars, hide_typing); \
351 pending = dbus_message_ref(msg); \
356 GET_INPUT_TEMPLATE(agent_request_input, "RequestInput")
357 GET_INPUT_TEMPLATE(agent_request_digits, "RequestDigits")
359 static void server_debug(const char *str, void *data)
361 g_print("%s: %s\n", (char *) data, str);
364 static void cgmi_cb(GAtServer *server, GAtServerRequestType type,
365 GAtResult *cmd, gpointer user)
368 case G_AT_SERVER_REQUEST_TYPE_COMMAND_ONLY:
369 g_at_server_send_info(server, "oFono", TRUE);
370 g_at_server_send_final(server, G_AT_SERVER_RESULT_OK);
372 case G_AT_SERVER_REQUEST_TYPE_SUPPORT:
373 g_at_server_send_final(server, G_AT_SERVER_RESULT_OK);
376 g_at_server_send_final(server, G_AT_SERVER_RESULT_ERROR);
380 static void cgmm_cb(GAtServer *server, GAtServerRequestType type,
381 GAtResult *cmd, gpointer user)
384 case G_AT_SERVER_REQUEST_TYPE_COMMAND_ONLY:
385 g_at_server_send_info(server, "oFono pre-1.0", TRUE);
386 g_at_server_send_final(server, G_AT_SERVER_RESULT_OK);
388 case G_AT_SERVER_REQUEST_TYPE_SUPPORT:
389 g_at_server_send_final(server, G_AT_SERVER_RESULT_OK);
392 g_at_server_send_final(server, G_AT_SERVER_RESULT_ERROR);
396 static void cgmr_cb(GAtServer *server, GAtServerRequestType type,
397 GAtResult *cmd, gpointer user)
402 case G_AT_SERVER_REQUEST_TYPE_COMMAND_ONLY:
403 sprintf(buf, "oFono pre-1.0 version: %s", VERSION);
404 g_at_server_send_info(server, buf, TRUE);
405 g_at_server_send_final(server, G_AT_SERVER_RESULT_OK);
407 case G_AT_SERVER_REQUEST_TYPE_SUPPORT:
408 g_at_server_send_final(server, G_AT_SERVER_RESULT_OK);
411 g_at_server_send_final(server, G_AT_SERVER_RESULT_ERROR);
415 static void cgsn_cb(GAtServer *server, GAtServerRequestType type,
416 GAtResult *cmd, gpointer user)
419 case G_AT_SERVER_REQUEST_TYPE_COMMAND_ONLY:
420 g_at_server_send_info(server, "123456789", TRUE);
421 g_at_server_send_final(server, G_AT_SERVER_RESULT_OK);
423 case G_AT_SERVER_REQUEST_TYPE_SUPPORT:
424 g_at_server_send_final(server, G_AT_SERVER_RESULT_OK);
427 g_at_server_send_final(server, G_AT_SERVER_RESULT_ERROR);
431 static gboolean send_ok(gpointer user)
433 GAtServer *server = user;
435 g_at_server_send_final(server, G_AT_SERVER_RESULT_OK);
440 static void cfun_cb(GAtServer *server, GAtServerRequestType type,
441 GAtResult *cmd, gpointer user)
446 case G_AT_SERVER_REQUEST_TYPE_SUPPORT:
447 g_at_server_send_info(server, "+CFUN: (0-1,4)", TRUE);
448 g_at_server_send_final(server, G_AT_SERVER_RESULT_OK);
450 case G_AT_SERVER_REQUEST_TYPE_QUERY:
451 snprintf(buf, sizeof(buf), "+CFUN: %d", modem_mode);
452 g_at_server_send_info(server, buf, TRUE);
453 g_at_server_send_final(server, G_AT_SERVER_RESULT_OK);
455 case G_AT_SERVER_REQUEST_TYPE_SET:
460 g_at_result_iter_init(&iter, cmd);
461 g_at_result_iter_next(&iter, "");
463 if (g_at_result_iter_next_number(&iter, &mode) == FALSE)
466 if (mode != 0 && mode != 1)
469 if (modem_mode == mode) {
470 g_at_server_send_final(server, G_AT_SERVER_RESULT_OK);
475 g_timeout_add_seconds(1, send_ok, server);
485 g_at_server_send_final(server, G_AT_SERVER_RESULT_ERROR);
488 static void cusatt_cb(GAtServer *server, GAtServerRequestType type,
489 GAtResult *cmd, gpointer user)
492 case G_AT_SERVER_REQUEST_TYPE_SUPPORT:
493 g_at_server_send_final(server, G_AT_SERVER_RESULT_OK);
495 case G_AT_SERVER_REQUEST_TYPE_QUERY:
496 g_at_server_send_ext_final(server, "+CME ERROR: 4");
498 case G_AT_SERVER_REQUEST_TYPE_SET:
501 const unsigned char *pdu;
504 terminal_response_func func;
506 g_at_result_iter_init(&iter, cmd);
507 g_at_result_iter_next(&iter, "");
509 if (g_at_result_iter_next_hexstring(&iter, &pdu, &len) == FALSE)
512 if (cur_test == NULL)
515 g_at_server_send_final(server, G_AT_SERVER_RESULT_OK);
517 test = cur_test->data;
518 func = test->tr_func;
529 g_at_server_send_final(server, G_AT_SERVER_RESULT_ERROR);
532 static void listen_again(gpointer user_data)
534 g_at_server_unref(emulator);
537 if (create_tcp() == TRUE)
540 g_print("Error listening to socket\n");
541 g_main_loop_quit(main_loop);
544 static void setup_emulator(GAtServer *server)
546 g_at_server_set_debug(server, server_debug, "Server");
548 g_at_server_register(server, "+CGMI", cgmi_cb, NULL, NULL);
549 g_at_server_register(server, "+CGMM", cgmm_cb, NULL, NULL);
550 g_at_server_register(server, "+CGMR", cgmr_cb, NULL, NULL);
551 g_at_server_register(server, "+CGSN", cgsn_cb, NULL, NULL);
552 g_at_server_register(server, "+CFUN", cfun_cb, NULL, NULL);
553 g_at_server_register(server, "+CUSATT", cusatt_cb, NULL, NULL);
555 g_at_server_set_disconnect_function(server, listen_again, NULL);
558 static gboolean on_socket_connected(GIOChannel *chan, GIOCondition cond,
561 struct sockaddr saddr;
562 unsigned int len = sizeof(saddr);
564 GIOChannel *client_io = NULL;
569 fd = accept(g_io_channel_unix_get_fd(chan), &saddr, &len);
573 client_io = g_io_channel_unix_new(fd);
575 emulator = g_at_server_new(client_io);
576 g_at_server_set_echo(emulator, FALSE);
577 g_io_channel_unref(client_io);
579 if (emulator == NULL)
582 setup_emulator(emulator);
589 static gboolean create_tcp(void)
591 struct sockaddr_in addr;
594 GIOChannel *server_io;
596 sk = socket(PF_INET, SOCK_STREAM, 0);
598 g_print("Can't create tcp/ip socket: %s (%d)\n",
599 strerror(errno), errno);
603 memset(&addr, 0, sizeof(addr));
605 addr.sin_family = AF_INET;
606 addr.sin_addr.s_addr = INADDR_ANY;
607 addr.sin_port = htons(LISTEN_PORT);
609 setsockopt(sk, SOL_SOCKET, SO_REUSEADDR, &reuseaddr, sizeof(reuseaddr));
610 if (bind(sk, (struct sockaddr *) &addr, sizeof(struct sockaddr)) < 0) {
611 g_print("Can't bind socket: %s (%d)", strerror(errno), errno);
616 if (listen(sk, 1) < 0) {
617 g_print("Can't listen on socket: %s (%d)",
618 strerror(errno), errno);
623 g_print("new tcp is created at tcp port %d\n", LISTEN_PORT);
625 server_io = g_io_channel_unix_new(sk);
626 g_io_channel_set_close_on_unref(server_io, TRUE);
628 server_watch = g_io_add_watch_full(server_io,
630 G_IO_IN | G_IO_HUP | G_IO_ERR | G_IO_NVAL,
631 on_socket_connected, NULL, NULL);
633 g_io_channel_unref(server_io);
638 static gboolean has_stk_interface(DBusMessageIter *iter)
640 DBusMessageIter entry;
642 dbus_message_iter_recurse(iter, &entry);
644 while (dbus_message_iter_get_arg_type(&entry) == DBUS_TYPE_STRING) {
645 const char *interface;
647 dbus_message_iter_get_basic(&entry, &interface);
649 if (g_str_equal(interface, OFONO_STK_INTERFACE) == TRUE)
652 dbus_message_iter_next(&entry);
658 static int send_with_reply(const char *path, const char *interface,
659 const char *method, DBusPendingCall **call,
660 DBusPendingCallNotifyFunction cb,
661 void *user_data, DBusFreeFunction free_func,
662 int timeout, int type, ...)
669 msg = dbus_message_new_method_call(OFONO_SERVICE, path,
672 g_printerr("Unable to allocate new D-Bus %s message\n", method);
677 va_start(args, type);
679 if (!dbus_message_append_args_valist(msg, type, args)) {
690 if (!dbus_connection_send_with_reply(conn, msg, &c, timeout)) {
691 g_printerr("Sending %s failed\n", method);
699 dbus_pending_call_set_notify(c, cb, user_data, free_func);
700 dbus_pending_call_unref(c);
702 dbus_message_unref(msg);
707 if (free_func && user_data)
708 free_func(user_data);
711 dbus_message_unref(msg);
716 static void set_property_reply(DBusPendingCall *call, void *user_data)
718 DBusMessage *reply = dbus_pending_call_steal_reply(call);
721 dbus_error_init(&err);
723 if (dbus_set_error_from_message(&err, reply) == TRUE) {
724 g_printerr("%s: %s\n", err.name, err.message);
725 dbus_error_free(&err);
728 dbus_message_unref(reply);
731 static int set_property(const char *path, const char *interface,
732 const char *key, int type, const void *val,
733 DBusPendingCallNotifyFunction notify,
735 DBusFreeFunction destroy)
738 DBusMessageIter iter, value;
739 DBusPendingCall *call;
740 const char *signature;
742 msg = dbus_message_new_method_call(OFONO_SERVICE, path, interface,
747 dbus_message_set_auto_start(msg, FALSE);
749 dbus_message_iter_init_append(msg, &iter);
751 dbus_message_iter_append_basic(&iter, DBUS_TYPE_STRING, &key);
754 case DBUS_TYPE_BOOLEAN:
755 signature = DBUS_TYPE_BOOLEAN_AS_STRING;
758 dbus_message_unref(msg);
762 dbus_message_iter_open_container(&iter, DBUS_TYPE_VARIANT,
764 dbus_message_iter_append_basic(&value, type, val);
765 dbus_message_iter_close_container(&iter, &value);
767 if (dbus_connection_send_with_reply(conn, msg, &call, -1) == FALSE) {
768 dbus_message_unref(msg);
772 dbus_message_unref(msg);
777 dbus_pending_call_set_notify(call, notify, user_data, destroy);
779 dbus_pending_call_unref(call);
784 static void register_agent_reply(DBusPendingCall *call, void *user_data)
786 DBusMessage *reply = dbus_pending_call_steal_reply(call);
790 dbus_error_init(&err);
792 if (dbus_set_error_from_message(&err, reply) == TRUE) {
793 g_printerr("%s: %s\n", err.name, err.message);
794 dbus_error_free(&err);
797 dbus_message_unref(reply);
799 state = TEST_STATE_RUNNING;
800 test = cur_test->data;
801 send_proactive_command(test->req_pdu, test->req_len);
804 static void register_agent()
806 const char *path = "/default";
809 g_print("Gained STK interface, registering agent...\n");
811 status = send_with_reply(STKTEST_PATH, OFONO_STK_INTERFACE,
812 "RegisterAgent", NULL,
813 register_agent_reply, NULL, NULL, 1,
814 DBUS_TYPE_OBJECT_PATH, &path,
818 g_printerr("Unable to register agent with oFono\n");
819 g_main_loop_quit(main_loop);
823 state = TEST_STATE_REGISTERING_AGENT;
826 static gboolean modem_changed(DBusConnection *conn,
827 DBusMessage *msg, void *user_data)
829 DBusMessageIter iter, value;
830 const char *path, *key;
833 if (dbus_message_iter_init(msg, &iter) == FALSE)
836 path = dbus_message_get_path(msg);
838 if (g_str_equal(STKTEST_PATH, path) == FALSE)
841 dbus_message_iter_get_basic(&iter, &key);
843 dbus_message_iter_next(&iter);
844 dbus_message_iter_recurse(&iter, &value);
846 if (g_str_equal(key, "Interfaces") == FALSE)
849 has_stk = has_stk_interface(&value);
852 case TEST_STATE_POWERING_UP:
856 case TEST_STATE_REGISTERING_AGENT:
857 case TEST_STATE_RUNNING:
858 if (has_stk == FALSE)
859 g_printerr("Unexpectedly lost STK interface\n");
861 case TEST_STATE_POWERING_DOWN:
868 static void powerup(void)
870 dbus_bool_t powered = TRUE;
872 state = TEST_STATE_POWERING_UP;
873 set_property(STKTEST_PATH, OFONO_MODEM_INTERFACE, "Powered",
874 DBUS_TYPE_BOOLEAN, &powered,
875 set_property_reply, NULL, NULL);
878 static void get_modems_reply(DBusPendingCall *call, void *user_data)
880 DBusMessage *reply = dbus_pending_call_steal_reply(call);
881 DBusMessageIter iter, list;
883 gboolean found = FALSE;
885 dbus_error_init(&err);
887 if (dbus_set_error_from_message(&err, reply) == TRUE) {
888 g_printerr("%s: %s\n", err.name, err.message);
889 dbus_error_free(&err);
893 if (dbus_message_has_signature(reply, "a(oa{sv})") == FALSE)
896 if (dbus_message_iter_init(reply, &iter) == FALSE)
899 dbus_message_iter_recurse(&iter, &list);
901 while (dbus_message_iter_get_arg_type(&list) == DBUS_TYPE_STRUCT) {
902 DBusMessageIter entry;
905 dbus_message_iter_recurse(&list, &entry);
906 dbus_message_iter_get_basic(&entry, &path);
908 if (g_str_equal(path, STKTEST_PATH))
911 dbus_message_iter_next(&list);
915 dbus_message_unref(reply);
917 if (found == FALSE) {
918 g_printerr("STK Test modem not found\n");
919 g_main_loop_quit(main_loop);
923 g_print("Test modem found\n");
925 modem_changed_watch = g_dbus_add_signal_watch(conn, OFONO_SERVICE,
927 OFONO_MODEM_INTERFACE,
932 if (create_tcp() == FALSE) {
933 g_printerr("Unable to listen on modem emulator socket\n");
934 g_main_loop_quit(main_loop);
937 __stktest_test_next();
940 static int get_modems(DBusConnection *conn)
943 DBusPendingCall *call;
945 msg = dbus_message_new_method_call(OFONO_SERVICE, "/",
946 OFONO_MANAGER_INTERFACE, "GetModems");
950 dbus_message_set_auto_start(msg, FALSE);
952 g_print("getting modems\n");
954 if (dbus_connection_send_with_reply(conn, msg, &call, -1) == FALSE) {
955 dbus_message_unref(msg);
959 dbus_message_unref(msg);
964 dbus_pending_call_set_notify(call, get_modems_reply, conn, NULL);
966 dbus_pending_call_unref(call);
971 static const GDBusMethodTable agent_methods[] = {
972 { GDBUS_METHOD("Release", NULL, NULL, agent_release) },
973 { GDBUS_ASYNC_METHOD("DisplayText",
974 GDBUS_ARGS({ "text", "s" }, { "icon_id", "y" },
975 { "urgent", "b" }), NULL,
976 agent_display_text) },
977 { GDBUS_ASYNC_METHOD("RequestDigit",
978 GDBUS_ARGS({ "alpha", "s" }, { "icon_id", "y" }),
979 GDBUS_ARGS({ "digit", "s" }),
980 agent_request_digit) },
981 { GDBUS_ASYNC_METHOD("RequestKey",
982 GDBUS_ARGS({ "alpha", "s" }, { "icon_id", "y" }),
983 GDBUS_ARGS({ "key", "s" }),
984 agent_request_key) },
985 { GDBUS_ASYNC_METHOD("RequestConfirmation",
986 GDBUS_ARGS({ "alpha", "s" }, { "icon_id", "y" }),
987 GDBUS_ARGS({ "confirmation", "b" }),
988 agent_request_confirmation) },
989 { GDBUS_ASYNC_METHOD("RequestInput",
990 GDBUS_ARGS({ "alpha", "s" }, { "icon_id", "y" },
991 { "default", "s" }, { "min_chars", "y" },
992 { "max_chars", "y" }, { "hide_typing", "b" }),
993 GDBUS_ARGS({ "input", "s" }), agent_request_input) },
994 { GDBUS_ASYNC_METHOD("RequestDigits",
995 GDBUS_ARGS({ "alpha", "s" }, { "icon_id", "y" },
996 { "default", "s" }, { "min_chars", "y" },
997 { "max_chars", "y" }, { "hide_typing", "b" }),
998 GDBUS_ARGS({ "digits", "s" }), agent_request_digits) },
999 { GDBUS_NOREPLY_METHOD("Cancel", NULL, NULL, agent_cancel) },
1003 static void ofono_connect(DBusConnection *conn, void *user_data)
1005 g_print("starting telephony interface\n");
1007 if (!g_dbus_register_interface(conn, "/default",
1008 OFONO_STKAGENT_INTERFACE,
1009 agent_methods, NULL, NULL,
1011 g_printerr("Unable to register local agent");
1012 g_main_loop_quit(main_loop);
1015 ofono_running = TRUE;
1019 static void ofono_disconnect(DBusConnection *conn, void *user_data)
1021 g_print("stopping telephony interface\n");
1023 g_dbus_unregister_interface(conn, "/default", OFONO_STKAGENT_INTERFACE);
1025 ofono_running = FALSE;
1027 g_dbus_remove_watch(conn, modem_changed_watch);
1028 modem_changed_watch = 0;
1031 g_source_remove(server_watch);
1035 g_at_server_unref(emulator);
1039 static void sig_term(int sig)
1041 if (__terminated > 0)
1046 g_print("Terminating\n");
1048 g_main_loop_quit(main_loop);
1051 static void disconnect_callback(DBusConnection *conn, void *user_data)
1053 g_printerr("D-Bus disconnect\n");
1055 g_main_loop_quit(main_loop);
1058 static gboolean end_session_and_finish(gpointer user_data)
1060 g_at_server_send_unsolicited(emulator, "+CUSATEND");
1061 __stktest_test_finish(TRUE);
1066 static void expect_response_and_finish(const unsigned char *pdu,
1069 struct test *test = cur_test->data;
1071 STKTEST_RESPONSE_ASSERT(test->rsp_pdu, test->rsp_len, pdu, len);
1073 g_idle_add(end_session_and_finish, NULL);
1076 static void expect_response(const unsigned char *pdu, unsigned int len)
1078 struct test *test = cur_test->data;
1080 STKTEST_RESPONSE_ASSERT(test->rsp_pdu, test->rsp_len, pdu, len);
1083 static gboolean poweroff_not_canceled_after_3(gpointer user_data)
1085 __stktest_test_finish(pending != NULL);
1089 static gboolean end_session_and_not_canceled_after_3(gpointer user_data)
1091 g_at_server_send_unsolicited(emulator, "+CUSATEND");
1092 g_timeout_add_seconds(3, poweroff_not_canceled_after_3, NULL);
1097 static void expect_response_and_not_canceled_after_3(const unsigned char *pdu,
1100 struct test *test = cur_test->data;
1102 STKTEST_RESPONSE_ASSERT(test->rsp_pdu, test->rsp_len, pdu, len);
1104 g_idle_add(end_session_and_not_canceled_after_3, NULL);
1107 static gboolean poweroff_and_canceled_after_21(gpointer user_data)
1109 __stktest_test_finish(pending == NULL);
1113 static gboolean end_session_and_canceled_after_21(gpointer user_data)
1115 g_at_server_send_unsolicited(emulator, "+CUSATEND");
1116 g_timeout_add_seconds(21, poweroff_and_canceled_after_21, NULL);
1121 static void expect_response_and_canceled_after_21(const unsigned char *pdu,
1124 struct test *test = cur_test->data;
1126 STKTEST_RESPONSE_ASSERT(test->rsp_pdu, test->rsp_len, pdu, len);
1128 g_idle_add(end_session_and_canceled_after_21, NULL);
1131 static DBusMessage *test_display_text_11(DBusMessage *msg,
1133 unsigned char icon_id,
1136 STKTEST_AGENT_ASSERT(g_str_equal(text, "Toolkit Test 1"));
1137 STKTEST_AGENT_ASSERT(icon_id == 0);
1138 STKTEST_AGENT_ASSERT(urgent == FALSE);
1140 return dbus_message_new_method_return(msg);
1143 static DBusMessage *test_display_text_12(DBusMessage *msg,
1145 unsigned char icon_id,
1148 STKTEST_AGENT_ASSERT(g_str_equal(text, "Toolkit Test 1"));
1149 STKTEST_AGENT_ASSERT(icon_id == 0);
1150 STKTEST_AGENT_ASSERT(urgent == FALSE);
1152 return stktest_error_busy(msg);
1155 static DBusMessage *test_display_text_13(DBusMessage *msg,
1157 unsigned char icon_id,
1160 STKTEST_AGENT_ASSERT(g_str_equal(text, "Toolkit Test 2"));
1161 STKTEST_AGENT_ASSERT(icon_id == 0);
1162 STKTEST_AGENT_ASSERT(urgent == TRUE);
1164 return dbus_message_new_method_return(msg);
1167 static DBusMessage *test_display_text_14(DBusMessage *msg,
1169 unsigned char icon_id,
1172 STKTEST_AGENT_ASSERT(g_str_equal(text, "Toolkit Test 3"));
1173 STKTEST_AGENT_ASSERT(icon_id == 0);
1174 STKTEST_AGENT_ASSERT(urgent == FALSE);
1176 return dbus_message_new_method_return(msg);
1179 static DBusMessage *test_display_text_15(DBusMessage *msg,
1181 unsigned char icon_id,
1184 STKTEST_AGENT_ASSERT(g_str_equal(text, "Toolkit Test 4"));
1185 STKTEST_AGENT_ASSERT(icon_id == 0);
1186 STKTEST_AGENT_ASSERT(urgent == FALSE);
1191 static DBusMessage *test_display_text_16(DBusMessage *msg,
1193 unsigned char icon_id,
1196 STKTEST_AGENT_ASSERT(g_str_equal(text, "This command instructs the ME"
1197 " to display a text message. "
1198 "It allows the SIM to define "
1199 "the priority of that message, "
1200 "and the text string format. "
1201 "Two types of prio"));
1202 STKTEST_AGENT_ASSERT(icon_id == 0);
1203 STKTEST_AGENT_ASSERT(urgent == FALSE);
1205 return dbus_message_new_method_return(msg);
1208 static DBusMessage *test_display_text_17(DBusMessage *msg,
1210 unsigned char icon_id,
1213 /* oFono gives rich text formatting in HTML */
1214 STKTEST_AGENT_ASSERT(g_str_equal(text, "<GO-BACKWARDS>"));
1215 STKTEST_AGENT_ASSERT(icon_id == 0);
1216 STKTEST_AGENT_ASSERT(urgent == FALSE);
1218 return stktest_error_go_back(msg);
1221 static DBusMessage *test_display_text_18(DBusMessage *msg,
1223 unsigned char icon_id,
1226 /* oFono gives rich text formatting in HTML */
1227 STKTEST_AGENT_ASSERT(g_str_equal(text, "<ABORT>"));
1228 STKTEST_AGENT_ASSERT(icon_id == 0);
1229 STKTEST_AGENT_ASSERT(urgent == FALSE);
1231 return stktest_error_end_session(msg);
1234 static DBusMessage *test_display_text_21(DBusMessage *msg,
1236 unsigned char icon_id,
1239 STKTEST_AGENT_ASSERT(g_str_equal(text, "<TIME-OUT>"));
1240 STKTEST_AGENT_ASSERT(icon_id == 0);
1241 STKTEST_AGENT_ASSERT(urgent == FALSE);
1246 static DBusMessage *test_display_text_31(DBusMessage *msg,
1248 unsigned char icon_id,
1251 static const char *expected = "This command instructs the ME to display"
1252 " a text message, and/or an icon "
1253 "(see 6.5.4). It allows the "
1254 "SIM to define the priority of that "
1255 "message, and the text string format. "
1256 "Two types of priority are defined:- "
1257 "display normal priority text and/";
1258 STKTEST_AGENT_ASSERT(g_str_equal(text, expected));
1259 STKTEST_AGENT_ASSERT(icon_id == 0);
1260 STKTEST_AGENT_ASSERT(urgent == FALSE);
1262 return dbus_message_new_method_return(msg);
1265 static DBusMessage *test_display_text_41(DBusMessage *msg,
1267 unsigned char icon_id,
1270 STKTEST_AGENT_ASSERT(g_str_equal(text, "Toolkit Test 1"));
1271 STKTEST_AGENT_ASSERT(icon_id == 0);
1272 STKTEST_AGENT_ASSERT(urgent == FALSE);
1277 static DBusMessage *test_display_text_42(DBusMessage *msg,
1279 unsigned char icon_id,
1282 STKTEST_AGENT_ASSERT(g_str_equal(text, "Toolkit Test 2"));
1283 STKTEST_AGENT_ASSERT(icon_id == 0);
1284 STKTEST_AGENT_ASSERT(urgent == FALSE);
1289 static gboolean user_response(gpointer user_data)
1291 if (pending == NULL) {
1292 __stktest_test_finish(FALSE);
1296 g_dbus_send_reply(conn, pending, DBUS_TYPE_INVALID);
1297 dbus_message_unref(pending);
1300 __stktest_test_finish(TRUE);
1305 static DBusMessage *test_display_text_43(DBusMessage *msg,
1307 unsigned char icon_id,
1310 STKTEST_AGENT_ASSERT(g_str_equal(text, "Toolkit Test 3"));
1311 STKTEST_AGENT_ASSERT(icon_id == 0);
1312 STKTEST_AGENT_ASSERT(urgent == FALSE);
1314 g_timeout_add_seconds(3, user_response, NULL);
1318 static DBusMessage *test_display_text_51(DBusMessage *msg,
1320 unsigned char icon_id,
1323 STKTEST_AGENT_ASSERT(g_str_equal(text, "Basic Icon"));
1324 STKTEST_AGENT_ASSERT(icon_id == 1);
1325 STKTEST_AGENT_ASSERT(urgent == FALSE);
1327 return dbus_message_new_method_return(msg);
1330 static DBusMessage *test_display_text_52(DBusMessage *msg,
1332 unsigned char icon_id,
1335 STKTEST_AGENT_ASSERT(g_str_equal(text, "Colour Icon"));
1336 STKTEST_AGENT_ASSERT(icon_id == 2);
1337 STKTEST_AGENT_ASSERT(urgent == FALSE);
1339 return dbus_message_new_method_return(msg);
1342 static DBusMessage *test_display_text_53(DBusMessage *msg,
1344 unsigned char icon_id,
1347 STKTEST_AGENT_ASSERT(g_str_equal(text, "Basic Icon"));
1348 STKTEST_AGENT_ASSERT(icon_id == 1);
1349 STKTEST_AGENT_ASSERT(urgent == FALSE);
1351 return dbus_message_new_method_return(msg);
1354 static DBusMessage *test_display_text_61(DBusMessage *msg,
1356 unsigned char icon_id,
1359 STKTEST_AGENT_ASSERT(g_str_equal(text, "ЗДРАВСТВУЙТЕ"));
1360 STKTEST_AGENT_ASSERT(icon_id == 0);
1361 STKTEST_AGENT_ASSERT(urgent == FALSE);
1363 return dbus_message_new_method_return(msg);
1366 static DBusMessage *test_display_text_71(DBusMessage *msg,
1368 unsigned char icon_id,
1371 STKTEST_AGENT_ASSERT(g_str_equal(text, "10 Second"));
1372 STKTEST_AGENT_ASSERT(icon_id == 0);
1373 STKTEST_AGENT_ASSERT(urgent == FALSE);
1378 static DBusMessage *test_display_text_81(DBusMessage *msg,
1380 unsigned char icon_id,
1383 const char *expect =
1384 "<div style=\"text-align: left;\"><span style=\"color: "
1385 "#347235;background-color: #FFFF00;\">Text Attribute 1</span>"
1388 STKTEST_AGENT_ASSERT(g_str_equal(text, expect));
1389 STKTEST_AGENT_ASSERT(icon_id == 0);
1390 STKTEST_AGENT_ASSERT(urgent == FALSE);
1392 return dbus_message_new_method_return(msg);
1395 static DBusMessage *test_display_text_82(DBusMessage *msg,
1397 unsigned char icon_id,
1400 const char *expect =
1401 "<div style=\"text-align: center;\"><span style=\"color: "
1402 "#347235;background-color: #FFFF00;\">Text Attribute 1</span>"
1405 STKTEST_AGENT_ASSERT(g_str_equal(text, expect));
1406 STKTEST_AGENT_ASSERT(icon_id == 0);
1407 STKTEST_AGENT_ASSERT(urgent == FALSE);
1409 return dbus_message_new_method_return(msg);
1412 static DBusMessage *test_display_text_83(DBusMessage *msg,
1414 unsigned char icon_id,
1417 const char *expect =
1418 "<div style=\"text-align: right;\"><span style=\"color: "
1419 "#347235;background-color: #FFFF00;\">Text Attribute 1</span>"
1422 STKTEST_AGENT_ASSERT(g_str_equal(text, expect));
1423 STKTEST_AGENT_ASSERT(icon_id == 0);
1424 STKTEST_AGENT_ASSERT(urgent == FALSE);
1426 return dbus_message_new_method_return(msg);
1429 static DBusMessage *test_display_text_84(DBusMessage *msg,
1431 unsigned char icon_id,
1434 const char *expect =
1435 "<div style=\"text-align: left;\"><span style=\"font-size: "
1436 "big;color: #347235;background-color: #FFFF00;\">"
1437 "Text Attribute 1</span></div>";
1439 STKTEST_AGENT_ASSERT(g_str_equal(text, expect));
1440 STKTEST_AGENT_ASSERT(icon_id == 0);
1441 STKTEST_AGENT_ASSERT(urgent == FALSE);
1443 return dbus_message_new_method_return(msg);
1446 static DBusMessage *test_display_text_85(DBusMessage *msg,
1448 unsigned char icon_id,
1451 const char *expect =
1452 "<div style=\"text-align: left;\"><span style=\"font-size: "
1453 "small;color: #347235;background-color: #FFFF00;\">"
1454 "Text Attribute 1</span></div>";
1456 STKTEST_AGENT_ASSERT(g_str_equal(text, expect));
1457 STKTEST_AGENT_ASSERT(icon_id == 0);
1458 STKTEST_AGENT_ASSERT(urgent == FALSE);
1460 return dbus_message_new_method_return(msg);
1463 static DBusMessage *test_display_text_86(DBusMessage *msg,
1465 unsigned char icon_id,
1468 const char *expect =
1469 "<div style=\"text-align: left;\"><span style=\"font-weight: "
1470 "bold;color: #347235;background-color: #FFFF00;\">"
1471 "Text Attribute 1</span></div>";
1473 STKTEST_AGENT_ASSERT(g_str_equal(text, expect));
1474 STKTEST_AGENT_ASSERT(icon_id == 0);
1475 STKTEST_AGENT_ASSERT(urgent == FALSE);
1477 return dbus_message_new_method_return(msg);
1480 static DBusMessage *test_display_text_87(DBusMessage *msg,
1482 unsigned char icon_id,
1485 const char *expect =
1486 "<div style=\"text-align: left;\"><span style=\"font-style: "
1487 "italic;color: #347235;background-color: #FFFF00;\">"
1488 "Text Attribute 1</span></div>";
1490 STKTEST_AGENT_ASSERT(g_str_equal(text, expect));
1491 STKTEST_AGENT_ASSERT(icon_id == 0);
1492 STKTEST_AGENT_ASSERT(urgent == FALSE);
1494 return dbus_message_new_method_return(msg);
1497 static DBusMessage *test_display_text_88(DBusMessage *msg,
1499 unsigned char icon_id,
1502 const char *expect =
1503 "<div style=\"text-align: left;\"><span style=\""
1504 "text-decoration: underline;color: #347235;"
1505 "background-color: #FFFF00;\">Text Attribute 1</span></div>";
1507 STKTEST_AGENT_ASSERT(g_str_equal(text, expect));
1508 STKTEST_AGENT_ASSERT(icon_id == 0);
1509 STKTEST_AGENT_ASSERT(urgent == FALSE);
1511 return dbus_message_new_method_return(msg);
1514 static DBusMessage *test_display_text_89(DBusMessage *msg,
1516 unsigned char icon_id,
1519 const char *expect =
1520 "<div style=\"text-align: left;\"><span style=\""
1521 "text-decoration: line-through;color: #347235;"
1522 "background-color: #FFFF00;\">Text Attribute 1</span></div>";
1524 STKTEST_AGENT_ASSERT(g_str_equal(text, expect));
1525 STKTEST_AGENT_ASSERT(icon_id == 0);
1526 STKTEST_AGENT_ASSERT(urgent == FALSE);
1528 return dbus_message_new_method_return(msg);
1531 static DBusMessage *test_display_text_810(DBusMessage *msg,
1533 unsigned char icon_id,
1536 const char *expect =
1537 "<div style=\"text-align: left;\"><span style=\"color: "
1538 "#347235;background-color: #FFFF00;\">Text Attribute 1</span>"
1541 STKTEST_AGENT_ASSERT(g_str_equal(text, expect));
1542 STKTEST_AGENT_ASSERT(icon_id == 0);
1543 STKTEST_AGENT_ASSERT(urgent == FALSE);
1545 return dbus_message_new_method_return(msg);
1548 static DBusMessage *test_display_text_91(DBusMessage *msg,
1550 unsigned char icon_id,
1553 const char *expect = "你好";
1555 STKTEST_AGENT_ASSERT(g_str_equal(text, expect));
1556 STKTEST_AGENT_ASSERT(icon_id == 0);
1557 STKTEST_AGENT_ASSERT(urgent == FALSE);
1559 return dbus_message_new_method_return(msg);
1562 static DBusMessage *test_display_text_101(DBusMessage *msg,
1564 unsigned char icon_id,
1567 const char *expect = "80ル";
1569 STKTEST_AGENT_ASSERT(g_str_equal(text, expect));
1570 STKTEST_AGENT_ASSERT(icon_id == 0);
1571 STKTEST_AGENT_ASSERT(urgent == FALSE);
1573 return dbus_message_new_method_return(msg);
1576 static DBusMessage *test_get_inkey_11(DBusMessage *msg,
1578 unsigned char icon_id)
1581 const char *ret = "+";
1583 STKTEST_AGENT_ASSERT(g_str_equal(alpha, "Enter \"+\""));
1584 STKTEST_AGENT_ASSERT(icon_id == 0);
1586 reply = dbus_message_new_method_return(msg);
1587 dbus_message_append_args(reply, DBUS_TYPE_STRING, &ret,
1593 static DBusMessage *test_get_inkey_12(DBusMessage *msg,
1595 unsigned char icon_id)
1598 const char *ret = "0";
1600 STKTEST_AGENT_ASSERT(g_str_equal(alpha, "Enter \"0\""));
1601 STKTEST_AGENT_ASSERT(icon_id == 0);
1603 reply = dbus_message_new_method_return(msg);
1604 dbus_message_append_args(reply, DBUS_TYPE_STRING, &ret,
1610 static DBusMessage *test_get_inkey_13(DBusMessage *msg,
1612 unsigned char icon_id)
1614 STKTEST_AGENT_ASSERT(g_str_equal(alpha, "<GO-BACKWARDS>"));
1615 STKTEST_AGENT_ASSERT(icon_id == 0);
1617 return stktest_error_go_back(msg);
1620 static DBusMessage *test_get_inkey_14(DBusMessage *msg,
1622 unsigned char icon_id)
1624 STKTEST_AGENT_ASSERT(g_str_equal(alpha, "<ABORT>"));
1625 STKTEST_AGENT_ASSERT(icon_id == 0);
1627 return stktest_error_end_session(msg);
1630 static DBusMessage *test_get_inkey_15(DBusMessage *msg,
1632 unsigned char icon_id)
1635 const char *ret = "q";
1637 STKTEST_AGENT_ASSERT(g_str_equal(alpha, "Enter \"q\""));
1638 STKTEST_AGENT_ASSERT(icon_id == 0);
1640 reply = dbus_message_new_method_return(msg);
1641 dbus_message_append_args(reply, DBUS_TYPE_STRING, &ret,
1647 static DBusMessage *test_get_inkey_16(DBusMessage *msg,
1649 unsigned char icon_id)
1652 const char *ret = "x";
1653 const char *expected =
1654 "Enter \"x\". This command instructs the ME to display text, "
1655 "and to expect the user to enter a single character. Any "
1656 "response entered by the user shall be passed t";
1658 STKTEST_AGENT_ASSERT(g_str_equal(alpha, expected));
1659 STKTEST_AGENT_ASSERT(icon_id == 0);
1661 reply = dbus_message_new_method_return(msg);
1662 dbus_message_append_args(reply, DBUS_TYPE_STRING, &ret,
1668 static DBusMessage *test_get_inkey_21(DBusMessage *msg,
1669 const char *text, unsigned char icon_id)
1671 STKTEST_AGENT_ASSERT(g_str_equal(text, "<TIME-OUT>"));
1672 STKTEST_AGENT_ASSERT(icon_id == 0);
1677 static DBusMessage *test_get_inkey_31(DBusMessage *msg,
1679 unsigned char icon_id)
1682 const char *ret = "+";
1684 STKTEST_AGENT_ASSERT(g_str_equal(alpha, "ЗДРАВСТВУЙТЕ"));
1685 STKTEST_AGENT_ASSERT(icon_id == 0);
1687 reply = dbus_message_new_method_return(msg);
1688 dbus_message_append_args(reply, DBUS_TYPE_STRING, &ret,
1694 static DBusMessage *test_get_inkey_32(DBusMessage *msg,
1696 unsigned char icon_id)
1699 const char *ret = "+";
1700 const char *expect = "ЗДРАВСТВУЙТЕЗДРАВСТВУЙТЕ"
1701 "ЗДРАВСТВУЙТЕЗДРАВСТВУЙТЕ"
1702 "ЗДРАВСТВУЙТЕЗДРАВСТВУЙ";
1704 STKTEST_AGENT_ASSERT(g_str_equal(alpha, expect));
1705 STKTEST_AGENT_ASSERT(icon_id == 0);
1707 reply = dbus_message_new_method_return(msg);
1708 dbus_message_append_args(reply, DBUS_TYPE_STRING, &ret,
1714 static DBusMessage *test_get_inkey_41(DBusMessage *msg,
1716 unsigned char icon_id)
1719 const char *ret = "Д";
1721 STKTEST_AGENT_ASSERT(g_str_equal(alpha, "Enter"));
1722 STKTEST_AGENT_ASSERT(icon_id == 0);
1724 reply = dbus_message_new_method_return(msg);
1725 dbus_message_append_args(reply, DBUS_TYPE_STRING, &ret,
1731 static DBusMessage *test_get_inkey_51a(DBusMessage *msg,
1733 unsigned char icon_id)
1736 dbus_bool_t ret = 1;
1738 STKTEST_AGENT_ASSERT(g_str_equal(alpha, "Enter YES"));
1739 STKTEST_AGENT_ASSERT(icon_id == 0);
1741 reply = dbus_message_new_method_return(msg);
1742 dbus_message_append_args(reply, DBUS_TYPE_BOOLEAN, &ret,
1748 static DBusMessage *test_get_inkey_51b(DBusMessage *msg,
1750 unsigned char icon_id)
1753 dbus_bool_t ret = 0;
1755 STKTEST_AGENT_ASSERT(g_str_equal(alpha, "Enter NO"));
1756 STKTEST_AGENT_ASSERT(icon_id == 0);
1758 reply = dbus_message_new_method_return(msg);
1759 dbus_message_append_args(reply, DBUS_TYPE_BOOLEAN, &ret,
1765 static DBusMessage *test_get_inkey_61(DBusMessage *msg,
1767 unsigned char icon_id)
1770 const char *ret = "+";
1772 STKTEST_AGENT_ASSERT(g_str_equal(alpha, "<NO-ICON>"));
1773 STKTEST_AGENT_ASSERT(icon_id == 1);
1775 reply = dbus_message_new_method_return(msg);
1776 dbus_message_append_args(reply, DBUS_TYPE_STRING, &ret,
1782 static DBusMessage *test_get_inkey_62(DBusMessage *msg,
1784 unsigned char icon_id)
1787 const char *ret = "+";
1789 STKTEST_AGENT_ASSERT(g_str_equal(alpha, "<BASIC-ICON>"));
1790 STKTEST_AGENT_ASSERT(icon_id == 1);
1792 reply = dbus_message_new_method_return(msg);
1793 dbus_message_append_args(reply, DBUS_TYPE_STRING, &ret,
1799 static DBusMessage *test_get_inkey_63(DBusMessage *msg,
1801 unsigned char icon_id)
1804 const char *ret = "+";
1806 STKTEST_AGENT_ASSERT(g_str_equal(alpha, "<NO-ICON>"));
1807 STKTEST_AGENT_ASSERT(icon_id == 2);
1809 reply = dbus_message_new_method_return(msg);
1810 dbus_message_append_args(reply, DBUS_TYPE_STRING, &ret,
1816 static DBusMessage *test_get_inkey_64(DBusMessage *msg,
1818 unsigned char icon_id)
1821 const char *ret = "+";
1823 STKTEST_AGENT_ASSERT(g_str_equal(alpha, "<COLOUR-ICON>"));
1824 STKTEST_AGENT_ASSERT(icon_id == 2);
1826 reply = dbus_message_new_method_return(msg);
1827 dbus_message_append_args(reply, DBUS_TYPE_STRING, &ret,
1833 static DBusMessage *test_get_inkey_81(DBusMessage *msg,
1835 unsigned char icon_id)
1837 STKTEST_AGENT_ASSERT(g_str_equal(alpha, "Enter \"+\""));
1838 STKTEST_AGENT_ASSERT(icon_id == 0);
1843 static DBusMessage *test_get_inkey_91(DBusMessage *msg,
1845 unsigned char icon_id)
1848 const char *ret = "+";
1849 const char *expect =
1850 "<div style=\"text-align: left;\"><span style=\"color: "
1851 "#347235;background-color: #FFFF00;\">Enter \"+\"</span></div>";
1853 STKTEST_AGENT_ASSERT(g_str_equal(alpha, expect));
1854 STKTEST_AGENT_ASSERT(icon_id == 0);
1856 reply = dbus_message_new_method_return(msg);
1857 dbus_message_append_args(reply, DBUS_TYPE_STRING, &ret,
1863 static DBusMessage *test_get_inkey_92(DBusMessage *msg,
1865 unsigned char icon_id)
1868 const char *ret = "+";
1869 const char *expect =
1870 "<div style=\"text-align: center;\"><span style=\"color: "
1871 "#347235;background-color: #FFFF00;\">Enter \"+\"</span>"
1874 STKTEST_AGENT_ASSERT(g_str_equal(alpha, expect));
1875 STKTEST_AGENT_ASSERT(icon_id == 0);
1877 reply = dbus_message_new_method_return(msg);
1878 dbus_message_append_args(reply, DBUS_TYPE_STRING, &ret,
1884 static DBusMessage *test_get_inkey_93(DBusMessage *msg,
1886 unsigned char icon_id)
1889 const char *ret = "+";
1890 const char *expect =
1891 "<div style=\"text-align: right;\"><span style=\"color: "
1892 "#347235;background-color: #FFFF00;\">Enter \"+\"</span>"
1895 STKTEST_AGENT_ASSERT(g_str_equal(alpha, expect));
1896 STKTEST_AGENT_ASSERT(icon_id == 0);
1898 reply = dbus_message_new_method_return(msg);
1899 dbus_message_append_args(reply, DBUS_TYPE_STRING, &ret,
1905 static DBusMessage *test_get_inkey_94(DBusMessage *msg,
1907 unsigned char icon_id)
1910 const char *ret = "+";
1911 const char *expect =
1912 "<div style=\"text-align: left;\"><span style=\"font-size: "
1913 "big;color: #347235;background-color: #FFFF00;\">Enter \"+\""
1916 STKTEST_AGENT_ASSERT(g_str_equal(alpha, expect));
1917 STKTEST_AGENT_ASSERT(icon_id == 0);
1919 reply = dbus_message_new_method_return(msg);
1920 dbus_message_append_args(reply, DBUS_TYPE_STRING, &ret,
1926 static DBusMessage *test_get_inkey_95(DBusMessage *msg,
1928 unsigned char icon_id)
1931 const char *ret = "+";
1932 const char *expect =
1933 "<div style=\"text-align: left;\"><span style=\"font-size: "
1934 "small;color: #347235;background-color: #FFFF00;\">"
1935 "Enter \"+\"</span></div>";
1937 STKTEST_AGENT_ASSERT(g_str_equal(alpha, expect));
1938 STKTEST_AGENT_ASSERT(icon_id == 0);
1940 reply = dbus_message_new_method_return(msg);
1941 dbus_message_append_args(reply, DBUS_TYPE_STRING, &ret,
1947 static DBusMessage *test_get_inkey_96(DBusMessage *msg,
1949 unsigned char icon_id)
1952 const char *ret = "+";
1953 const char *expect =
1954 "<div style=\"text-align: left;\"><span style=\"font-weight: "
1955 "bold;color: #347235;background-color: #FFFF00;\">Enter \"+\""
1958 STKTEST_AGENT_ASSERT(g_str_equal(alpha, expect));
1959 STKTEST_AGENT_ASSERT(icon_id == 0);
1961 reply = dbus_message_new_method_return(msg);
1962 dbus_message_append_args(reply, DBUS_TYPE_STRING, &ret,
1968 static DBusMessage *test_get_inkey_97(DBusMessage *msg,
1970 unsigned char icon_id)
1973 const char *ret = "+";
1974 const char *expect =
1975 "<div style=\"text-align: left;\"><span style=\"font-style: "
1976 "italic;color: #347235;background-color: #FFFF00;\">"
1977 "Enter \"+\"</span></div>";
1979 STKTEST_AGENT_ASSERT(g_str_equal(alpha, expect));
1980 STKTEST_AGENT_ASSERT(icon_id == 0);
1982 reply = dbus_message_new_method_return(msg);
1983 dbus_message_append_args(reply, DBUS_TYPE_STRING, &ret,
1989 static DBusMessage *test_get_inkey_98(DBusMessage *msg,
1991 unsigned char icon_id)
1994 const char *ret = "+";
1995 const char *expect =
1996 "<div style=\"text-align: left;\"><span style=\""
1997 "text-decoration: underline;color: #347235;"
1998 "background-color: #FFFF00;\">Enter \"+\"</span></div>";
2000 STKTEST_AGENT_ASSERT(g_str_equal(alpha, expect));
2001 STKTEST_AGENT_ASSERT(icon_id == 0);
2003 reply = dbus_message_new_method_return(msg);
2004 dbus_message_append_args(reply, DBUS_TYPE_STRING, &ret,
2010 static DBusMessage *test_get_inkey_99(DBusMessage *msg,
2012 unsigned char icon_id)
2015 const char *ret = "+";
2016 const char *expect =
2017 "<div style=\"text-align: left;\"><span style=\""
2018 "text-decoration: line-through;color: #347235;"
2019 "background-color: #FFFF00;\">Enter \"+\"</span></div>";
2021 STKTEST_AGENT_ASSERT(g_str_equal(alpha, expect));
2022 STKTEST_AGENT_ASSERT(icon_id == 0);
2024 reply = dbus_message_new_method_return(msg);
2025 dbus_message_append_args(reply, DBUS_TYPE_STRING, &ret,
2031 static DBusMessage *test_get_inkey_910(DBusMessage *msg,
2033 unsigned char icon_id)
2036 const char *ret = "+";
2037 const char *expect =
2038 "<div style=\"text-align: left;\"><span style=\"color: "
2039 "#347235;background-color: #FFFF00;\">Enter \"+\"</span></div>";
2041 STKTEST_AGENT_ASSERT(g_str_equal(alpha, expect));
2042 STKTEST_AGENT_ASSERT(icon_id == 0);
2044 reply = dbus_message_new_method_return(msg);
2045 dbus_message_append_args(reply, DBUS_TYPE_STRING, &ret,
2051 static DBusMessage *test_get_inkey_101(DBusMessage *msg,
2053 unsigned char icon_id)
2056 const char *ret = "+";
2057 const char *expect = "你好";
2059 STKTEST_AGENT_ASSERT(g_str_equal(alpha, expect));
2060 STKTEST_AGENT_ASSERT(icon_id == 0);
2062 reply = dbus_message_new_method_return(msg);
2063 dbus_message_append_args(reply, DBUS_TYPE_STRING, &ret,
2069 static DBusMessage *test_get_inkey_102(DBusMessage *msg,
2071 unsigned char icon_id)
2074 const char *ret = "+";
2075 const char *expect =
2076 "你好你好你好你好你好你好你好你好你好你好"
2077 "你好你好你好你好你好你好你好你好你好你好"
2078 "你好你好你好你好你好你好你好你好你好你好"
2081 STKTEST_AGENT_ASSERT(g_str_equal(alpha, expect));
2082 STKTEST_AGENT_ASSERT(icon_id == 0);
2084 reply = dbus_message_new_method_return(msg);
2085 dbus_message_append_args(reply, DBUS_TYPE_STRING, &ret,
2091 static DBusMessage *test_get_inkey_111(DBusMessage *msg,
2093 unsigned char icon_id)
2096 const char *ret = "好";
2098 STKTEST_AGENT_ASSERT(g_str_equal(alpha, "Enter"));
2099 STKTEST_AGENT_ASSERT(icon_id == 0);
2101 reply = dbus_message_new_method_return(msg);
2102 dbus_message_append_args(reply, DBUS_TYPE_STRING, &ret,
2108 static DBusMessage *test_get_inkey_121(DBusMessage *msg,
2110 unsigned char icon_id)
2113 const char *ret = "+";
2114 const char *expect = "ル";
2116 STKTEST_AGENT_ASSERT(g_str_equal(alpha, expect));
2117 STKTEST_AGENT_ASSERT(icon_id == 0);
2119 reply = dbus_message_new_method_return(msg);
2120 dbus_message_append_args(reply, DBUS_TYPE_STRING, &ret,
2126 static DBusMessage *test_get_inkey_122(DBusMessage *msg,
2128 unsigned char icon_id)
2131 const char *ret = "+";
2132 const char *expect =
2133 "ルルルルルルルルルルルルルルルルルルルル"
2134 "ルルルルルルルルルルルルルルルルルルルル"
2135 "ルルルルルルルルルルルルルルルルルルルル"
2138 STKTEST_AGENT_ASSERT(g_str_equal(alpha, expect));
2139 STKTEST_AGENT_ASSERT(icon_id == 0);
2141 reply = dbus_message_new_method_return(msg);
2142 dbus_message_append_args(reply, DBUS_TYPE_STRING, &ret,
2148 static DBusMessage *test_get_inkey_131(DBusMessage *msg,
2150 unsigned char icon_id)
2153 const char *ret = "ル";
2155 STKTEST_AGENT_ASSERT(g_str_equal(alpha, "Enter"));
2156 STKTEST_AGENT_ASSERT(icon_id == 0);
2158 reply = dbus_message_new_method_return(msg);
2159 dbus_message_append_args(reply, DBUS_TYPE_STRING, &ret,
2165 static void power_down_reply(DBusPendingCall *call, void *user_data)
2167 __stktest_test_next();
2170 void __stktest_test_finish(gboolean successful)
2172 struct test *test = cur_test->data;
2173 dbus_bool_t powered = FALSE;
2175 test->result = successful ? TEST_RESULT_PASSED : TEST_RESULT_FAILED;
2177 state = TEST_STATE_POWERING_DOWN;
2178 set_property(STKTEST_PATH, OFONO_MODEM_INTERFACE, "Powered",
2179 DBUS_TYPE_BOOLEAN, &powered,
2180 power_down_reply, NULL, NULL);
2183 void __stktest_test_next()
2185 if (cur_test == NULL)
2188 cur_test = cur_test->next;
2190 if (cur_test == NULL) {
2191 g_main_loop_quit(main_loop);
2198 static void stktest_add_test(const char *name, const char *method,
2199 const unsigned char *req, unsigned int req_len,
2200 const unsigned char *rsp, unsigned int rsp_len,
2202 terminal_response_func tr_func)
2204 struct test *test = g_new0(struct test, 1);
2206 test->name = g_strdup(name);
2207 test->method = g_strdup(method);
2208 test->req_pdu = g_memdup(req, req_len);
2209 test->req_len = req_len;
2210 test->rsp_pdu = g_memdup(rsp, rsp_len);
2211 test->rsp_len = rsp_len;
2212 test->agent_func = agent_func;
2213 test->tr_func = tr_func;
2215 tests = g_list_append(tests, test);
2218 static void __stktest_test_init(void)
2220 stktest_add_test("Display Text 1.1", "DisplayText",
2221 display_text_111, sizeof(display_text_111),
2222 display_text_response_111,
2223 sizeof(display_text_response_111),
2224 test_display_text_11,
2225 expect_response_and_finish);
2226 stktest_add_test("Display Text 1.2", "DisplayText",
2227 display_text_111, sizeof(display_text_111),
2228 display_text_response_121,
2229 sizeof(display_text_response_121),
2230 test_display_text_12,
2231 expect_response_and_finish);
2232 stktest_add_test("Display Text 1.3", "DisplayText",
2233 display_text_131, sizeof(display_text_131),
2234 display_text_response_131,
2235 sizeof(display_text_response_131),
2236 test_display_text_13,
2237 expect_response_and_finish);
2238 stktest_add_test("Display Text 1.4", "DisplayText",
2239 display_text_141, sizeof(display_text_141),
2240 display_text_response_141,
2241 sizeof(display_text_response_141),
2242 test_display_text_14,
2243 expect_response_and_finish);
2244 stktest_add_test("Display Text 1.5", "DisplayText",
2245 display_text_151, sizeof(display_text_151),
2246 display_text_response_151,
2247 sizeof(display_text_response_151),
2248 test_display_text_15,
2249 expect_response_and_finish);
2250 stktest_add_test("Display Text 1.6", "DisplayText",
2251 display_text_161, sizeof(display_text_161),
2252 display_text_response_161,
2253 sizeof(display_text_response_161),
2254 test_display_text_16,
2255 expect_response_and_finish);
2256 stktest_add_test("Display Text 1.7", "DisplayText",
2257 display_text_171, sizeof(display_text_171),
2258 display_text_response_171,
2259 sizeof(display_text_response_171),
2260 test_display_text_17,
2261 expect_response_and_finish);
2262 stktest_add_test("Display Text 1.8", "DisplayText",
2263 display_text_181, sizeof(display_text_181),
2264 display_text_response_181,
2265 sizeof(display_text_response_181),
2266 test_display_text_18,
2267 expect_response_and_finish);
2268 stktest_add_test("Display Text 1.9", "DisplayText",
2269 display_text_191, sizeof(display_text_191),
2270 display_text_response_191,
2271 sizeof(display_text_response_191),
2272 NULL, expect_response_and_finish);
2273 stktest_add_test("Display Text 2.1", "DisplayText",
2274 display_text_211, sizeof(display_text_211),
2275 display_text_response_211,
2276 sizeof(display_text_response_211),
2277 test_display_text_21,
2278 expect_response_and_finish);
2279 stktest_add_test("Display Text 3.1", "DisplayText",
2280 display_text_311, sizeof(display_text_311),
2281 display_text_response_311,
2282 sizeof(display_text_response_311),
2283 test_display_text_31,
2284 expect_response_and_finish);
2285 stktest_add_test("Display Text 4.1", "DisplayText",
2286 display_text_411, sizeof(display_text_411),
2287 display_text_response_411,
2288 sizeof(display_text_response_411),
2289 test_display_text_41,
2290 expect_response_and_not_canceled_after_3);
2291 stktest_add_test("Display Text 4.2", "DisplayText",
2292 display_text_421, sizeof(display_text_421),
2293 display_text_response_421,
2294 sizeof(display_text_response_421),
2295 test_display_text_42,
2296 expect_response_and_canceled_after_21);
2297 stktest_add_test("Display Text 4.3", "DisplayText",
2298 display_text_431, sizeof(display_text_431),
2299 display_text_response_431,
2300 sizeof(display_text_response_431),
2301 test_display_text_43, expect_response);
2302 stktest_add_test("Display Text 5.1A", "DisplayText",
2303 display_text_511, sizeof(display_text_511),
2304 display_text_response_511a,
2305 sizeof(display_text_response_511a),
2306 test_display_text_51,
2307 expect_response_and_finish);
2308 stktest_add_test("Display Text 5.2A", "DisplayText",
2309 display_text_521, sizeof(display_text_521),
2310 display_text_response_521a,
2311 sizeof(display_text_response_521a),
2312 test_display_text_52,
2313 expect_response_and_finish);
2314 stktest_add_test("Display Text 5.3A", "DisplayText",
2315 display_text_531, sizeof(display_text_531),
2316 display_text_response_531a,
2317 sizeof(display_text_response_531a),
2318 test_display_text_53,
2319 expect_response_and_finish);
2320 stktest_add_test("Display Text 6.1", "DisplayText",
2321 display_text_611, sizeof(display_text_611),
2322 display_text_response_611,
2323 sizeof(display_text_response_611),
2324 test_display_text_61,
2325 expect_response_and_finish);
2326 stktest_add_test("Display Text 7.1", "DisplayText",
2327 display_text_711, sizeof(display_text_711),
2328 display_text_response_711,
2329 sizeof(display_text_response_711),
2330 test_display_text_71,
2331 expect_response_and_finish);
2333 * We skip parts where the UI is asked to display simple text to ensure
2334 * that the alignment, font is set up correctly and not 'remembered'
2335 * from a previous state. oFono does not keep any state of the
2338 stktest_add_test("Display Text 8.1", "DisplayText",
2339 display_text_811, sizeof(display_text_811),
2340 display_text_response_811,
2341 sizeof(display_text_response_811),
2342 test_display_text_81,
2343 expect_response_and_finish);
2344 stktest_add_test("Display Text 8.2", "DisplayText",
2345 display_text_821, sizeof(display_text_821),
2346 display_text_response_821,
2347 sizeof(display_text_response_821),
2348 test_display_text_82,
2349 expect_response_and_finish);
2350 stktest_add_test("Display Text 8.3", "DisplayText",
2351 display_text_831, sizeof(display_text_831),
2352 display_text_response_831,
2353 sizeof(display_text_response_831),
2354 test_display_text_83,
2355 expect_response_and_finish);
2356 stktest_add_test("Display Text 8.4", "DisplayText",
2357 display_text_841, sizeof(display_text_841),
2358 display_text_response_841,
2359 sizeof(display_text_response_841),
2360 test_display_text_84,
2361 expect_response_and_finish);
2362 stktest_add_test("Display Text 8.5", "DisplayText",
2363 display_text_851, sizeof(display_text_851),
2364 display_text_response_851,
2365 sizeof(display_text_response_851),
2366 test_display_text_85,
2367 expect_response_and_finish);
2368 stktest_add_test("Display Text 8.6", "DisplayText",
2369 display_text_861, sizeof(display_text_861),
2370 display_text_response_861,
2371 sizeof(display_text_response_861),
2372 test_display_text_86,
2373 expect_response_and_finish);
2374 stktest_add_test("Display Text 8.7", "DisplayText",
2375 display_text_871, sizeof(display_text_871),
2376 display_text_response_871,
2377 sizeof(display_text_response_871),
2378 test_display_text_87,
2379 expect_response_and_finish);
2380 stktest_add_test("Display Text 8.8", "DisplayText",
2381 display_text_881, sizeof(display_text_881),
2382 display_text_response_881,
2383 sizeof(display_text_response_881),
2384 test_display_text_88,
2385 expect_response_and_finish);
2386 stktest_add_test("Display Text 8.9", "DisplayText",
2387 display_text_891, sizeof(display_text_891),
2388 display_text_response_891,
2389 sizeof(display_text_response_891),
2390 test_display_text_89,
2391 expect_response_and_finish);
2392 stktest_add_test("Display Text 8.10", "DisplayText",
2393 display_text_8101, sizeof(display_text_8101),
2394 display_text_response_8101,
2395 sizeof(display_text_response_8101),
2396 test_display_text_810,
2397 expect_response_and_finish);
2398 stktest_add_test("Display Text 9.1", "DisplayText",
2399 display_text_911, sizeof(display_text_911),
2400 display_text_response_911,
2401 sizeof(display_text_response_911),
2402 test_display_text_91,
2403 expect_response_and_finish);
2404 stktest_add_test("Display Text 10.1", "DisplayText",
2405 display_text_1011, sizeof(display_text_1011),
2406 display_text_response_1011,
2407 sizeof(display_text_response_1011),
2408 test_display_text_101,
2409 expect_response_and_finish);
2410 stktest_add_test("Get Inkey 1.1", "RequestDigit",
2411 get_inkey_111, sizeof(get_inkey_111),
2412 get_inkey_response_111,
2413 sizeof(get_inkey_response_111),
2415 expect_response_and_finish);
2416 stktest_add_test("Get Inkey 1.2", "RequestDigit",
2417 get_inkey_121, sizeof(get_inkey_121),
2418 get_inkey_response_121,
2419 sizeof(get_inkey_response_121),
2421 expect_response_and_finish);
2422 stktest_add_test("Get Inkey 1.3", "RequestDigit",
2423 get_inkey_131, sizeof(get_inkey_131),
2424 get_inkey_response_131,
2425 sizeof(get_inkey_response_131),
2427 expect_response_and_finish);
2428 stktest_add_test("Get Inkey 1.4", "RequestDigit",
2429 get_inkey_141, sizeof(get_inkey_141),
2430 get_inkey_response_141,
2431 sizeof(get_inkey_response_141),
2433 expect_response_and_finish);
2434 stktest_add_test("Get Inkey 1.5", "RequestKey",
2435 get_inkey_151, sizeof(get_inkey_151),
2436 get_inkey_response_151,
2437 sizeof(get_inkey_response_151),
2439 expect_response_and_finish);
2440 stktest_add_test("Get Inkey 1.6", "RequestKey",
2441 get_inkey_161, sizeof(get_inkey_161),
2442 get_inkey_response_161,
2443 sizeof(get_inkey_response_161),
2445 expect_response_and_finish);
2446 stktest_add_test("Get Inkey 2.1", "RequestDigit",
2447 get_inkey_211, sizeof(get_inkey_211),
2448 get_inkey_response_211,
2449 sizeof(get_inkey_response_211),
2451 expect_response_and_finish);
2452 stktest_add_test("Get Inkey 3.1", "RequestDigit",
2453 get_inkey_311, sizeof(get_inkey_311),
2454 get_inkey_response_311,
2455 sizeof(get_inkey_response_311),
2457 expect_response_and_finish);
2458 stktest_add_test("Get Inkey 3.2", "RequestDigit",
2459 get_inkey_321, sizeof(get_inkey_321),
2460 get_inkey_response_321,
2461 sizeof(get_inkey_response_321),
2463 expect_response_and_finish);
2464 stktest_add_test("Get Inkey 4.1", "RequestKey",
2465 get_inkey_411, sizeof(get_inkey_411),
2466 get_inkey_response_411,
2467 sizeof(get_inkey_response_411),
2469 expect_response_and_finish);
2470 stktest_add_test("Get Inkey 5.1a", "RequestConfirmation",
2471 get_inkey_511, sizeof(get_inkey_511),
2472 get_inkey_response_511,
2473 sizeof(get_inkey_response_511),
2475 expect_response_and_finish);
2476 stktest_add_test("Get Inkey 5.1b", "RequestConfirmation",
2477 get_inkey_512, sizeof(get_inkey_512),
2478 get_inkey_response_512,
2479 sizeof(get_inkey_response_512),
2481 expect_response_and_finish);
2482 stktest_add_test("Get Inkey 6.1", "RequestDigit",
2483 get_inkey_611, sizeof(get_inkey_611),
2484 get_inkey_response_611,
2485 sizeof(get_inkey_response_611),
2487 expect_response_and_finish);
2488 stktest_add_test("Get Inkey 6.2", "RequestDigit",
2489 get_inkey_621, sizeof(get_inkey_621),
2490 get_inkey_response_621,
2491 sizeof(get_inkey_response_621),
2493 expect_response_and_finish);
2494 stktest_add_test("Get Inkey 6.3", "RequestDigit",
2495 get_inkey_631, sizeof(get_inkey_631),
2496 get_inkey_response_631,
2497 sizeof(get_inkey_response_631),
2499 expect_response_and_finish);
2500 stktest_add_test("Get Inkey 6.4", "RequestDigit",
2501 get_inkey_641, sizeof(get_inkey_641),
2502 get_inkey_response_641,
2503 sizeof(get_inkey_response_641),
2505 expect_response_and_finish);
2506 /* Test Sequence for GetInkey 7.1 skipped, we do not support help */
2507 stktest_add_test("Get Inkey 8.1", "RequestDigit",
2508 get_inkey_811, sizeof(get_inkey_811),
2509 get_inkey_response_811,
2510 sizeof(get_inkey_response_811),
2512 expect_response_and_finish);
2513 stktest_add_test("Get Inkey 9.1", "RequestDigit",
2514 get_inkey_911, sizeof(get_inkey_911),
2515 get_inkey_response_911,
2516 sizeof(get_inkey_response_911),
2518 expect_response_and_finish);
2519 stktest_add_test("Get Inkey 9.2", "RequestDigit",
2520 get_inkey_921, sizeof(get_inkey_921),
2521 get_inkey_response_921,
2522 sizeof(get_inkey_response_921),
2524 expect_response_and_finish);
2525 stktest_add_test("Get Inkey 9.3", "RequestDigit",
2526 get_inkey_931, sizeof(get_inkey_931),
2527 get_inkey_response_931,
2528 sizeof(get_inkey_response_931),
2530 expect_response_and_finish);
2531 stktest_add_test("Get Inkey 9.4", "RequestDigit",
2532 get_inkey_941, sizeof(get_inkey_941),
2533 get_inkey_response_941,
2534 sizeof(get_inkey_response_941),
2536 expect_response_and_finish);
2537 stktest_add_test("Get Inkey 9.5", "RequestDigit",
2538 get_inkey_951, sizeof(get_inkey_951),
2539 get_inkey_response_951,
2540 sizeof(get_inkey_response_951),
2542 expect_response_and_finish);
2543 stktest_add_test("Get Inkey 9.6", "RequestDigit",
2544 get_inkey_961, sizeof(get_inkey_961),
2545 get_inkey_response_961,
2546 sizeof(get_inkey_response_961),
2548 expect_response_and_finish);
2549 stktest_add_test("Get Inkey 9.7", "RequestDigit",
2550 get_inkey_971, sizeof(get_inkey_971),
2551 get_inkey_response_971,
2552 sizeof(get_inkey_response_971),
2554 expect_response_and_finish);
2555 stktest_add_test("Get Inkey 9.8", "RequestDigit",
2556 get_inkey_981, sizeof(get_inkey_981),
2557 get_inkey_response_981,
2558 sizeof(get_inkey_response_981),
2560 expect_response_and_finish);
2561 stktest_add_test("Get Inkey 9.9", "RequestDigit",
2562 get_inkey_991, sizeof(get_inkey_991),
2563 get_inkey_response_991,
2564 sizeof(get_inkey_response_991),
2566 expect_response_and_finish);
2567 stktest_add_test("Get Inkey 9.10", "RequestDigit",
2568 get_inkey_9101, sizeof(get_inkey_9101),
2569 get_inkey_response_9101,
2570 sizeof(get_inkey_response_9101),
2572 expect_response_and_finish);
2573 stktest_add_test("Get Inkey 10.1", "RequestDigit",
2574 get_inkey_1011, sizeof(get_inkey_1011),
2575 get_inkey_response_1011,
2576 sizeof(get_inkey_response_1011),
2578 expect_response_and_finish);
2579 stktest_add_test("Get Inkey 10.2", "RequestDigit",
2580 get_inkey_1021, sizeof(get_inkey_1021),
2581 get_inkey_response_1021,
2582 sizeof(get_inkey_response_1021),
2584 expect_response_and_finish);
2585 stktest_add_test("Get Inkey 11.1", "RequestKey",
2586 get_inkey_1111, sizeof(get_inkey_1111),
2587 get_inkey_response_1111,
2588 sizeof(get_inkey_response_1111),
2590 expect_response_and_finish);
2591 stktest_add_test("Get Inkey 12.1", "RequestDigit",
2592 get_inkey_1211, sizeof(get_inkey_1211),
2593 get_inkey_response_1211,
2594 sizeof(get_inkey_response_1211),
2596 expect_response_and_finish);
2597 stktest_add_test("Get Inkey 12.2", "RequestDigit",
2598 get_inkey_1221, sizeof(get_inkey_1221),
2599 get_inkey_response_1221,
2600 sizeof(get_inkey_response_1221),
2602 expect_response_and_finish);
2603 stktest_add_test("Get Inkey 13.1", "RequestKey",
2604 get_inkey_1311, sizeof(get_inkey_1311),
2605 get_inkey_response_1311,
2606 sizeof(get_inkey_response_1311),
2608 expect_response_and_finish);
2611 static void test_destroy(gpointer user_data)
2613 struct test *test = user_data;
2616 g_free(test->method);
2617 g_free(test->req_pdu);
2618 g_free(test->rsp_pdu);
2623 static void __stktest_test_summarize(void)
2626 unsigned int not_run = 0;
2627 unsigned int passed = 0;
2628 unsigned int failed = 0;
2630 g_print("\n\nTest Summary\n");
2631 g_print("============\n");
2633 for (l = tests; l; l = l->next) {
2634 struct test *test = l->data;
2636 g_print("%-60s", test->name);
2638 switch (test->result) {
2639 case TEST_RESULT_NOT_RUN:
2640 g_print("Not Run\n");
2643 case TEST_RESULT_PASSED:
2644 g_print("Passed\n");
2647 case TEST_RESULT_FAILED:
2648 g_print("Failed\n");
2654 g_print("\nTotal: %d, Passed: %d(%.1f%%), Failed: %d, NotRun: %d\n",
2655 not_run + passed + failed, passed,
2656 (float) passed * 100 / (not_run + passed + failed),
2660 static void __stktest_test_cleanup(void)
2662 g_list_free_full(tests, test_destroy);
2667 static gboolean option_version = FALSE;
2669 static GOptionEntry options[] = {
2670 { "version", 'v', 0, G_OPTION_ARG_NONE, &option_version,
2671 "Show version information and exit" },
2675 int main(int argc, char **argv)
2677 GOptionContext *context;
2678 GError *error = NULL;
2681 struct sigaction sa;
2683 context = g_option_context_new(NULL);
2684 g_option_context_add_main_entries(context, options, NULL);
2686 if (g_option_context_parse(context, &argc, &argv, &error) == FALSE) {
2687 if (error != NULL) {
2688 g_printerr("%s\n", error->message);
2689 g_error_free(error);
2691 g_printerr("An unknown error occurred\n");
2695 g_option_context_free(context);
2697 if (option_version == TRUE) {
2698 printf("%s\n", VERSION);
2702 __stktest_test_init();
2704 main_loop = g_main_loop_new(NULL, FALSE);
2706 dbus_error_init(&err);
2708 conn = g_dbus_setup_bus(DBUS_BUS_SYSTEM, NULL, &err);
2710 if (dbus_error_is_set(&err) == TRUE) {
2711 fprintf(stderr, "%s\n", err.message);
2712 dbus_error_free(&err);
2714 fprintf(stderr, "Can't register with system bus\n");
2718 g_dbus_set_disconnect_function(conn, disconnect_callback, NULL, NULL);
2720 memset(&sa, 0, sizeof(sa));
2721 sa.sa_handler = sig_term;
2722 sigaction(SIGINT, &sa, NULL);
2723 sigaction(SIGTERM, &sa, NULL);
2725 watch = g_dbus_add_service_watch(conn, OFONO_SERVICE,
2726 ofono_connect, ofono_disconnect, NULL, NULL);
2728 g_main_loop_run(main_loop);
2730 g_dbus_remove_watch(conn, watch);
2732 if (ofono_running == TRUE)
2733 ofono_disconnect(conn, NULL);
2735 dbus_connection_unref(conn);
2737 g_main_loop_unref(main_loop);
2739 __stktest_test_summarize();
2740 __stktest_test_cleanup();