X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/b20aaa51420e1324dd0d4ab7bebd15757bfc5cf8..192e6259fa0a0a0b2aa296b0492e63b9785f1fc7:/teshsuite/simdag/platforms/basic_parsing_test.c diff --git a/teshsuite/simdag/platforms/basic_parsing_test.c b/teshsuite/simdag/platforms/basic_parsing_test.c index f7ed3041ca..f273c69d69 100644 --- a/teshsuite/simdag/platforms/basic_parsing_test.c +++ b/teshsuite/simdag/platforms/basic_parsing_test.c @@ -1,4 +1,4 @@ -/* Copyright (c) 2008, 2009, 2010. The SimGrid Team. +/* Copyright (c) 2008-2015. The SimGrid Team. * All rights reserved. */ /* This program is free software; you can redistribute it and/or modify it @@ -6,45 +6,92 @@ #include #include -#include "simdag/simdag.h" +#include "simgrid/simdag.h" +#include "surf/surf_private.h" int main(int argc, char **argv) { - /* initialisation of SD */ + /* SD initialization */ SD_workstation_t w1, w2; const SD_workstation_t *workstations; const SD_link_t *route; const char *name1; const char *name2; - int route_size,i; + int route_size, i, j, k; + int list_size; + +#ifdef _XBT_WIN32 + setbuf(stderr, NULL); + setbuf(stdout, NULL); +#else + setvbuf(stdout, NULL, _IOLBF, 0); +#endif SD_init(&argc, argv); /* creation of the environment */ SD_create_environment(argv[1]); - printf("Workstation number: %d, link number: %d\n", SD_workstation_get_number(), SD_link_get_number()); - workstations = SD_workstation_get_list(); - w1 = workstations[0]; - w2 = workstations[1]; - name1 = SD_workstation_get_name(w1); - name2 = SD_workstation_get_name(w2); - - printf("Route between %s and %s\n", name1, name2); - route = SD_route_get_list(w1, w2); - route_size = SD_route_get_size(w1, w2); - printf("Route size %d\n", route_size); - for (i = 0; i < route_size; i++) { - printf(" Link %s: latency = %f, bandwidth = %f\n", - SD_link_get_name(route[i]), SD_link_get_current_latency(route[i]), - SD_link_get_current_bandwidth(route[i])); + if (argc >= 3) { + if (!strcmp(argv[2], "ONE_LINK")) { + workstations = SD_workstation_get_list(); + w1 = workstations[0]; + w2 = workstations[1]; + name1 = SD_workstation_get_name(w1); + name2 = SD_workstation_get_name(w2); + + printf("Route between %s and %s\n", name1, name2); + route = SD_route_get_list(w1, w2); + route_size = SD_route_get_size(w1, w2); + printf("Route size %d\n", route_size); + for (i = 0; i < route_size; i++) { + printf(" Link %s: latency = %f, bandwidth = %f\n", + SD_link_get_name(route[i]), + SD_link_get_current_latency(route[i]), + SD_link_get_current_bandwidth(route[i])); + } + printf("Route latency = %f, route bandwidth = %f\n", + SD_route_get_current_latency(w1, w2), + SD_route_get_current_bandwidth(w1, w2)); + } + if (!strcmp(argv[2], "FULL_LINK")) { + workstations = SD_workstation_get_list(); + list_size = SD_workstation_get_number(); + for (i = 0; i < list_size; i++) { + w1 = workstations[i]; + name1 = SD_workstation_get_name(w1); + for (j = 0; j < list_size; j++) { + w2 = workstations[j]; + name2 = SD_workstation_get_name(w2); + printf("Route between %s and %s\n", name1, name2); + route = SD_route_get_list(w1, w2); + route_size = SD_route_get_size(w1, w2); + printf(" Route size %d\n", route_size); + for (k = 0; k < route_size; k++) { + printf(" Link %s: latency = %f, bandwidth = %f\n", + SD_link_get_name(route[k]), + SD_link_get_current_latency(route[k]), + SD_link_get_current_bandwidth(route[k])); + } + printf(" Route latency = %f, route bandwidth = %f\n", + SD_route_get_current_latency(w1, w2), + SD_route_get_current_bandwidth(w1, w2)); + } + } + } + if (!strcmp(argv[2], "PROP")) { + printf("SG_TEST_mem: %s\n", + SD_workstation_get_property_value(SD_workstation_get_by_name("host1"), + "SG_TEST_mem") + ); + printf("Author: %s\n", SD_as_router_get_property_value("AS0", "author")); + printf("AS1: %s\n", SD_as_router_get_property_value("AS1", "name")); + printf("AS2: %s\n", SD_as_router_get_property_value("AS2", "name")); + } } - printf("Route latency = %f, route bandwidth = %f\n", - SD_route_get_current_latency(w1, w2), - SD_route_get_current_bandwidth(w1, w2)); SD_exit(); return 0;