Logo AND Algorithmique Numérique Distribuée

Public GIT Repository
model-checker : update snapshot_comparison tests
[simgrid.git] / examples / msg / mc / test / snapshot_comparison5.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_liveness5, "Debug information for snasphot comparison liveness5 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("Increment local variable");
21
22   int j = 0;
23   XBT_INFO("j = %d", j);
24
25   void *snap1 = MC_snapshot();
26
27   MSG_process_sleep(1);
28
29   XBT_INFO("First snapshot");
30
31   j = 1;
32   XBT_INFO("j = %d", j);
33  
34   void *snap2 = MC_snapshot();
35
36   MSG_process_sleep(1);
37
38   XBT_INFO("Second snapshot");
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   xbt_abort();
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 }