Metadata-Version: 2.0
Name: systest
Version: 5.4.0
Summary: System test framework with serial and parallel execution.
Home-page: https://github.com/eerimoq/systest
Author: Erik Moqvist
Author-email: erik.moqvist@gmail.com
License: MIT
Description-Content-Type: UNKNOWN
Keywords: test,system,sequencer,parallel
Platform: UNKNOWN
Classifier: License :: OSI Approved :: MIT License
Classifier: Programming Language :: Python :: 2
Classifier: Programming Language :: Python :: 3
Requires-Dist: humanfriendly

|buildstatus|_

Installation
============

.. code-block:: python

    pip install systest

Description
===========

Execute a sequence of test cases in serial and/or parallel.

Test cases in a list are executed in serial and test cases in a tuple
are executed in parallel, in separate Python threads.

This framework is created with integration/system test in mind. The
framework is *not* intended as a replacement for ``unittest``, but
rather to be a complement to it.

Documentation: http://systest.readthedocs.org/en/latest

Example usage
=============

See the test suite:
https://github.com/eerimoq/systest/blob/master/tests/test_systest.py

For example, the sequence below starts with test case
``MyTestCase("1")``. When ``MyTestCase("1")`` has been executed,
``MyTestCase("2")`` and the list of ``MyTestCase("3")`` and
``MyTestCase("4")`` are executed in parallel. When both
``MyTestCase("2")`` and the list of ``MyTestCase("3")`` and
``MyTestCase("4")`` has been executed, ``MyTestCase("5")`` is
executed. Then the sequence ends.

.. code-block:: python

   import logging
   from systest import TestCase, Sequencer, configure_logging

   LOGGER = logging.getLogger(__name__)

   # Define a testcase.
   class MyTestCase(TestCase):
       """Test case description.

       """

       def __init__(self, name):
           super(MyTestCase, self).__init__()
           self.name = "my_testcase_" + name

       def run(self):
           LOGGER.info("Hello!")
           self.assert_equal(1, 1)
           self.assert_true(1 == 1)
           self.assert_in(1 in [1, 2])
           self.assert_none(None)

           with self.assert_raises(RuntimeError) as cm:
               raise RuntimeError('foo')

           self.assert_equal(str(cm.exception), 'foo')

   # Configure the logging module.
   configure_logging()

   sequencer = Sequencer("my_sequence")

   # Run the sequence.
   sequencer.run([
           MyTestCase("1"),
           (
               MyTestCase("2"),
               [
                   MyTestCase("3"),
                   MyTestCase("4")
               ]
           ),
           MyTestCase("5")
       ])

   # Print the report.
   sequencer.report()

The output is:

.. code-block:: text

   Name: my_sequence
   Date: 2016-02-02 18:42:40.446213
   Node: erik-VirtualBox
   User: erik

   ---------------------------------------------------------------

   Name: my_testcase_1
   Description:

       Test case description.

   Hello!

   my_testcase_1: PASSED in 0m 0s

   ---------------------------------------------------------------

   Name: my_testcase_2
   Description:

       Test case description.

   Hello!

   my_testcase_2: PASSED in 0m 0s

   ---------------------------------------------------------------

   Name: my_testcase_3
   Description:

       Test case description.

   Hello!

   my_testcase_3: PASSED in 0m 0s

   ---------------------------------------------------------------

   Name: my_testcase_4
   Description:

       Test case description.

   Hello!

   my_testcase_4: PASSED in 0m 0s

   ---------------------------------------------------------------

   Name: my_testcase_5
   Description:

       Test case description.

   Hello!

   my_testcase_5: PASSED in 0m 0s

   ---------------------- Test summary begin ----------------------

   [
       [
           my_testcase_1: PASSED,
           (
               my_testcase_2: PASSED,
               [
                   my_testcase_3: PASSED,
                   my_testcase_4: PASSED
               ]
           ),
           my_testcase_5: PASSED
       ]
   ]

   Execution time: 0m 0s
   Result: PASSED (passed: 5, failed: 0, skipped: 0, xpassed: 0, xfailed: 0)

   ----------------------- Test summary end -----------------------

.. |buildstatus| image:: https://travis-ci.org/eerimoq/systest.svg
.. _buildstatus: https://travis-ci.org/eerimoq/systest


