Skip to main content

Provide insights on the outcomes of software test cases.

Project description

testyoke

Provide insights on the outcomes of software test cases.

This project will provide resources to log the results of your test suites and aims to add useful insights to your testing. Tests are seen as gold, but how do you prune invalid, ineffective, or plain inaccurate test cases? With TestYoke you can:

  • See the results of tests on this git sha previously. Big time savings here, by not running again.
  • Flaky Tests - have both passed and failed on the present sha. There probably is a data or service dependency issue.
  • Bad Tests - tests that have been failing across consecutive shas. If these have been deployed anyways, these tests are worthless.  Prompt user to delete because they are costing the staff more than a good test is worth.
  • Regressions - tests that failed, were fixed, and fail again in different shas.  Regressions are recurring issues. They may prompt priority to fix.

The HTTP service in this project can run in the background and receive results of your test running, however you run them.

The service presently accepts junit xml, and there is a good chance your testing framework can export that format. Try setting up posting the results of your tests after every run of the suite via your build process.

getting started

  1. Run the service. Default port is 7357, but you may set it with the YOKE_PORT env var.
python3 -m testyoke.server YOKE_PORT=7357
  1. Everytime you run a test, POST the results using the client.
  python -m testyoke.client --sha=`git rev-parse HEAD` --report=junit.xml

junit.xml is presently the de facto format, as it is one of the more prevalent formats in the space. It is supported by pytest, scalatest, and obviously in java frameworks as well. This is the first format to be supported, but more formats are expected to be supported soon.

You can submit via curl/HTTP Post via the following (Run this after your tests run):

  curl -H "vc-sha: $(SHA)" -H "Content-Type: application/xml+junit" -X POST -d @$(JUNIT_XML) http://localhost:7357/projects/testharness/reports

Get reports by:

  curl http://localhost:7357/projects/testharness/shas/$(GIT_SHA)

Analytics

Run this before your tests run.

This will provide you with historical information. If the SHA has previously been proven, it will be reported it as clean.

  python -m testyoke.client --sha=`git rev-parse HEAD`

Example output:

###################################################
#
# nature: untested.  fails 0, passes 0
#
###################################################

Nature

This is a classification of the SHA you are running on.

  • untested - testyoke hasn't seen results from this SHA yet
  • clean - testyoke has never seen a failure on this SHA
  • broken - this SHA has never passed completely.
  • flaky - there is at least one flaky test, defined as having passed and failed on the same SHA.

Components

  • HTTP service
  • reporters
    • scalatest
    • pytest
    • rspec
  • cli client
  • analytics
  • web portal

Arch

API -> persist analyzers

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

testyoke-0.0.4.tar.gz (10.5 kB view details)

Uploaded Source

Built Distribution

testyoke-0.0.4-py3-none-any.whl (11.5 kB view details)

Uploaded Python 3

File details

Details for the file testyoke-0.0.4.tar.gz.

File metadata

  • Download URL: testyoke-0.0.4.tar.gz
  • Upload date:
  • Size: 10.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/2.0.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.6.0 requests-toolbelt/0.9.1 tqdm/4.37.0 CPython/3.7.3

File hashes

Hashes for testyoke-0.0.4.tar.gz
Algorithm Hash digest
SHA256 026d7fad20710f88625bdd4c5b2df43f860b5671a4a03f8bd7982f48928852d6
MD5 df65740f59cfa4cf239d15eda37835ae
BLAKE2b-256 1ec992db0304e7b8204a9e6f3fbe811ea9b7a1aec55257398d8cf889e070f775

See more details on using hashes here.

File details

Details for the file testyoke-0.0.4-py3-none-any.whl.

File metadata

  • Download URL: testyoke-0.0.4-py3-none-any.whl
  • Upload date:
  • Size: 11.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/2.0.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.6.0 requests-toolbelt/0.9.1 tqdm/4.37.0 CPython/3.7.3

File hashes

Hashes for testyoke-0.0.4-py3-none-any.whl
Algorithm Hash digest
SHA256 c1df32a7aeb2e118908977913a68b97d56f17df48d1767e557b61f7034e819e8
MD5 e8b33a0e7037a11e723138ad86c98bae
BLAKE2b-256 d8907d0f804c13235d2534385a1d8721b2077d66cc3e93f0dead3024db3000a1

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