Skip to main content

Easy string baseline.

Project description

Documentation Status https://travis-ci.org/dmgass/baseline.svg?branch=master

This tool streamlines creation and maintenance of tests which compare string output against a baseline. It offers a mechanism to compare a string against a baselined copy and update the baselined copy to match the new value when a mismatch occurs. The update process includes a manual step to facilitate a review of the change before acceptance. The tool uses multi-line string format for string baselines to improve readability for human review.

Quick Start

Create an empty baseline with a triple quoted multi-line string. Place the ending triple quote on a separate line and indent it to the level you wish the string baseline update to be indented to. Add a compare of the string being tested to the baseline string. Then save the file as fox.py:

from baseline import Baseline

expected = Baseline("""
    """)

test_string = """THE QUICK BROWN FOX
    JUMPS
OVER THE LAZY DOG."""

assert test_string == expected

Run fox.py and observe that the assert raises an exception since the strings are not equal. Because the comparison failed, the tool located the triple quoted baseline string in the source file and updated it with the mis-compared value. When the interpreter exited, the tool saved the updated source file but changed the file name to fox.py.update:

from baseline import Baseline

expected = Baseline("""
    THE QUICK BROWN FOX
        JUMPS
    OVER THE LAZY DOG.
    """)

test_string = """THE QUICK BROWN FOX
    JUMPS
OVER THE LAZY DOG."""

assert test_string == expected

After reviewing the change with your favorite file differencing tool, accept the change by either manually overwriting the original file or use the baseline command line tool to scan the directory for updated scripts:

$ python -m baseline *
Found baseline updates for:
  fox.py

Hit [ENTER] to accept, [Ctrl-C] to cancel

Pressing Enter causes the tool to overwrite the scripts with the new baseline updates and remove the temporary .py.update files.

Run fox.py again and observe the assert does not raise an exception nor is a copy of the source file update generated. If in the future the test value changes, the assert raises an exception and causes a new source file update to be generated. Simply repeat the review and acceptance step and you are back in business!

Project details


Download files

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

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distribution

baseline-1.2.1-py2.py3-none-any.whl (15.7 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file baseline-1.2.1-py2.py3-none-any.whl.

File metadata

  • Download URL: baseline-1.2.1-py2.py3-none-any.whl
  • Upload date:
  • Size: 15.7 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.3.0 pkginfo/1.6.1 requests/2.23.0 setuptools/51.1.0.post20201221 requests-toolbelt/0.9.1 tqdm/4.55.0 CPython/3.8.7

File hashes

Hashes for baseline-1.2.1-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 1f8046d5ecd9402cf6a2edde79ab7a5a61da9292808f9ea077f6025c548bfcfc
MD5 31513e733d544dc46c786de85241406e
BLAKE2b-256 80c9e0173857e1350599a0b0eb6c8bc059a345aebdb947839f3d25835b5a44f8

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