Skip to main content

Behavior-oriented, expressive, developer-friendly assertions library

Project description

grappa logo

Build Status PyPI Coverage Status Documentation Status Stability Code Climate Python Versions Say Thanks

About

grappa is a behavior-oriented, self-declarative, expressive and developer-friendly lightweight assertion library for Python.

grappa comes with two declarative assertion styles: expect and should.

It also comes with a detailed, human-friendly error reporting system that aims to reduce friction, provide better feedback and improve human speed and agility while identifying and fixing errors.

To get started, take a look to the showcase code, demo, tutorial and documentation.

Status

grappa is currently beta quality software. Contributions and issue reporting is welcome.

Showcase

A small example demonstrating some grappa features:

from grappa import should

True | should.be.true
False | should.be.false
None | should.be.none

'bar' | should.be.equal.to('bar')
13.14 | should.be.lower.than(14)
13.14 | should.be.higher.than(13)

'Hello grappa' | should.match('(\W)+ grappa$')
'Hello grappa' | should.contain('grappa') | should.contain('he')

{'foo': True} | should.be.a('dict')
[1, 2, 3] | should.be.a('list') > should.have.length.of(3)
(lambda x: x) | should.not_be.have.type.of('lambda')

{'foo': 'bar'} | should.have.key('foo').that.should.be.equal.to('bar')
(1, 2, 3, 4) | should.be.a(tuple) > should.have.index.at(3) > should.be.equal.to(4)

an_object | should.have.properties('foo', 'bar', 'baz')
an_object | should.implement.methods('foo', 'bar', 'baz')

({'bar': [1, 2, 3]}
    | should.have.key('bar')
    > should.be.a('list')
    > should.have.length.of(3)
    > should.contain.item(3)
    > should.have.index.at(1)
    > should.be.equal.to(2))

See documentation for more examples.

Demo

showcase

Why grappa?

grappa aims to assist humans while doing a very recurrent and not very fun task in software development: testing things.

The core idea behind grappa comes from the fact that human time is considerably more expensive than machine time, and therefore any machine assistance to optimize processes and close the gap is beneficial.

With grappa you can express almost in plain English what the test contract actually is, but in a way that’s fun and easy to write but also more easy and pleasant to read or maintain by other developers.

The Zen of grappa

  • Testing is about feedback: detailed, easy to understand, human-friendly is always better.

  • Frictionless testing: introducing self-declarative behavior testing patterns can make testing more fun for test writers and more enjoyable for test readers.

  • Expressivity is paramount: humans should easily understand what the code is doing.

  • Human time is expensive: any modern software should assist people to identify and understand errors easily.

  • Make error reporting great again: feedback during testing is key, let’s make it more handy and less frustrating.

  • Testing patterns consolidation: software expectations are limited to the boundaries of language data types and structures.

  • Hurt less feelings: seeing errors is not a nice thing, but it can be painless if details are showed you in a more gentle way.

Features

  • Behavior-oriented expressive fluent API.

  • Built-in assertion DSL with English lexicon and semantics.

  • Supports both expect and should assertion styles.

  • Full-featured built-in assertion operators.

  • Human-friendly and detailed error reporting.

  • Built-in expectations difference comparison between subject and expected values.

  • Extensible assertions supporting third-party plugins.

  • Assertion chaining and composition.

  • Composable assertion via logical operators such as and & or.

  • Testing framework agnostic. Works with unittest, nosetests, pytest, behave

  • Easy to hack via programmatic API.

  • Lightweight and (almost) dependency-free.

  • Works with Python 2.7+, 3+, PyPy and potentially with other Python implementations.

Installation

Using pip package manager:

pip install --upgrade grappa

Or install the latest sources from Github:

pip install -e git+git://github.com/grappa-py/grappa.git#egg=grappa

History

v0.1.2 / 2017-03-26

  • feat(docs): add matchers supported keyword arguments

  • feat(docs): improve descriptions

  • feat(operators): improve length operator for access based chaining

  • fix(docs): update error custom message example

  • feat(docs): improve documentation. adds operators composition section

  • fix(setup.py): add author email

v0.1.1 / 2017-03-23

  • refactor(diff): process expected values as tuple first

  • fix(contain): remove print statements

  • refactor(core): normalize yielding syntax, add missing documentation

  • refactor(core): normalize yielding syntax, add missing documentation

  • feat(#26): support disable operator chaining

  • feat(#28): better assertion reporting. feat(operators): add index operator

  • refactor(reporter): support raw mode with proper indent pretty printing

  • refactor(operators): add satisfy/satisfies attribute operators

  • feat(diff): consume diff specific subject/expected values

  • feat(operators): add is/is_not operator attributes

  • refactor(core): isolate reporters per module

  • feat(#13, #25): add suboperators support and diff output report

  • refactor(docs): update organization name

  • refactor(docs): update project image

  • refactor(reporter): ignore subject/expected output if empty

  • refactor(reporter): show diff if enabled

  • feat(docs): add in a nutshell section

  • feat(#24, #25): feature enhancements

  • feat(docs): add say thanks badge

  • refactor(reporter): load value from operator first

  • fix(docs): use proper badges

  • fix(docs): update type operator examples

  • fix(metadata): update

  • refactor(test): add chained test for keys

  • feat(Makefile): add publish commands

0.1.0 (2017-03-05)

  • First version (beta)

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

grappa-0.1.2.tar.gz (33.6 kB view hashes)

Uploaded Source

Built Distribution

grappa-0.1.2-py2.py3-none-any.whl (60.9 kB view hashes)

Uploaded Python 2 Python 3

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