1
0
mirror of https://github.com/OpenNebula/one.git synced 2025-01-11 05:17:41 +03:00

Feature #379: Testing for Life Cycle Manager.

This commit is contained in:
Carlos Martín 2010-11-10 13:58:48 +01:00 committed by Ruben S. Montero
parent 6b8855b0e3
commit 07ce708c3e
7 changed files with 1612 additions and 2 deletions

View File

@ -65,7 +65,7 @@ public:
* @param vid VM unique id. This is the argument of the passed to the
* invoked action.
*/
void trigger(
virtual void trigger(
Actions action,
int vid);

View File

@ -63,7 +63,7 @@ public:
* @param vid VM unique id. This is the argument of the passed to the
* invoked action.
*/
void trigger(
virtual void trigger(
Actions action,
int vid);

109
src/lcm/test/DummyManager.h Normal file
View File

@ -0,0 +1,109 @@
/* -------------------------------------------------------------------------- */
/* Copyright 2002-2010, OpenNebula Project Leads (OpenNebula.org) */
/* */
/* Licensed under the Apache License, Version 2.0 (the "License"); you may */
/* not use this file except in compliance with the License. You may obtain */
/* a copy of the License at */
/* */
/* http://www.apache.org/licenses/LICENSE-2.0 */
/* */
/* Unless required by applicable law or agreed to in writing, software */
/* distributed under the License is distributed on an "AS IS" BASIS, */
/* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. */
/* See the License for the specific language governing permissions and */
/* limitations under the License. */
/* -------------------------------------------------------------------------- */
#ifndef DUMMY_MANAGER_TEST_H
#define DUMMY_MANAGER_TEST_H
#include "TransferManager.h"
#include "VirtualMachineManager.h"
#include "LifeCycleManager.h"
/**
* The Dummy Manager will ignore any trigger calls but FINALIZE, unless the lcm
* actions are set.
*/
class DummyManager
{
protected:
vector<LifeCycleManager::Actions> actions;
int index;
DummyManager():index(0){}
public:
void clear_actions()
{
index = 0;
actions.clear();
}
void set_actions(vector<LifeCycleManager::Actions>& _actions)
{
index = 0;
actions = _actions;
}
void trigger_lcm_action(int _vid)
{
if(index < (int) actions.size())
{
(Nebula::instance().get_lcm())->trigger(actions[index], _vid);
index++;
}
}
};
class TransferManagerTest : public TransferManager, public DummyManager
{
public:
TransferManagerTest(
VirtualMachinePool * _vmpool,
HostPool * _hpool,
vector<const Attribute*>& _mads):
TransferManager(_vmpool, _hpool, _mads){}
void trigger(Actions action, int _vid)
{
if( action == FINALIZE )
{
TransferManager::trigger(action, _vid);
}
else
{
trigger_lcm_action(_vid);
}
}
};
class VirtualMachineManagerTest : public VirtualMachineManager, public DummyManager
{
public:
VirtualMachineManagerTest(
VirtualMachinePool * _vmpool,
HostPool * _hpool,
time_t _timer_period,
time_t _poll_period,
vector<const Attribute*>& _mads):
VirtualMachineManager( _vmpool, _hpool, _timer_period,
_poll_period, _mads){}
void trigger(Actions action, int _vid)
{
if( action == FINALIZE )
{
VirtualMachineManager::trigger(action, _vid);
}
else
{
trigger_lcm_action(_vid);
}
}
};
#endif /* DUMMY_MANAGER_TEST_H */

View File

@ -0,0 +1,99 @@
/* -------------------------------------------------------------------------- */
/* Copyright 2002-2010, OpenNebula Project Leads (OpenNebula.org) */
/* */
/* Licensed under the Apache License, Version 2.0 (the "License"); you may */
/* not use this file except in compliance with the License. You may obtain */
/* a copy of the License at */
/* */
/* http://www.apache.org/licenses/LICENSE-2.0 */
/* */
/* Unless required by applicable law or agreed to in writing, software */
/* distributed under the License is distributed on an "AS IS" BASIS, */
/* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. */
/* See the License for the specific language governing permissions and */
/* limitations under the License. */
/* -------------------------------------------------------------------------- */
#include "LifeCycleManagerTest.h"
string LifeCycleManagerTest::db_name;
bool LifeCycleManagerTest::mysql;
/* -------------------------------------------------------------------------- */
/* -------------------------------------------------------------------------- */
void show_options ()
{
cout << "Options:\n";
cout << " -h --help Show this help\n"
" -s --sqlite Run Sqlite tests (default)\n"
" -m --mysql Run MySQL tests\n"
" -l --log Keep the log file, test.log\n";
};
int main(int argc, char ** argv)
{
// Option flags
bool sqlite_flag = true;
bool log_flag = false;
// Long options
const struct option long_opt[] =
{
{ "sqlite", 0, NULL, 's'},
{ "mysql", 0, NULL, 'm'},
{ "log", 0, NULL, 'l'},
{ "help", 0, NULL, 'h'}
};
int c;
while ((c = getopt_long (argc, argv, "smlh", long_opt, NULL)) != -1)
switch (c)
{
case 'm':
sqlite_flag = false;
break;
case 'l':
log_flag = true;
break;
case 'h':
show_options();
return 0;
}
// We need to set the log file, otherwise it will end in a dead-lock
NebulaLog::init_log_system(NebulaLog::FILE, Log::DEBUG, "test.log");
NebulaLog::log("Test", Log::INFO, "Test started");
CppUnit::TextUi::TestRunner runner;
SETUP_XML_WRITER(runner, "output.xml")
runner.addTest( LifeCycleManagerTest::suite() );
if (sqlite_flag)
{
LifeCycleManagerTest::mysql = false;
NebulaLog::log("Test", Log::INFO, "Running Sqlite tests...");
cout << "\nRunning Sqlite tests...\n";
}
else
{
LifeCycleManagerTest::mysql = true;
NebulaLog::log("Test", Log::INFO, "Running MySQL tests...");
cout << "\nRunning MySQL tests...\n";
}
runner.run();
END_XML_WRITER
if (!log_flag)
remove("test.log");
NebulaLog::finalize_log_system();
return 0;
}

View File

@ -0,0 +1,836 @@
/* -------------------------------------------------------------------------- */
/* Copyright 2002-2010, OpenNebula Project Leads (OpenNebula.org) */
/* */
/* Licensed under the Apache License, Version 2.0 (the "License"); you may */
/* not use this file except in compliance with the License. You may obtain */
/* a copy of the License at */
/* */
/* http://www.apache.org/licenses/LICENSE-2.0 */
/* */
/* Unless required by applicable law or agreed to in writing, software */
/* distributed under the License is distributed on an "AS IS" BASIS, */
/* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. */
/* See the License for the specific language governing permissions and */
/* limitations under the License. */
/* -------------------------------------------------------------------------- */
#include "Nebula.h"
#include "DummyManager.h"
#include "SqliteDB.h"
#include "MySqlDB.h"
#include <string>
#include <iostream>
#include <stdlib.h>
#include <getopt.h>
#include <TestFixture.h>
#include <TestAssert.h>
#include <TestSuite.h>
#include <TestCaller.h>
#include <ui/text/TestRunner.h>
#include <cppunit/extensions/HelperMacros.h>
#include <unistd.h>
#include "test/one_test_common.h"
using namespace std;
const int uids[] = {123, 261, 123};
const string names[] = {"VM one", "Second VM", "VM 3"};
const string templates[] =
{
"NAME = \"VM one\"\n"
"MEMORY = 128\n"
"CPU = 1",
"NAME = \"Second VM\"\n"
"MEMORY = 256\n"
"CPU = 2",
"NAME = \"VM 3\"\n"
"MEMORY = 1024\n"
"CPU = 1"
};
static int hid = 123;
static string hostname = "test_hostname";
static string vmm_mad = "vmm_mad";
static string tm_mad = "tm_mad";
static string vmdir = "vmdir";
class LifeCycleManagerTest : public CppUnit::TestFixture
{
CPPUNIT_TEST_SUITE (LifeCycleManagerTest);
CPPUNIT_TEST ( lcm_init_to_prolog );
CPPUNIT_TEST ( lcm_init_to_prolog_resume );
CPPUNIT_TEST ( prolog_to_boot );
CPPUNIT_TEST ( prolog_to_failed );
CPPUNIT_TEST ( prolog_resume_to_boot );
CPPUNIT_TEST ( prolog_resume_to_failed );
CPPUNIT_TEST ( boot_to_running );
CPPUNIT_TEST ( boot_to_failed );
CPPUNIT_TEST ( running_to_save_migrate );
CPPUNIT_TEST ( running_to_save_stop );
CPPUNIT_TEST ( running_to_shutdown );
CPPUNIT_TEST ( running_to_save_suspend );
CPPUNIT_TEST ( running_to_migrate );
CPPUNIT_TEST ( running_to_cancel );
CPPUNIT_TEST ( save_migrate_to_prolog_migrate );
CPPUNIT_TEST ( save_migrate_to_running );
CPPUNIT_TEST ( prolog_migrate_to_boot );
CPPUNIT_TEST ( prolog_migrate_to_failed );
CPPUNIT_TEST ( cancel_to_done );
CPPUNIT_TEST ( cancel_to_running );
CPPUNIT_TEST ( migrate_to_running );
CPPUNIT_TEST ( migrate_to_failed );
CPPUNIT_TEST ( save_suspend_to_suspended );
CPPUNIT_TEST ( save_suspend_to_running );
CPPUNIT_TEST ( shutdown_to_epilog );
CPPUNIT_TEST ( shutdown_to_running );
CPPUNIT_TEST ( save_stop_to_epilog_stop );
CPPUNIT_TEST ( save_stop_to_running );
CPPUNIT_TEST ( epilog_to_done );
CPPUNIT_TEST ( epilog_to_failed );
CPPUNIT_TEST ( epilog_stop_to_stop );
CPPUNIT_TEST ( epilog_stop_to_failed );
CPPUNIT_TEST_SUITE_END ();
private:
VirtualMachine * vm;
VirtualMachinePool * vmpool;
HostPool * hpool;
LifeCycleManager * lcm;
VirtualMachineManagerTest * vmm;
TransferManagerTest * tm;
DispatchManager * dm;
int oid;
int rc;
vector<LifeCycleManager::Actions> tm_actions;
vector<LifeCycleManager::Actions> vmm_actions;
void wait(int nullllll)
{
sleep(2);
}
/**
* Wait until the VM changes to the specified state.
* There is a time-out of 3 seconds.
*/
void wait_assert( VirtualMachine* vm,
VirtualMachine::VmState state,
VirtualMachine::LcmState lcm_state = VirtualMachine::RUNNING)
{
int n_steps = 100;
int step = 30000;
int i = 0;
while( !(
(
vm->get_state() == state
&&
(
state != VirtualMachine::ACTIVE
||
vm->get_lcm_state() == lcm_state
)
)
||
i > n_steps ))
{
usleep(step);
i++;
}
CPPUNIT_ASSERT( vm->get_state() == state );
if( state == VirtualMachine::ACTIVE)
{
CPPUNIT_ASSERT( vm->get_lcm_state() == lcm_state );
}
}
/**
* Allocates the indexth VM template
*/
int allocate(int index)
{
VirtualMachineTemplate * vm_template;
int oid;
char * error_msg = 0;
int rc;
string err;
vm_template = new VirtualMachineTemplate;
rc = vm_template->parse(templates[index],&error_msg);
if( rc == 0 )
{
return vmpool->allocate(uids[index], vm_template, &oid,
err, false);
}
else
{
return -1;
}
};
/**
* Allocates a VM and sets it to pending state, creaing a history entry.
* The VM returned is locked
*/
VirtualMachine* allocate_pending(int index)
{
oid = allocate(index);
CPPUNIT_ASSERT(oid >= 0);
vm = vmpool->get(oid,true);
vm->unlock();
CPPUNIT_ASSERT( vm != 0 );
CPPUNIT_ASSERT( vm->get_state() == VirtualMachine::PENDING );
vm->lock();
vm->add_history(hid,hostname,vmdir,vmm_mad,tm_mad);
rc = vmpool->update_history(vm);
CPPUNIT_ASSERT( rc == 0 );
vmpool->update(vm); //Insert last_seq in the DB
return vm;
}
/**
* Allocates a VM and sets it to running state.
* The VM returned is unlocked
*/
VirtualMachine* allocate_running(int index)
{
vm = allocate_pending(index);
tm_actions.push_back(LifeCycleManager::PROLOG_SUCCESS);
tm->set_actions(tm_actions);
vmm_actions.push_back(LifeCycleManager::DEPLOY_SUCCESS);
vmm->set_actions(vmm_actions);
rc = dm->deploy(vm);
vm->unlock();
wait_assert(vm, VirtualMachine::ACTIVE, VirtualMachine::RUNNING);
tm->clear_actions();
vmm->clear_actions();
tm_actions.clear();
vmm_actions.clear();
return vm;
}
public:
static bool mysql;
static string db_name;
static bool isMysql()
{
return mysql;
}
void setUp()
{
// Create var dir.
string command = "mkdir -p var";
std::system(command.c_str());
Nebula& neb = Nebula::instance();
neb.start();
lcm = neb.get_lcm();
vmpool = neb.get_vmpool();
hpool = neb.get_hpool();
vmm = static_cast<VirtualMachineManagerTest*>(neb.get_vmm());
tm = static_cast<TransferManagerTest*>(neb.get_tm());
dm = neb.get_dm();
}
void tearDown()
{
tm_actions.clear();
vmm_actions.clear();
// -----------------------------------------------------------
// Stop the managers & free resources
// -----------------------------------------------------------
vmm->trigger(VirtualMachineManager::FINALIZE,0);
lcm->trigger(LifeCycleManager::FINALIZE,0);
tm->trigger(TransferManager::FINALIZE,0);
dm->trigger(DispatchManager::FINALIZE,0);
//sleep to wait drivers???
pthread_join(vmm->get_thread_id(),0);
pthread_join(lcm->get_thread_id(),0);
pthread_join(tm->get_thread_id(),0);
pthread_join(dm->get_thread_id(),0);
//XML Library
xmlCleanupParser();
if (mysql)
{
SqlDB * db;
db = new MySqlDB("localhost","oneadmin","oneadmin",NULL);
ostringstream oss;
oss << "DROP DATABASE IF EXISTS " << db_name;
db->exec(oss);
delete db;
}
// Clean var dir.
string command = "rm -r var";
std::system(command.c_str());
}
/* -------------------------------------------------------------------------- */
/* -------------------------------------------------------------------------- */
void lcm_init_to_prolog()
{
vm = allocate_pending(0);
rc = dm->deploy(vm);
vm->unlock();
wait_assert(vm, VirtualMachine::ACTIVE, VirtualMachine::PROLOG );
}
/* -------------------------------------------------------------------------- */
void lcm_init_to_prolog_resume()
{
vm = allocate_pending(0);
vm->set_reason(History::STOP_RESUME);
vm->cp_history();
rc = dm->deploy(vm);
vm->unlock();
wait_assert(vm, VirtualMachine::ACTIVE, VirtualMachine::PROLOG_RESUME );
}
/* -------------------------------------------------------------------------- */
void prolog_to_boot()
{
vm = allocate_pending(0);
tm_actions.push_back(LifeCycleManager::PROLOG_SUCCESS);
tm->set_actions(tm_actions);
rc = dm->deploy(vm);
vm->unlock();
wait_assert(vm, VirtualMachine::ACTIVE, VirtualMachine::BOOT );
}
/* -------------------------------------------------------------------------- */
void prolog_to_failed()
{
vm = allocate_pending(0);
tm_actions.push_back(LifeCycleManager::PROLOG_FAILURE);
tm->set_actions(tm_actions);
rc = dm->deploy(vm);
vm->unlock();
wait_assert(vm, VirtualMachine::FAILED );
}
/* -------------------------------------------------------------------------- */
void prolog_resume_to_boot()
{
vm = allocate_pending(0);
vm->set_reason(History::STOP_RESUME);
vm->cp_history();
tm_actions.push_back(LifeCycleManager::PROLOG_SUCCESS);
tm->set_actions(tm_actions);
rc = dm->deploy(vm);
vm->unlock();
wait_assert(vm, VirtualMachine::ACTIVE, VirtualMachine::BOOT );
}
/* -------------------------------------------------------------------------- */
void prolog_resume_to_failed()
{
vm = allocate_pending(0);
vm->set_reason(History::STOP_RESUME);
vm->cp_history();
tm_actions.push_back(LifeCycleManager::PROLOG_FAILURE);
tm->set_actions(tm_actions);
rc = dm->deploy(vm);
vm->unlock();
wait_assert(vm, VirtualMachine::FAILED );
}
/* -------------------------------------------------------------------------- */
void boot_to_running()
{
allocate_running(0);
}
/* -------------------------------------------------------------------------- */
void boot_to_failed()
{
vm = allocate_pending(0);
tm_actions.push_back(LifeCycleManager::PROLOG_SUCCESS);
tm->set_actions(tm_actions);
vmm_actions.push_back(LifeCycleManager::DEPLOY_FAILURE);
vmm->set_actions(vmm_actions);
rc = dm->deploy(vm);
vm->unlock();
wait_assert(vm, VirtualMachine::FAILED );
}
/* -------------------------------------------------------------------------- */
void running_to_save_migrate()
{
vm = allocate_running(0);
vm->add_history(hid,hostname,vmdir,vmm_mad,tm_mad);
rc = vmpool->update_history(vm);
CPPUNIT_ASSERT( rc == 0 );
vmpool->update(vm); //Insert last_seq in the DB
dm->migrate(vm);
wait_assert(vm, VirtualMachine::ACTIVE, VirtualMachine::SAVE_MIGRATE );
}
/* -------------------------------------------------------------------------- */
void running_to_save_stop()
{
vm = allocate_running(0);
dm->stop(vm->get_oid());
wait_assert(vm, VirtualMachine::ACTIVE, VirtualMachine::SAVE_STOP );
}
/* -------------------------------------------------------------------------- */
void running_to_shutdown()
{
vm = allocate_running(0);
dm->shutdown(vm->get_oid());
wait_assert(vm, VirtualMachine::ACTIVE, VirtualMachine::SHUTDOWN );
}
/* -------------------------------------------------------------------------- */
void running_to_save_suspend()
{
vm = allocate_running(0);
dm->suspend(vm->get_oid());
wait_assert(vm, VirtualMachine::ACTIVE, VirtualMachine::SAVE_SUSPEND );
}
/* -------------------------------------------------------------------------- */
void running_to_migrate()
{
vm = allocate_running(0);
dm->live_migrate(vm);
wait_assert(vm, VirtualMachine::ACTIVE, VirtualMachine::MIGRATE );
}
/* -------------------------------------------------------------------------- */
void running_to_cancel()
{
vm = allocate_running(0);
dm->cancel(vm->get_oid());
wait_assert(vm, VirtualMachine::ACTIVE, VirtualMachine::CANCEL );
}
/* -------------------------------------------------------------------------- */
void save_migrate_to_prolog_migrate()
{
vm = allocate_running(0);
vm->add_history(hid,hostname,vmdir,vmm_mad,tm_mad);
rc = vmpool->update_history(vm);
CPPUNIT_ASSERT( rc == 0 );
vmpool->update(vm); //Insert last_seq in the DB
vmm_actions.push_back(LifeCycleManager::SAVE_SUCCESS);
vmm->set_actions(vmm_actions);
dm->migrate(vm);
wait_assert(vm, VirtualMachine::ACTIVE,VirtualMachine::PROLOG_MIGRATE );
}
/* -------------------------------------------------------------------------- */
void save_migrate_to_running()
{
vm = allocate_running(0);
vm->add_history(hid,hostname,vmdir,vmm_mad,tm_mad);
rc = vmpool->update_history(vm);
CPPUNIT_ASSERT( rc == 0 );
vmpool->update(vm); //Insert last_seq in the DB
vmm_actions.push_back(LifeCycleManager::SAVE_FAILURE);
vmm->set_actions(vmm_actions);
dm->migrate(vm);
wait_assert(vm, VirtualMachine::ACTIVE, VirtualMachine::RUNNING );
}
/* -------------------------------------------------------------------------- */
void prolog_migrate_to_boot()
{
vm = allocate_running(0);
vm->add_history(hid,hostname,vmdir,vmm_mad,tm_mad);
rc = vmpool->update_history(vm);
CPPUNIT_ASSERT( rc == 0 );
vmpool->update(vm); //Insert last_seq in the DB
tm_actions.push_back(LifeCycleManager::PROLOG_SUCCESS);
tm->set_actions(tm_actions);
vmm_actions.push_back(LifeCycleManager::SAVE_SUCCESS);
vmm->set_actions(vmm_actions);
dm->migrate(vm);
wait_assert(vm, VirtualMachine::ACTIVE, VirtualMachine::BOOT );
}
/* -------------------------------------------------------------------------- */
void prolog_migrate_to_failed()
{
vm = allocate_running(0);
vm->add_history(hid,hostname,vmdir,vmm_mad,tm_mad);
rc = vmpool->update_history(vm);
CPPUNIT_ASSERT( rc == 0 );
vmpool->update(vm); //Insert last_seq in the DB
tm_actions.push_back(LifeCycleManager::PROLOG_FAILURE);
tm->set_actions(tm_actions);
vmm_actions.push_back(LifeCycleManager::SAVE_SUCCESS);
vmm->set_actions(vmm_actions);
dm->migrate(vm);
wait_assert(vm, VirtualMachine::FAILED);
}
/* -------------------------------------------------------------------------- */
void cancel_to_done()
{
vm = allocate_running(0);
vmm_actions.push_back(LifeCycleManager::CANCEL_SUCCESS);
vmm->set_actions(vmm_actions);
dm->cancel(vm->get_oid());
wait_assert(vm, VirtualMachine::DONE);
}
/* -------------------------------------------------------------------------- */
void cancel_to_running()
{
vm = allocate_running(0);
vmm_actions.push_back(LifeCycleManager::CANCEL_FAILURE);
vmm->set_actions(vmm_actions);
dm->cancel(vm->get_oid());
wait_assert(vm, VirtualMachine::ACTIVE, VirtualMachine::RUNNING );
}
/* -------------------------------------------------------------------------- */
void migrate_to_running()
{
vm = allocate_running(0);
vm->add_history(hid,hostname,vmdir,vmm_mad,tm_mad);
rc = vmpool->update_history(vm);
CPPUNIT_ASSERT( rc == 0 );
vmpool->update(vm); //Insert last_seq in the DB
CPPUNIT_ASSERT( vm->hasHistory() );
CPPUNIT_ASSERT( vm->hasPreviousHistory() );
vmm_actions.push_back(LifeCycleManager::DEPLOY_SUCCESS);
vmm->set_actions(vmm_actions);
dm->live_migrate(vm);
wait_assert(vm, VirtualMachine::ACTIVE, VirtualMachine::RUNNING );
}
/* -------------------------------------------------------------------------- */
void migrate_to_failed()
{
vm = allocate_running(0);
vm->add_history(hid,hostname,vmdir,vmm_mad,tm_mad);
rc = vmpool->update_history(vm);
CPPUNIT_ASSERT( rc == 0 );
vmpool->update(vm); //Insert last_seq in the DB
CPPUNIT_ASSERT( vm->hasHistory() );
CPPUNIT_ASSERT( vm->hasPreviousHistory() );
vmm_actions.push_back(LifeCycleManager::DEPLOY_FAILURE);
vmm->set_actions(vmm_actions);
dm->live_migrate(vm);
wait_assert(vm, VirtualMachine::ACTIVE, VirtualMachine::RUNNING );
}
/* -------------------------------------------------------------------------- */
void save_suspend_to_suspended()
{
vm = allocate_running(0);
vmm_actions.push_back(LifeCycleManager::SAVE_SUCCESS);
vmm->set_actions(vmm_actions);
dm->suspend(vm->get_oid());
wait_assert(vm, VirtualMachine::SUSPENDED);
}
/* -------------------------------------------------------------------------- */
void save_suspend_to_running()
{
vm = allocate_running(0);
vmm_actions.push_back(LifeCycleManager::SAVE_FAILURE);
vmm->set_actions(vmm_actions);
dm->suspend(vm->get_oid());
wait_assert(vm, VirtualMachine::ACTIVE, VirtualMachine::RUNNING );
}
/* -------------------------------------------------------------------------- */
void shutdown_to_epilog()
{
vm = allocate_running(0);
vmm_actions.push_back(LifeCycleManager::SHUTDOWN_SUCCESS);
vmm->set_actions(vmm_actions);
dm->shutdown(vm->get_oid());
wait_assert(vm, VirtualMachine::ACTIVE, VirtualMachine::EPILOG );
}
/* -------------------------------------------------------------------------- */
void shutdown_to_running()
{
vm = allocate_running(0);
vmm_actions.push_back(LifeCycleManager::SHUTDOWN_FAILURE);
vmm->set_actions(vmm_actions);
dm->shutdown(vm->get_oid());
wait_assert(vm, VirtualMachine::ACTIVE, VirtualMachine::RUNNING );
}
/* -------------------------------------------------------------------------- */
void save_stop_to_epilog_stop()
{
vm = allocate_running(0);
vmm_actions.push_back(LifeCycleManager::SAVE_SUCCESS);
vmm->set_actions(vmm_actions);
dm->stop(vm->get_oid());
wait_assert(vm, VirtualMachine::ACTIVE, VirtualMachine::EPILOG_STOP );
}
/* -------------------------------------------------------------------------- */
void save_stop_to_running()
{
vm = allocate_running(0);
vmm_actions.push_back(LifeCycleManager::SAVE_FAILURE);
vmm->set_actions(vmm_actions);
dm->stop(vm->get_oid());
wait_assert(vm, VirtualMachine::ACTIVE, VirtualMachine::RUNNING );
}
/* -------------------------------------------------------------------------- */
void epilog_to_done()
{
vm = allocate_running(0);
vmm_actions.push_back(LifeCycleManager::SHUTDOWN_SUCCESS);
vmm->set_actions(vmm_actions);
tm_actions.push_back(LifeCycleManager::EPILOG_SUCCESS);
tm->set_actions(tm_actions);
dm->shutdown(vm->get_oid());
wait_assert(vm, VirtualMachine::DONE );
}
/* -------------------------------------------------------------------------- */
void epilog_to_failed()
{
vm = allocate_running(0);
vmm_actions.push_back(LifeCycleManager::SHUTDOWN_SUCCESS);
vmm->set_actions(vmm_actions);
tm_actions.push_back(LifeCycleManager::EPILOG_FAILURE);
tm->set_actions(tm_actions);
dm->shutdown(vm->get_oid());
wait_assert(vm, VirtualMachine::FAILED );
}
/* -------------------------------------------------------------------------- */
void epilog_stop_to_stop()
{
vm = allocate_running(0);
vmm_actions.push_back(LifeCycleManager::SAVE_SUCCESS);
vmm->set_actions(vmm_actions);
tm_actions.push_back(LifeCycleManager::EPILOG_SUCCESS);
tm->set_actions(tm_actions);
dm->stop(vm->get_oid());
wait_assert(vm, VirtualMachine::STOPPED );
}
/* -------------------------------------------------------------------------- */
void epilog_stop_to_failed()
{
vm = allocate_running(0);
vmm_actions.push_back(LifeCycleManager::SAVE_SUCCESS);
vmm->set_actions(vmm_actions);
tm_actions.push_back(LifeCycleManager::EPILOG_FAILURE);
tm->set_actions(tm_actions);
dm->stop(vm->get_oid());
wait_assert(vm, VirtualMachine::FAILED );
}
/* -------------------------------------------------------------------------- */
};

330
src/lcm/test/Nebula.cc Normal file
View File

@ -0,0 +1,330 @@
/* -------------------------------------------------------------------------- */
/* Copyright 2002-2010, OpenNebula Project Leads (OpenNebula.org) */
/* */
/* Licensed under the Apache License, Version 2.0 (the "License"); you may */
/* not use this file except in compliance with the License. You may obtain */
/* a copy of the License at */
/* */
/* http://www.apache.org/licenses/LICENSE-2.0 */
/* */
/* Unless required by applicable law or agreed to in writing, software */
/* distributed under the License is distributed on an "AS IS" BASIS, */
/* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. */
/* See the License for the specific language governing permissions and */
/* limitations under the License. */
/* -------------------------------------------------------------------------- */
#include "Nebula.h"
#include "NebulaLog.h"
#include "VirtualMachine.h"
#include "SqliteDB.h"
#include "MySqlDB.h"
#include "LifeCycleManagerTest.h"
#include "DummyManager.h"
#include <stdlib.h>
#include <stdexcept>
#include <libxml/parser.h>
#include <signal.h>
#include <unistd.h>
#include <fcntl.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <pthread.h>
using namespace std;
/* -------------------------------------------------------------------------- */
/* -------------------------------------------------------------------------- */
void Nebula::start()
{
// Clean up
if ( vmpool != 0)
{
delete vmpool;
}
if ( vnpool != 0)
{
delete vnpool;
}
if ( hpool != 0)
{
delete hpool;
}
if ( upool != 0)
{
delete upool;
}
if ( ipool != 0)
{
delete ipool;
}
if ( vmm != 0)
{
delete vmm;
}
if ( lcm != 0)
{
delete lcm;
}
if ( im != 0)
{
delete im;
}
if ( tm != 0)
{
delete tm;
}
if ( dm != 0)
{
delete dm;
}
if ( rm != 0)
{
delete rm;
}
if ( hm != 0)
{
delete hm;
}
if ( authm != 0)
{
delete authm;
}
if ( nebula_configuration != 0)
{
delete nebula_configuration;
}
if ( db != 0 )
{
delete db;
}
nebula_location = "./";
mad_location = nebula_location + "lib/mads/";
etc_location = nebula_location + "etc/";
log_location = nebula_location + "var/";
var_location = nebula_location + "var/";
hook_location = nebula_location + "share/hooks/";
remotes_location = nebula_location + "lib/remotes/";
int rc;
sigset_t mask;
// -----------------------------------------------------------
// Initialize the XML library
// -----------------------------------------------------------
xmlInitParser();
// -----------------------------------------------------------
// Pools
// -----------------------------------------------------------
try
{
vector<const Attribute *> dbs;
int rc;
bool db_is_sqlite = ! LifeCycleManagerTest::isMysql();
string server = "localhost";
string user = "oneadmin";
string passwd = "oneadmin";
string db_name = "ONE_test_database";
if ( db_is_sqlite )
{
string db_name = var_location + "one.db";
db = new SqliteDB(db_name);
}
else
{
ostringstream oss;
db = new MySqlDB(server,user,passwd,0);
oss << "DROP DATABASE IF EXISTS " << db_name;
db->exec(oss);
oss.str("");
oss << "CREATE DATABASE IF NOT EXISTS " << db_name;
rc = db->exec(oss);
if ( rc != 0 )
{
throw runtime_error("Could not create database.");
}
oss.str("");
oss << "USE " << db_name;
rc = db->exec(oss);
if ( rc != 0 )
{
throw runtime_error("Could not open database.");
}
}
NebulaLog::log("ONE",Log::INFO,"Bootstraping OpenNebula database.");
VirtualMachinePool::bootstrap(db);
HostPool::bootstrap(db);
VirtualNetworkPool::bootstrap(db);
UserPool::bootstrap(db);
ImagePool::bootstrap(db);
}
catch (exception&)
{
throw;
}
try
{
string mac_prefix = "00:00";
int size = 1;
string repository_path;
string default_image_type;
string default_device_prefix;
vector<const Attribute *> vm_hooks;
vmpool = new VirtualMachinePool(db, vm_hooks,hook_location);
hpool = new HostPool(db);
vnpool = new VirtualNetworkPool(db,mac_prefix,size);
upool = new UserPool(db);
ipool = new ImagePool(db,
repository_path,
default_image_type,
default_device_prefix);
}
catch (exception&)
{
throw;
}
// -----------------------------------------------------------
// Block all signals before creating any Nebula thread
// -----------------------------------------------------------
sigfillset(&mask);
pthread_sigmask(SIG_BLOCK, &mask, NULL);
// -----------------------------------------------------------
//Managers
// -----------------------------------------------------------
MadManager::mad_manager_system_init();
time_t timer_period = 0;
// ---- Virtual Machine Manager ----
try
{
time_t poll_period = 0;
vector<const Attribute *> vmm_mads;
vmm = new VirtualMachineManagerTest(
vmpool,
hpool,
timer_period,
poll_period,
vmm_mads);
}
catch (bad_alloc&)
{
throw;
}
rc = vmm->start();
if ( rc != 0 )
{
throw runtime_error("Could not start the Virtual Machine Manager");
}
// ---- Transfer Manager ----
try
{
vector<const Attribute *> tm_mads;
tm = new TransferManagerTest(vmpool, hpool, tm_mads);
}
catch (bad_alloc&)
{
throw;
}
rc = tm->start();
if ( rc != 0 )
{
throw runtime_error("Could not start the Transfer Manager");
}
// ---- Dispatch Manager ----
try
{
dm = new DispatchManager(vmpool,hpool);
}
catch (bad_alloc&)
{
throw;
}
rc = dm->start();
if ( rc != 0 )
{
throw runtime_error("Could not start the Dispatch Manager");
}
// ---- Life-cycle Manager ----
try
{
// lcm = new LifeCycleManager(vmpool,hpool,vmm,tm,dm);
lcm = new LifeCycleManager(vmpool,hpool);
}
catch (bad_alloc&)
{
throw;
}
rc = lcm->start();
if ( rc != 0 )
{
throw runtime_error("Could not start the Life-cycle Manager");
}
// -----------------------------------------------------------
// Load mads
// -----------------------------------------------------------
sleep(2);
vmm->load_mads(0);
};

236
src/lcm/test/SConstruct Normal file
View File

@ -0,0 +1,236 @@
# -------------------------------------------------------------------------- #
# Copyright 2002-2010, OpenNebula Project Leads (OpenNebula.org) #
# #
# Licensed under the Apache License, Version 2.0 (the "License"); you may #
# not use this file except in compliance with the License. You may obtain #
# a copy of the License at #
# #
# http://www.apache.org/licenses/LICENSE-2.0 #
# #
# Unless required by applicable law or agreed to in writing, software #
# distributed under the License is distributed on an "AS IS" BASIS, #
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. #
# See the License for the specific language governing permissions and #
# limitations under the License. #
#--------------------------------------------------------------------------- #
import os
import sys
import shutil
sys.path.append("../../../share/scons")
from lex_bison import *
# This is the absolute path where the project is located
cwd="../../.."
# Environment that will be applied to each scons child
main_env=Environment()
main_env['ENV']['PATH']=os.environ['PATH']
# snippet borrowed from http://dev.gentoo.org/~vapier/scons-blows.txt
# makes scons aware of build related environment variables
if os.environ.has_key('CC'):
main_env['CC'] = os.environ['CC']
if os.environ.has_key('CFLAGS'):
main_env['CCFLAGS'] += SCons.Util.CLVar(os.environ['CFLAGS'])
if os.environ.has_key('CXX'):
main_env['CXX'] = os.environ['CXX']
if os.environ.has_key('CXXFLAGS'):
main_env['CXXFLAGS'] += SCons.Util.CLVar(os.environ['CXXFLAGS'])
if os.environ.has_key('LDFLAGS'):
main_env['LINKFLAGS'] += SCons.Util.CLVar(os.environ['LDFLAGS'])
# Add builders for flex and bison
add_lex(main_env)
add_bison(main_env)
# Include dirs
main_env.Append(CPPPATH=[
cwd+'/include',
'/usr/include/cppunit/'
])
# Library dirs
main_env.Append(LIBPATH=[
cwd+'/src/common',
cwd+'/src/log',
cwd+'/src/sql',
cwd+'/src/host',
cwd+'/src/mad',
cwd+'/src/nebula',
cwd+'/src/pool',
cwd+'/src/template',
cwd+'/src/vm',
cwd+'/src/vmm',
cwd+'/src/lcm',
cwd+'/src/tm',
cwd+'/src/dm',
cwd+'/src/im',
cwd+'/src/image',
cwd+'/src/rm',
cwd+'/src/vnm',
cwd+'/src/hm',
cwd+'/src/um',
cwd+'/src/authm',
'.',
])
# Compile flags
main_env.Append(CPPFLAGS=[
"-g",
"-Wall",
"-Werror",
])
# Linking flags
main_env.Append(LINKFLAGS=['-g', '-pthread'])
#######################
# EXTRA CONFIGURATION #
#######################
# SQLITE
sqlite_dir=ARGUMENTS.get('sqlite_dir', 'none')
if sqlite_dir!='none':
main_env.Append(LIBPATH=[sqlite_dir+"/lib"])
main_env.Append(CPPPATH=[sqlite_dir+"/include"])
sqlite=ARGUMENTS.get('sqlite', 'yes')
if sqlite=='yes':
main_env.Append(sqlite='yes')
main_env.Append(CPPFLAGS=["-DSQLITE_DB"])
else:
main_env.Append(sqlite='no')
# MySQL
mysql=ARGUMENTS.get('mysql', 'no')
if mysql=='yes':
main_env.Append(mysql='yes')
main_env.Append(CPPFLAGS=["-DMYSQL_DB"])
else:
main_env.Append(mysql='no')
# xmlrpc
xmlrpc_dir=ARGUMENTS.get('xmlrpc', 'none')
if xmlrpc_dir!='none':
main_env.Append(LIBPATH=[xmlrpc_dir+"/lib"])
main_env.Append(CPPPATH=[xmlrpc_dir+"/include"])
# build lex/bison
build_parsers=ARGUMENTS.get('parsers', 'no')
if build_parsers=='yes':
main_env.Append(parsers='yes')
else:
main_env.Append(parsers='no')
if not main_env.GetOption('clean'):
try:
main_env.ParseConfig('../../../share/scons/get_xmlrpc_config server')
main_env.ParseConfig('../../../share/scons/get_xmlrpc_config client')
if mysql=='yes':
main_env.ParseConfig('mysql_config --cflags --libs')
except Exception, e:
print ""
print "Error searching for xmlrpc-c libraries. Please check this"+\
" things:"
print ""
print " * You have installed development libraries for xmlrpc-c. One"+\
" way to check"
print " this is calling xmlrpc-c-config that is provided with the"+\
" development"
print " package."
print " * Check that the version of xmlrpc-c is at least 1.06. You"+\
" can do this also"
print " calling:"
print " $ xmlrpc-c-config --version"
print " * If all this requirements are already met please send log"+\
" files located in"
print " .xmlrpc_test to the mailing list."
print ""
exit(-1)
else:
main_env.Replace(mysql='yes')
shutil.rmtree('.xmlrpc_test', True)
shutil.rmtree('src/nebula/.xmlrpc_test', True)
shutil.rmtree('src/scheduler/.xmlrpc_test', True)
# libxml2
main_env.ParseConfig('xml2-config --libs --cflags')
# Build LCM and DM toguether in a lib
lib_name='nebula_lcm_dm'
# Sources to generate the library
source_files=[
'../LifeCycleManager.cc',
'../LifeCycleActions.cc',
'../LifeCycleStates.cc',
'../../dm/DispatchManager.cc',
'../../dm/DispatchManagerActions.cc',
'../../dm/DispatchManagerStates.cc',
]
# Build library
main_env.StaticLibrary(lib_name, source_files)
# Build a modified Nebula lib
lib_name='nebula_core_test'
# Sources to generate the library
source_files=[
'Nebula.cc',
'../../nebula/NebulaTemplate.cc',
]
# Build library
main_env.StaticLibrary(lib_name, source_files)
# Build daemon
main_env.Append(LIBS=[
'nebula_lcm_dm',
'nebula_core_test',
'nebula_vmm',
'nebula_im',
'nebula_rm',
'nebula_tm',
'nebula_um',
'nebula_mad',
'nebula_template',
'nebula_host',
'nebula_vm',
'nebula_vnm',
'nebula_image',
'nebula_pool',
'nebula_hm',
'nebula_authm',
'nebula_common',
'nebula_sql',
'nebula_log',
'crypto',
'cppunit',
])
# Sources to generate the library
if main_env['sqlite']=='yes':
main_env.Append(LIBS=['sqlite3'])
if main_env['mysql']=='yes':
main_env.Append(LIBS=['mysqlclient'])
if not main_env.GetOption('clean'):
main_env.ParseConfig('../../../share/scons/get_xmlrpc_config server')
main_env.Program('test','LifeCycleManagerTest.cc')