Logo AND Algorithmique Numérique Distribuée

Public GIT Repository
convert trace-integration test
[simgrid.git] / teshsuite / s4u / trace-integration / trace-integration.cpp
@@ -4,41 +4,37 @@
 /* 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 "simgrid/msg.h"
+#include "simgrid/s4u.hpp"
 
 XBT_LOG_NEW_DEFAULT_CATEGORY(test_trace_integration, "Messages specific for this msg example");
 
 /** test the trace integration cpu model */
-static int test_trace(int argc, char *argv[])
+static void test_trace(int argc, char* argv[])
 {
-  xbt_assert (argc == 3,"Wrong number of arguments!\nUsage: %s <task computational size in FLOPS> <task priority>", argv[0]);
+  xbt_assert(argc == 3, "Wrong number of arguments!\nUsage: %s <task computational size in FLOPS> <task priority>",
+             argv[0]);
 
-  double task_comp_size = xbt_str_parse_double(argv[1], "Invalid computational size: %s");
-  double task_prio      = xbt_str_parse_double(argv[2], "Invalid task priority: %s");
+  double task_comp_size = std::stod(argv[1]);
+  double task_prio      = std::stod(argv[2]);
 
   XBT_INFO("Testing the trace integration cpu model: CpuTI");
   XBT_INFO("Task size: %f", task_comp_size);
   XBT_INFO("Task prio: %f", task_prio);
 
   /* Create and execute a single task. */
-  msg_task_t task = MSG_task_create("proc 0", task_comp_size, 0, NULL);
-  MSG_task_set_priority(task, task_prio);
-  MSG_task_execute(task);
-  MSG_task_destroy(task);
-
+  simgrid::s4u::ExecPtr exec = simgrid::s4u::this_actor::exec_init(task_comp_size);
+  exec->set_priority(task_prio)->wait();
   XBT_INFO("Test finished");
-
-  return 0;
 }
 
-int main(int argc, char *argv[])
+int main(int argc, charargv[])
 {
-  MSG_init(&argc, argv);
+  simgrid::s4u::Engine e(&argc, argv);
   xbt_assert(argc > 2, "Usage: %s test_trace_integration_model.xml deployment.xml\n", argv[0]);
 
-  MSG_function_register("test_trace", test_trace);
-  MSG_create_environment(argv[1]);
-  MSG_launch_application(argv[2]);
-
-  return MSG_main() != MSG_OK;
+  e.register_function("test_trace", test_trace);
+  e.load_platform(argv[1]);
+  e.load_deployment(argv[2]);
+  e.run();
+  return 0;
 }