Skip to main content

Simple System Tests Environment.

Project description

simple-system-tests

Simple Python library for writing test cases for System and components tests including automatic reports via html. The intention is to have an easy framework for developers without the need to learn a separate coding language. Check out the repository via:

git clone https://github.com/chrisKoeh/simple-system-tests.git

Main advantages using this framework:

  • separate command line option for each testcase allows faster debugging
  • parameterized subtests require only one test function but allows multiple tests of one part with different values
  • python only with just 3 decorator functions being necessary to learn

(Optional) Build package locally

pip3 install setuptools wheel
python3 setup.py sdist bdist_wheel
(sudo) python3 setup.py install

Installation

pip3 install simple-system-tests

Quick-Start

After installation create a script with the following content:

import simple_system_tests as sst

@sst.testcase()
def my_testcase():
    sst.logger().info("this is a PASS")

sst.run_tests()

Upon execution an error message will be printed, that the system_params.json was not found which can be ignored for now. After that open the created index.html for an overview of the results in a web browser. For a more detailed example take a look at examples folder.

Testsuite

The Testsuite is defined under simple_system_tests/TestSuite.py:

  • holds and executes testcases
  • prepare and teardown of Testsuite, which can be implemented by using decorators(optional):
import simple_system_tests as sst
@sst.prepare_suite
def s_prepare():
    sst.logger().info("preparing the suite")
@sst.teardown_suite
def s_teardown():
    sst.logger().info("tearing the suite down")
  • reporting of test results stored in index.html (can be configured via command line)
  • providing command line options for configurations and all testcases allowing them to be called separately

Command line options

Auto created

When using a Testsuite command line options for all testcases added to the suite will be automatically created. Command line option shortcut will be derived from the beginning characters of the decorated function name. Make sure to have varying descriptions for your testcases. Having a look at the help of examples/main.py will give the following output:

shell: python3 main.py -h
usage: main.py [-h] [-no] [-p JSON_SYSTEM_PARAMS] [-o REPORT_OUTPUT] [-e] [-s]
               [-m] [-j] [-r] [-t] [-pr] [-te]

optional arguments:
  -h, --help            show this help message and exit
  -no, --no-suite-setup
                        No Suite Prepare and Teardown
  -p JSON_SYSTEM_PARAMS, --json-system-params JSON_SYSTEM_PARAMS
                        Path to JSON params file.
  -o REPORT_OUTPUT, --report-output REPORT_OUTPUT
                        Path to report html file.
  -e, --env_case        Test Env case
  -s, --simple_print    Test Simple print
  -m, --multi_prints    Test Multi prints
  -j, --json_multi_prints
                        Test Json multi prints
  -r, --retry_case      Test Retry case
  -t, --timeout_case    Test Timeout case
  -pr, --prepare_fail_case
                        Test Prepare fail case
  -te, --teardown_fail_case
                        Test Teardown fail case

Testcases can be called separately without having to execute all testcases in one run. It is also possible to pass multiple testcases in one execution. In case the Suite setup and teardown is not wanted this can be achieved by putting the -no, --no-suite-setup option.

Adding custom command line options

System parameters can be also defined and passed via cmd line option. Just create the according cmd option like, within your main script on the top at best:

sst.add_cmd_option('my_opt', 'A custom option that needs to be passed')

With that the option will be added to the command line parser. The value passed via command line can then be used within the main script using sst.get_env()["my_opt"]. If the key is also red from system_params.json the command line option will override, as long as provided by the user or if a default value was given.

Testcases

Create new testcases

Testcases are created using decorators:

import simple_system_tests as sst

@sst.testcase()
def custom_testcase():
    raise Exception("Fails always, anyways")

A testcase is considered PASS as long as no exception is raised.

Testcase arguments

@sst.testcase(retry=0, timeout=-1, prepare_func=None, teardown_func=None)
  • retry: how often a testcase is retried before considered as FAIL
  • timeout: in seconds how long the testcase may last, considered as FAIL if extended
  • prepare_func / teardown_func: functions to be called before / after testcase execution

Sub testcases

@sst.testcases(sub_params, retry=0...)
def multi_tests(sub_param):
    ...

It is possible to run multiple tests at once. The number of tests is defined by the list length of the sub_params argument. The rest of the arguments are the same as for @sst.testcase decorator.

System parameters

Environment parameters for the testsuite can be used from a json file named system_params.json (the file path can be customized by passing the -p option). Those will be made available in the Testcase by the function sst.get_env():

import simple_system_tests as sst

@sst.testcase()
def env_case():
    sst.logger().info(sst.get_env())

Setting these json params from within the testsuite, eg. in case a global python object should be made available in Testsuite preparation for all testcases, is possible with sst.set_env(key, value) function.

Logging

The file path of the output file can be customized by passing the -o option, which defaults to index.html. A logger object attribute is available within testcases and testsuites. However stdout is mapped to logger.info, hence print can also be used directly which will result in output of both console and html report file as INFO message.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

simple-system-tests-0.6.2.tar.gz (10.8 kB view details)

Uploaded Source

Built Distributions

simple_system_tests-0.6.2-py3.7.egg (22.6 kB view details)

Uploaded Source

simple_system_tests-0.6.2-py3-none-any.whl (11.7 kB view details)

Uploaded Python 3

File details

Details for the file simple-system-tests-0.6.2.tar.gz.

File metadata

  • Download URL: simple-system-tests-0.6.2.tar.gz
  • Upload date:
  • Size: 10.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.7.3

File hashes

Hashes for simple-system-tests-0.6.2.tar.gz
Algorithm Hash digest
SHA256 768d95d49521b592ca439504515e94da638b2670ad09da1f0e88525993ab3d6e
MD5 3b745dba5e132cd24bfc782da66d957f
BLAKE2b-256 39ea4a586dbb7cfb56c38345a837575c2993b75fe48d796d8878b8d45a620715

See more details on using hashes here.

File details

Details for the file simple_system_tests-0.6.2-py3.7.egg.

File metadata

File hashes

Hashes for simple_system_tests-0.6.2-py3.7.egg
Algorithm Hash digest
SHA256 5299f452cc088d7ce391ce3a15763d45a609414fb207e213d9fb0e25bba50499
MD5 bcd97f4eaaffc35fba78ecc330aea9a2
BLAKE2b-256 7794a8e997ce30412561eb5d10fd9978307b43986eeec493bbb644e2e6999507

See more details on using hashes here.

File details

Details for the file simple_system_tests-0.6.2-py3-none-any.whl.

File metadata

File hashes

Hashes for simple_system_tests-0.6.2-py3-none-any.whl
Algorithm Hash digest
SHA256 6b3dad12d3d7bf0741e89d0b7018f99f0f522a9b84441a888b59e2ef996efdd6
MD5 e16561690709bb86d56dc583e2cae9e8
BLAKE2b-256 4cb49c1d919462d094142cee5d281220b0c3a53a16c00dd7976ff9771169f762

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page