Logo AND Algorithmique Numérique Distribuée

Public GIT Repository
add the test of allReduce replay
[simgrid.git] / examples / msg / mc / test / snapshot_comparison4.c
1 /* Copyright (c) 2012. The SimGrid Team.
2  * All rights reserved.                                                     */
3
4 /* This program is free software; you can redistribute it and/or modify it
5  * under the terms of the license (GNU LGPL) which comes with this package. */
6
7 #include <msg/msg.h>
8 #include <simgrid/modelchecker.h>
9 #include "mc/mc.h"
10
11 XBT_LOG_NEW_DEFAULT_CATEGORY(snapshot_comparison_liveness4, "Debug information for snasphot comparison liveness4 test example");
12
13 int test(int argc, char **argv);
14
15 int test(int argc, char **argv){
16
17   MSG_process_sleep(1);
18
19   XBT_INFO("**** Start test ****");
20   XBT_INFO("Free after first snapshot");
21   
22   char *toto = xbt_malloc(5);
23   XBT_INFO("Toto allocated");
24
25   void *snap1 = MC_snapshot();
26
27   MSG_process_sleep(1);
28
29   XBT_INFO("First snapshot");
30
31   xbt_free(toto);
32   XBT_INFO("Toto free");
33
34   void *snap2 = MC_snapshot();
35
36   XBT_INFO("Second snapshot");
37
38   MSG_process_sleep(1);
39   
40   MC_ignore_stack("snap2", "test");   
41   MC_ignore_stack("snap1", "test");
42
43   XBT_INFO("Test result : %d (0 = state equality, 1 = different states)", MC_compare_snapshots(snap1, snap2));
44   
45   XBT_INFO("**** End test ****");
46
47   return 0;
48 }
49
50 int main(int argc, char **argv){
51   MSG_init(&argc, argv);
52   
53   MSG_config("model-check/property","promela");
54
55   MSG_create_environment("snapshot_comparison_platform.xml");
56
57   MSG_function_register("test", test);
58
59   MSG_launch_application("deploy_snapshot_comparison.xml");
60
61   MSG_main();
62
63   return 0;
64 }