Jump to: navigation, search

MagnetoDB/QA/Tests on env with devstack

< MagnetoDB
Revision as of 17:11, 2 January 2015 by Andrei Ostapenko (talk | contribs) (Environment Creation)

Tests on environment with DevStack

The easiest way to build a fully functional development environment is with DevStack. Create a machine (such as a VM or Vagrant box) running a distribution supported by DevStack and install DevStack there.

Environment Creation

1. Clone DevStack

$ git clone https://github.com/openstack-dev/devstack.git

2. Clone MagnetoDB

$ git clone https://github.com/stackforge/magnetodb.git

3. Integrate MagnetoDB with DevStack. To install:

$ DEVSTACK_DIR=.../path/to/devstack
$ cp magnetodb/contrib/devstack/lib/magnetodb ${DEVSTACK_DIR}/lib
$ cp magnetodb/contrib/devstack/extras.d/90-magnetodb.sh ${DEVSTACK_DIR}/extras.d

To configure devstack to run MagnetoDB with functional testing:

$ cd ${DEVSTACK_DIR}
$ echo "enable_service magnetodb" >> local.conf
$ echo "enable_service tempest" >> local.conf

Run DevStack as normal:

$ ./stack.sh

Note: Make sure that your local.conf contains [[local | localrc]] in the first line. See more about configuration of DevStack at http://devstack.org/configuration.html Also you can change other MagnetoDB variables, see file lib/magnetodb

4. Make sure magnetodb-server-api started

$ ps aux | grep magnetodb

5. Change current directory to magnetodb

$ cd /opt/stack/magnetodb

Tests Running

6. Run tox with necessary parameters:

  • to start unit tests:
$ tox


Tempest functional/integration tests

NOTE: Update your devstack variables, e.g. tenant name, user name, password of that user, etc in magnetodb/tempest/tempest.conf

  • to start stable tempest tests (this folder contains scenarios that verify already implemented functionality):
$ tox -e tempest-stable
  • to start in_progress tempest tests (contains scenarios that are in progress (i.e. is being worked on) or the functionality that is a subject to changes (minor additions, refactoring, debugging)):
$ tox -e tempest-in-progress
  • to start not_ready tempest tests (dedicated to the test scenarios that were created, but the appropriate functionality is not ready yet (not implemented or partially implemented)):
$ tox -e tempest-not-ready


Note: Each group of tests run in individual venv and will require some time to install dependencies (Python packages)