From 46d6e58bedd6b6c44e710b1e97afaf1277225770 Mon Sep 17 00:00:00 2001 From: Santosh Kodicherla <ksantosh.cs@gmail.com> Date: Tue, 17 Nov 2015 05:32:19 +0000 Subject: [PATCH] Developers guide for functional tests Adding developers documentation for tacker functional tests. Closes-Bug: 1516878 Change-Id: Ic31a4152d744f3d9a220538d1d7f3c1b6f6698bb --- doc/source/devref/tacker_functional_test.rst | 115 +++++++++++++++++++ doc/source/index.rst | 1 + 2 files changed, 116 insertions(+) create mode 100644 doc/source/devref/tacker_functional_test.rst diff --git a/doc/source/devref/tacker_functional_test.rst b/doc/source/devref/tacker_functional_test.rst new file mode 100644 index 000000000..7b320fd7d --- /dev/null +++ b/doc/source/devref/tacker_functional_test.rst @@ -0,0 +1,115 @@ +.. + This work is licensed under a Creative Commons Attribution 3.0 Unported + License. + + http://creativecommons.org/licenses/by/3.0/legalcode + + +=============================== +Functional testcases for tacker +=============================== + +Purpose of functional testcases is to verify various functionality of tacker +features. From tacker home directory, testcases are located at +tacker/tests/functional. + +Writing a testcase:A testcase is written by declaring a class name derived from +class base.BaseTackerTest. BaseTackerTest is class declared in +tacker/tests/functional/vnfd/base.py + +A testcase body typically looks as below: + + +.. code-block:: python + + class vnfClassName(base.BaseTackerTest): + + def test_create_delete(self): + + //Testcase operations + + //validations or asserts + + //cleanup + + +In above example test class 'vnfClassName' is derived from +base.BaseTackerTest. Testcases typically has sections to setup, test, validate +results and finally cleanup. + +Input yaml files: These are input files used in testcases for operations like +create vnfd or create vnf. The location of files is tacker/tests/etc/samples/ + +requirements.txt and test-requirements.txt : The file requirements.txt and +test-requirements.txt lists all the packages needed for functional test. +These packages are installed during devstack installation. If there are any +new packages needed for functional test make sure they are added in +test-requirements.txt + +Asserting values in testcase: The base class BaseTackerTest +inherits base.TestCase which has inbuild assert functions which can be used in +testcase. +Eg: assertIsNotNone, assertEqual + +Tacker-client: In base.py we instantiate tackerclient object which has apis to +create/delete/list vnfd/vnf once given the necessary parameters. +Verify tackerclient/v1_0/client.py for all the tacker related apis supported. + + + +Important guidelines to follow: +=============================== + +* Install test-requirements.txt with below command: + +.. code-block:: console + + pip install -r test-requirements.txt + +* It is important that the test case executed leaves the + system in the same state it was prior to test case execution + and not leave any stale data on system as this might affect + other test cases. +* There should not be any dependencies between testcases + which assume one testcase should be executed and be passed + for second testcase. +* Testcases in tox environment may be executed in parallel. + The order in which the testcases are executed may vary + between two environments. +* The code added should meet pep8 standards. This can be verified with + following command and ensuring the code does not return any errors. + +.. code-block:: console + + tox -e pep8 + + + +Execution of testcase: +====================== + +* From tacker directory, testcases can be executed using following commands: + + (Note: Make sure tacker server is installed and running) + + * To execute all testcases or one testcase use below commands: + +.. code-block:: console + + tox -e functional + tox -e functional tacker.tests.functional.vnfd.<testcase> + + + +Committing testcase and opening a review: +========================================= + +* Once testcase is added in local setup, commit the testcase and open for + review using below guidelines, + * http://docs.openstack.org/infra/manual/developers.html + +Sample testcase: +================ +* Check sample tests under following directory: + +https://github.com/openstack/tacker/blob/master/tacker/tests/functional/ diff --git a/doc/source/index.rst b/doc/source/index.rst index f3610404f..28d905888 100644 --- a/doc/source/index.rst +++ b/doc/source/index.rst @@ -71,6 +71,7 @@ Developer Info devref/development.environment.rst devref/api_layer.rst devref/api_extensions.rst + devref/tacker_functional_test.rst Indices and tables ------------------