-/* Copyright (c) 2017. The SimGrid Team. All rights reserved. */
+/* Copyright (c) 2017-2018. 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. */
+// TODO: also test the properties attached to links
+
+#include <algorithm>
#include <simgrid/s4u.hpp>
#include <string>
static void test_host(std::string hostname)
{
simgrid::s4u::Host* thehost = simgrid::s4u::Host::by_name(hostname);
- std::map<std::string, std::string>* props = thehost->getProperties();
+ std::unordered_map<std::string, std::string>* props = thehost->get_properties();
const char* noexist = "Unknown";
const char* exist = "Hdd";
const char* value;
XBT_INFO("== Print the properties of the host '%s'", hostname.c_str());
- for (const auto& kv : *props)
- XBT_INFO(" Host property: '%s' -> '%s'", kv.first.c_str(), kv.second.c_str());
+ // Sort the properties before displaying them, so that the tests are perfectly reproducible
+ std::vector<std::string> keys;
+ for (auto const& kv : *props)
+ keys.push_back(kv.first);
+ std::sort(keys.begin(), keys.end());
+ for (std::string key : keys)
+ XBT_INFO(" Host property: '%s' -> '%s'", key.c_str(), props->at(key).c_str());
XBT_INFO("== Try to get a host property that does not exist");
- value = thehost->getProperty(noexist);
+ value = thehost->get_property(noexist);
xbt_assert(not value, "The key exists (it's not supposed to)");
XBT_INFO("== Try to get a host property that does exist");
- value = thehost->getProperty(exist);
+ value = thehost->get_property(exist);
xbt_assert(value, "\tProperty %s is undefined (where it should)", exist);
xbt_assert(!strcmp(value, "180"), "\tValue of property %s is defined to %s (where it should be 180)", exist, value);
XBT_INFO(" Property: %s old value: %s", exist, value);
XBT_INFO("== Trying to modify a host property");
- thehost->setProperty(exist, "250");
+ thehost->set_property(exist, "250");
/* Test if we have changed the value */
- value = thehost->getProperty(exist);
+ value = thehost->get_property(exist);
xbt_assert(value, "Property %s is undefined (where it should)", exist);
xbt_assert(!strcmp(value, "250"), "Value of property %s is defined to %s (where it should be 250)", exist, value);
XBT_INFO(" Property: %s old value: %s", exist, value);
/* Restore the value for the next test */
- thehost->setProperty(exist, "180");
+ thehost->set_property(exist, "180");
}
static int alice(int argc, char* argv[])
static int bob(int argc, char* argv[])
{
/* this host also tests the properties of the AS*/
- simgrid::s4u::NetZone* root = simgrid::s4u::Engine::getInstance()->getNetRoot();
+ simgrid::s4u::NetZone* root = simgrid::s4u::Engine::get_instance()->get_netzone_root();
XBT_INFO("== Print the properties of the zone");
- XBT_INFO(" Zone property: filename -> %s", root->getProperty("filename"));
- XBT_INFO(" Zone property: date -> %s", root->getProperty("date"));
- XBT_INFO(" Zone property: author -> %s", root->getProperty("author"));
+ XBT_INFO(" Zone property: filename -> %s", root->get_property("filename"));
+ XBT_INFO(" Zone property: date -> %s", root->get_property("date"));
+ XBT_INFO(" Zone property: author -> %s", root->get_property("author"));
/* Get the property list of current bob process */
- std::map<std::string, std::string>* props = simgrid::s4u::Actor::self()->getProperties();
+ std::unordered_map<std::string, std::string>* props = simgrid::s4u::Actor::self()->get_properties();
const char* noexist = "UnknownProcessProp";
XBT_ATTRIB_UNUSED const char* value;
XBT_INFO("== Try to get an actor property that does not exist");
- value = simgrid::s4u::Actor::self()->getProperty(noexist);
- xbt_assert(not value, "The property is defined (it shouldnt)");
+ value = simgrid::s4u::Actor::self()->get_property(noexist);
+ xbt_assert(not value, "The property is defined (it should not)");
return 0;
}
int main(int argc, char* argv[])
{
simgrid::s4u::Engine e(&argc, argv);
- e.loadPlatform(argv[1]);
+ e.load_platform(argv[1]);
- e.registerFunction("alice", alice);
- e.registerFunction("bob", bob);
- e.registerFunction("carole", carole);
- e.registerFunction("david", david);
+ e.register_function("alice", alice);
+ e.register_function("bob", bob);
+ e.register_function("carole", carole);
+ e.register_function("david", david);
size_t totalHosts = sg_host_count();
XBT_INFO("There are %zu hosts in the environment", totalHosts);
- simgrid::s4u::Host** hosts = sg_host_list();
- for (unsigned int i = 0; i < totalHosts; i++)
- XBT_INFO("Host '%s' runs at %.0f flops/s", hosts[i]->getCname(), hosts[i]->getSpeed());
+ std::vector<simgrid::s4u::Host*> hosts = e.get_all_hosts();
+ for (unsigned int i = 0; i < hosts.size(); i++)
+ XBT_INFO("Host '%s' runs at %.0f flops/s", hosts[i]->get_cname(), hosts[i]->get_speed());
- e.loadDeployment(argv[2]);
+ e.load_deployment(argv[2]);
e.run();
return 0;