-
Notifications
You must be signed in to change notification settings - Fork 20
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
1 parent
521924e
commit deb1d07
Showing
3 changed files
with
244 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
241 changes: 241 additions & 0 deletions
241
...es/compute_services/batch_standard_and_pilot_jobs/BatchServiceResourceInformationTest.cpp
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,241 @@ | ||
/** | ||
* Copyright (c) 2017-2021. The WRENCH Team. | ||
* | ||
* This program is free software: you can redistribute it and/or modify | ||
* it under the terms of the GNU General Public License as published by | ||
* the Free Software Foundation, either version 3 of the License, or | ||
* (at your option) any later version. | ||
*/ | ||
|
||
#include <cmath> | ||
|
||
#include <gtest/gtest.h> | ||
#include <wrench-dev.h> | ||
|
||
#include "../../../include/TestWithFork.h" | ||
#include "../../../include/UniqueTmpPathPrefix.h" | ||
|
||
#define EPSILON 0.005 | ||
|
||
|
||
class BatchComputeServiceTestResourceInformation : public ::testing::Test { | ||
|
||
|
||
public: | ||
// Default | ||
std::shared_ptr<wrench::BatchComputeService> compute_service = nullptr; | ||
|
||
std::shared_ptr<wrench::Workflow> workflow; | ||
|
||
void do_ResourceInformation_test(); | ||
|
||
protected: | ||
~BatchComputeServiceTestResourceInformation() { | ||
workflow->clear(); | ||
wrench::Simulation::removeAllFiles(); | ||
} | ||
|
||
BatchComputeServiceTestResourceInformation() { | ||
|
||
// Create the simplest workflow | ||
workflow = wrench::Workflow::createWorkflow(); | ||
|
||
// Create a two-host quad-core platform file | ||
std::string xml = "<?xml version='1.0'?>" | ||
"<!DOCTYPE platform SYSTEM \"https://simgrid.org/simgrid.dtd\">" | ||
"<platform version=\"4.1\"> " | ||
" <zone id=\"AS0\" routing=\"Full\"> " | ||
" <host id=\"Host1\" speed=\"10Gf\" core=\"4\"> " | ||
" <prop id=\"ram\" value=\"2048B\"/> " | ||
" </host> " | ||
" <host id=\"Host2\" speed=\"10Gf\" core=\"4\"> " | ||
" <prop id=\"ram\" value=\"2048B\"/> " | ||
" </host> " | ||
" <link id=\"1\" bandwidth=\"5000GBps\" latency=\"0us\"/>" | ||
" <route src=\"Host1\" dst=\"Host2\"> <link_ctn id=\"1\"/> </route>" | ||
" </zone> " | ||
"</platform>"; | ||
FILE *platform_file = fopen(platform_file_path.c_str(), "w"); | ||
fprintf(platform_file, "%s", xml.c_str()); | ||
fclose(platform_file); | ||
} | ||
|
||
std::string platform_file_path = UNIQUE_TMP_PATH_PREFIX + "platform.xml"; | ||
}; | ||
|
||
|
||
/**********************************************************************/ | ||
/** RESOURCE INFORMATION SIMULATION TEST **/ | ||
/**********************************************************************/ | ||
|
||
class ResourceInformationBatchTestWMS : public wrench::ExecutionController { | ||
|
||
public: | ||
ResourceInformationBatchTestWMS(BatchComputeServiceTestResourceInformation *test, | ||
const std::string& hostname) : wrench::ExecutionController(hostname, "test") { | ||
this->test = test; | ||
} | ||
|
||
private: | ||
BatchComputeServiceTestResourceInformation *test; | ||
|
||
int main() override { | ||
|
||
// Create a job manager | ||
auto job_manager = this->createJobManager(); | ||
|
||
// Ask questions about resources | ||
|
||
// Get number of Hosts | ||
unsigned long num_hosts; | ||
|
||
num_hosts = this->test->compute_service->getNumHosts(); | ||
if (num_hosts != 2) { | ||
throw std::runtime_error("getNumHosts() should return 2 for compute service #1"); | ||
} | ||
|
||
// Get Host list | ||
std::vector<std::string> host_list; | ||
host_list = this->test->compute_service->getHosts(); | ||
if (host_list.size() != 2) { | ||
throw std::runtime_error("getHosts() should return a list with 2 items for compute service #1"); | ||
} | ||
if (std::find(host_list.begin(), host_list.end(), "Host1") == host_list.end()) { | ||
throw std::runtime_error("getHosts() should return a list that contains 'Host1' for compute service #1"); | ||
} | ||
if (std::find(host_list.begin(), host_list.end(), "Host2") == host_list.end()) { | ||
throw std::runtime_error("getHosts() should return a list that contains 'Host2' for compute service #1"); | ||
} | ||
|
||
// Get number of Cores | ||
std::map<std::string, unsigned long> num_cores; | ||
|
||
num_cores = this->test->compute_service->getPerHostNumCores(); | ||
if ((num_cores.size() != 2) or ((*(num_cores.begin())).second != 4) or ((*(++num_cores.begin())).second != 4)) { | ||
throw std::runtime_error("getHostNumCores() should return {4,4} for compute service #1"); | ||
} | ||
|
||
if (this->test->compute_service->getTotalNumCores() != 8) { | ||
throw std::runtime_error("getHostTotalNumCores() should return 8 for compute service #1"); | ||
} | ||
|
||
// Get Ram capacities | ||
std::map<std::string, double> ram_capacities; | ||
|
||
ram_capacities = this->test->compute_service->getMemoryCapacity(); | ||
std::vector<double> sorted_ram_capacities; | ||
sorted_ram_capacities.reserve(ram_capacities.size()); | ||
for (auto const &r: ram_capacities) { | ||
sorted_ram_capacities.push_back(r.second); | ||
} | ||
std::sort(sorted_ram_capacities.begin(), sorted_ram_capacities.end()); | ||
if ((sorted_ram_capacities.size() != 2) or | ||
(std::abs(sorted_ram_capacities.at(0) - 2048) > EPSILON) or | ||
(std::abs(sorted_ram_capacities.at(1) - 2048) > EPSILON)) { | ||
throw std::runtime_error("getHostMemoryCapacity() should return {2048,2048} for compute service"); | ||
} | ||
|
||
// Get Core flop rates | ||
std::map<std::string, double> core_flop_rates = this->test->compute_service->getCoreFlopRate(); | ||
std::vector<double> sorted_core_flop_rates; | ||
sorted_core_flop_rates.reserve(core_flop_rates.size()); | ||
for (auto const &f: core_flop_rates) { | ||
sorted_core_flop_rates.push_back(f.second); | ||
} | ||
std::sort(sorted_core_flop_rates.begin(), sorted_core_flop_rates.end()); | ||
if ((sorted_core_flop_rates.size() != 2) or | ||
(std::abs(sorted_core_flop_rates.at(0) - 1e+10) > EPSILON) or | ||
(std::abs(sorted_core_flop_rates.at(1) - 1e+10) > EPSILON)) { | ||
throw std::runtime_error("getCoreFlopRate() should return {10,10} for compute service"); | ||
} | ||
|
||
// Create a job that will use cores on compute service #1 | ||
std::shared_ptr<wrench::WorkflowTask> t1 = this->test->workflow->addTask("task1", 60.0000, 3, 3, 0); | ||
std::shared_ptr<wrench::WorkflowTask> t2 = this->test->workflow->addTask("task2", 60000000000.0001, 2, 2, 0); | ||
|
||
std::vector<std::shared_ptr<wrench::WorkflowTask>> tasks; | ||
tasks.push_back(t1); | ||
tasks.push_back(t2); | ||
auto job = job_manager->createStandardJob(tasks); | ||
std::map<std::string, std::string> batch_job_args; | ||
batch_job_args["-N"] = std::to_string(2); // Number of nodes/tasks | ||
batch_job_args["-t"] = std::to_string(1800);// Time in seconds (at least 1 minute) | ||
batch_job_args["-c"] = std::to_string(3); //number of cores | ||
job_manager->submitJob(job, this->test->compute_service, batch_job_args); | ||
|
||
wrench::Simulation::sleep(1.0); | ||
|
||
// Get number of idle cores | ||
std::map<std::string, unsigned long> num_idle_cores = this->test->compute_service->getPerHostNumIdleCores(); | ||
std::vector<unsigned long> idle_core_counts; | ||
idle_core_counts.reserve(num_idle_cores.size()); | ||
for (auto const &c: num_idle_cores) { | ||
idle_core_counts.push_back(c.second); | ||
} | ||
std::sort(idle_core_counts.begin(), idle_core_counts.end()); | ||
|
||
if ((idle_core_counts.size() != 2) or | ||
(idle_core_counts[0] != 1) or | ||
(idle_core_counts[1] != 1)) { | ||
throw std::runtime_error("getPerHostNumIdleCores() should return {1,1} for compute service " | ||
"(instead {" + std::to_string(idle_core_counts[0]) + "," + std::to_string(idle_core_counts[1]) + "})"); | ||
} | ||
|
||
if (this->test->compute_service->getTotalNumIdleCores() != 2) { | ||
throw std::runtime_error("getTotalNumIdleCores() should return 2 for compute service"); | ||
} | ||
|
||
this->test->compute_service->getPerHostAvailableMemoryCapacity();// coverage | ||
|
||
// Wait for the workflow execution event | ||
auto event = this->waitForNextEvent(); | ||
if (not std::dynamic_pointer_cast<wrench::StandardJobCompletedEvent>(event)) { | ||
throw std::runtime_error("Unexpected workflow execution event!"); | ||
} | ||
|
||
|
||
this->test->workflow->removeTask(t1); | ||
this->test->workflow->removeTask(t2); | ||
|
||
return 0; | ||
} | ||
}; | ||
|
||
|
||
TEST_F(BatchComputeServiceTestResourceInformation, ResourceInformation) { | ||
DO_TEST_WITH_FORK(do_ResourceInformation_test); | ||
} | ||
|
||
void BatchComputeServiceTestResourceInformation::do_ResourceInformation_test() { | ||
|
||
// Create and initialize a simulation | ||
auto simulation = wrench::Simulation::createSimulation(); | ||
int argc = 1; | ||
char **argv = (char **) calloc(argc, sizeof(char *)); | ||
argv[0] = strdup("unit_test"); | ||
// argv[1] = strdup("--wrench-full-log"); | ||
|
||
simulation->init(&argc, argv); | ||
|
||
// Setting up the platform | ||
ASSERT_NO_THROW(simulation->instantiatePlatform(platform_file_path)); | ||
|
||
// Create 1 Compute Service that manages Host1 and Host2 | ||
ASSERT_NO_THROW(this->compute_service = simulation->add( | ||
new wrench::BatchComputeService("Host1", | ||
{"Host1","Host2"}, | ||
"", | ||
{}))); | ||
|
||
// Create the WMS | ||
std::shared_ptr<wrench::ExecutionController> wms; | ||
|
||
ASSERT_NO_THROW(wms = simulation->add(new ResourceInformationBatchTestWMS(this, "Host1"))); | ||
|
||
ASSERT_NO_THROW(simulation->launch()); | ||
|
||
|
||
for (int i = 0; i < argc; i++) | ||
free(argv[i]); | ||
free(argv); | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters