Logo AND Algorithmique Numérique Distribuée

Public GIT Repository
3e409d6a42edee2a97010c5de32a9a165e95d341
[simgrid.git] / teshsuite / msg / listen_async / listen_async.c
1 /* Bug report: https://github.com/mquinson/simgrid/issues/40
2  * 
3  * Task.listen used to be on async mailboxes as it always returned false.
4  * This occures in Java and C, but is only tested here in C.
5  */
6
7 #include "simgrid/msg.h"
8
9 XBT_LOG_NEW_DEFAULT_CATEGORY(msg_test, "Messages specific for this msg example");
10
11 static int server(int argc, char *argv[])
12 {
13    msg_task_t task =  MSG_task_create("a", 0, 0, (char*)"Some data");
14    MSG_task_isend(task, "mailbox");
15
16    xbt_assert(MSG_task_listen("mailbox")); // True (1)
17    XBT_INFO("Task listen works on regular mailboxes");
18    task = NULL;
19    MSG_task_receive(&task, "mailbox");
20    xbt_assert(!strcmp("Some data", MSG_task_get_data(task)), "Data received: %s", (char*)MSG_task_get_data(task));
21    MSG_task_destroy(task);
22    XBT_INFO("Data successfully received from regular mailbox");
23
24    MSG_mailbox_set_async("mailbox2");
25    task = MSG_task_create("b", 0, 0, (char*)"More data");
26    MSG_task_isend(task, "mailbox2");
27
28    xbt_assert(MSG_task_listen("mailbox2")); // used to break.
29    XBT_INFO("Task listen works on asynchronous mailboxes");
30    task = NULL;
31    MSG_task_receive(&task, "mailbox2");
32    xbt_assert(!strcmp("More data", MSG_task_get_data(task)));
33    MSG_task_destroy(task);
34    XBT_INFO("Data successfully received from asynchronous mailbox");
35
36    return 0;
37 }
38
39 int main(int argc, char *argv[])
40 {
41    MSG_init(&argc, argv);
42    xbt_assert(argc==2);
43    MSG_create_environment(argv[1]);
44    MSG_process_create("test", server, NULL, MSG_host_by_name("Tremblay"));
45    MSG_main();
46
47    return 0;
48 }