Skip to main content

Easy, flexible deep comparison and testing of structured data

Project description

Flexible comparison of nested python datastrucures and objects.

Composable "regular expressions" for data structures.

This module allows easy and flexible deep comparisons of
datastructure. It's not well documented yet but it's a port to python
of Test::Deep which is well documented
(http://search.cpan.org/~fdaly/Test-Deep/).

It can provide useful output, pin-pointing where 2 items begin to
differ, rather than just returning true or false. This makes it very
useful for unit-testing and deep.test provides classes for use with
unittest.py .

It allows easy comparison of objects - it just checks that
they're in the same class and have the same __dict__.

It allows set-wise comparison of lists or tuples.

Most importantly it allows aribitrary nesting of the various
comparisons and embedding of them inside other datastructures and
object. This makes it easy to perform comparisons that would otherwise
have been tedious.

It turns what would have involved lots of looping and iffing and
comparing into just putting together a structure that looks like what
you're trying to match.

Examples:

###
# Test that we have a list of objects from the correct classes (yes you
# can do this easily without deep.py).

three_types = [deep.InstanceOf(int),
deep.InstanceOf(list),
deep.InstanceOf(dict)]
diff = deep.diff([1, 2, 3], three_types)
if diff:
diff.print_full()

# Outputs
x[1]:
Expected: instance of <type 'list'>
Actual : instance of <type 'int'>

###
# Test that we have a list of strings that all match a pattern.

list_of_bings = deep.Elements(deep.Re("^bing "))
diff = deep.diff(["bing bong", "bing crosby", "bin laden"], list_of_bings)
if diff:
diff.print_full()

# Outputs
x[2]:
Expected: something matching '^bing '
Actual : 'bin laden'

###

# Test that we have an object who's "wibble" attribute is a dict and
# that this dict has 3 keys "time", "bings" and "things" and
# "time". We want to make sure that "time" is a float and we want to
# reuse the comparisons from the earlier examples for the other 2
# keys.

complex = deep.Attr("wibble", {"time": deep.InstanceOf(float),
"bings": list_of_bings,
"things": three_types})
class O(object):
wibble = {"time": 1234.12,
"bings": ["bing go"],
"things": [1, [], {}, "hello"]}

diff = deep.diff(O(), complex)
if diff:
diff.print_full()

# Outputs
len(x.wibble['things']):
Expected: 3
Actual : 4

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

deep-0.10.tar.gz (18.6 kB view details)

Uploaded Source

File details

Details for the file deep-0.10.tar.gz.

File metadata

  • Download URL: deep-0.10.tar.gz
  • Upload date:
  • Size: 18.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for deep-0.10.tar.gz
Algorithm Hash digest
SHA256 fd692023d65b21c11bdaa38f7b5264d195d2ed678ffc82f841a4a320a8e0127b
MD5 62aaae35b8be08b5dae0e728189e2b97
BLAKE2b-256 440dae234be6c9595329de866a17bfb85b41d4761e6252bda9e227559f6f51a7

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