Logo AND Algorithmique Numérique Distribuée

Public GIT Repository
update surf doc to kill some more doc warnings
[simgrid.git] / teshsuite / simdag / basic6.c
index 1a1752e..f48f761 100644 (file)
@@ -1,32 +1,46 @@
+/* test scheduling 2 tasks at the same time without artificial dependencies */
+
+/* Copyright (c) 2007, 2008, 2009, 2010. The SimGrid Team.
+ * All rights reserved.                                                     */
+
+/* This program is free software; you can redistribute it and/or modify it
+ * under the terms of the license (GNU LGPL) which comes with this package. */
+
 #include <stdio.h>
 #include <stdlib.h>
 #include "simdag/simdag.h"
+#include "xbt/asserts.h"
+#include "xbt/log.h"
+
+XBT_LOG_NEW_DEFAULT_SUBCATEGORY(basic6, sd, "SimDag test basic6");
+
+int main(int argc, char **argv)
+{
+  double comm_cost[] = { 0.0, 0.0, 0.0, 0.0 };
+  double comp_cost[] = { 1.0 };
+  SD_task_t taskA, taskB;
+  xbt_dynar_t ret;
+
+  SD_init(&argc, argv);
+  SD_create_environment(argv[1]);
+
+  taskA = SD_task_create("Task A", NULL, 1.0);
+  taskB = SD_task_create("Task B", NULL, 1.0);
+
+  SD_task_schedule(taskA, 1, SD_workstation_get_list(), comp_cost,
+                   comm_cost, -1.0);
+  SD_task_schedule(taskB, 1, SD_workstation_get_list(), comp_cost,
+                   comm_cost, -1.0);
+
+  ret = SD_simulate(-1.0);
+  xbt_assert(xbt_dynar_length(ret) == 2,
+      "I was expecting the terminaison of 2 tasks, but I got %lu instead", xbt_dynar_length(ret));
+  xbt_dynar_free(&ret);
+  SD_task_destroy(taskA);
+  SD_task_destroy(taskB);
+
+  XBT_INFO("Simulation time: %f", SD_get_clock());
 
-/*
- * test: scheduling 2 tasks at the same time
- * without artificial dependecies
- * 
- * author: sahu
- */
-
-int main(int argc, char **argv) {
-    double comm_cost[] = { 0.0, 0.0, 0.0, 0.0 };
-    double comp_cost[] = { 1.0 };
-       SD_task_t taskA, taskB;
-       
-       SD_init(&argc, argv);
-    SD_create_environment(argv[1]);
-
-    taskA = SD_task_create("Task A", NULL, 1.0);
-    taskB = SD_task_create("Task B", NULL, 1.0);
-
-    SD_task_schedule(taskA, 1, SD_workstation_get_list(), comp_cost, comm_cost,
-                       -1.0);
-       SD_task_schedule(taskB, 1, SD_workstation_get_list(), comp_cost, comm_cost,
-                       -1.0);
-           
-    SD_simulate(-1.0);
-
-    SD_exit();
-    return 0;
+  SD_exit();
+  return 0;
 }