Welcome, guest | Sign In | My Account | Store | Cart

Notice! PyPM is being replaced with the ActiveState Platform, which enhances PyPM’s build and deploy capabilities. Create your free Platform account to download ActivePython or customize Python with the packages you require and get automatic updates.

pypm install compare

How to install compare

  1. Download and install ActivePython
  2. Open Command Prompt
  3. Type pypm install compare
 Python 2.7Python 3.2Python 3.3
Windows (32-bit)
0.2b Available View build log
0.1a Available View build log
Windows (64-bit)
0.2b Available View build log
0.1a Available View build log
Mac OS X (10.5+)
0.2b Available View build log
0.1a Available View build log
Linux (32-bit)
0.2b Available View build log
0.1a Available View build log
Linux (64-bit)
0.2b Available View build log
0.1a Available View build log
Simplified BSD
Lastest release
version 0.2b on Feb 12th, 2011


Compare is a compact utility that provides an alternative, expressive syntax for comparing data values. Have you been looking for an escape from the stale XUnit style asserts that plague the omni-present unittest? You may have found just what you need. I invite you to take a look at this little utility. If it fits your style, you may use it as a drop-in replacement for the "self.assert..." style of doing assertions in python.

The compare API exposes the expect construct which allows you to compare values with readable and extensible syntax. It was designed to be a stand-alone alternative assertion syntax. As such you may use it as-is with your favorite testing/specification framework.

Documentation: http://packages.python.org/compare

Project source: https://github.com/rudylattae/compare

PyPI page: http://pypi.python.org/pypi/compare

  • provides a base set of matchers for comparing values
  • easy to extend with custom matchers
  • packaged as a single drop-in module

The core implementation of compare is a single file module with no additional requirements beyond the Python Standard Library.


The simplest and recommended way to install compare is with Pip. You may install the latest stable release from PyPI with pip:

> pip install compare

If you do not have pip, you may use easy_install:

> easy_install compare

Alternatively, you may download the source package from the compare page on PyPI, extract it and install it using:

> python setup.py install

If you wish, you may grab the in development (cutting-edge but unstable) version compare.py from the project repository and put it into your project directory.

What you get

When you install the package, you get the "expect" starter, a simple function that allows you to compare two values and fail if the outcome does not meet your expectation. This starter has extensible matchers that enable you to describe the expected outcome in a pythonic BDD manner.

Compare shines brightest when you are crafting executable specifications for your software. It helps you maintain your flow of thought without succumbing to test-focused non-pythonic distrations like "self.assertEqual(s)...", "self.assertTrue", etc.

Here is a trivial example of the readability you gain when you employ the "expect" construct in your specs.

> cat hello.py:

greeting = 'Hello you'

> cat hello_specs.py:

from compare import expect
import hello

expect(hello.greeting).to_equal('Hello you')

If you define an expectation that is not met, you will get an "Unmet Expectation" error which inherits from the python AssertionError so it is compatible with the usual unittest tools. Here is an example of such an error:

>>> from compare import expect
>>> opts = ['foo', 'bar', 'baz']
>>> expect(opts).to_contain('BAT')
Traceback (most recent call last):
UnmetExpectation: Expected ['foo', 'bar', 'baz'] to contain 'BAT'
What's missing

The expect syntax does not yet have a clean way to negate a matcher. This feature is planned for the next release. An example of the anticipated usage:

expect(['a', 'c', 'd']).NOT.to_contain('b')

The to_return matcher does not accept any parameters to pass to the callable.

Matchers do not accept custom fail messages.


I welcome any questions or feedback about bugs and suggestions on how to improve compare. Let me know what you think about compare. I am on twitter @RudyLattae . I appreciate constructive criticsms or high fives :)

Do you have suggestions for improvement? Then please create an issue with details of what you would like to see. I'll take a look at it and work with you to either kill the idea or implement it.


0.2b -- 2011-02-11

  • First public beta release
  • Added base matchers: to_be_less_than, to_be_less_than_or_equal_to, to_be_greater_than, to_be_greater_than_or_equal_to, to_be_none, to_be_truthy, to_be_falsy, to_raise
  • Added "rich comparison" matchers: ==, <, <=, >, >=
  • Documentation: Core API + Simple user guide.

0.1a -- 2011-02-01

  • First public alpha release

Subscribe to package updates

Last updated Feb 12th, 2011

Download Stats

Last month:1

What does the lock icon mean?

Builds marked with a lock icon are only available via PyPM to users with a current ActivePython Business Edition subscription.

Need custom builds or support?

ActivePython Enterprise Edition guarantees priority access to technical support, indemnification, expert consulting and quality-assured language builds.

Plan on re-distributing ActivePython?

Get re-distribution rights and eliminate legal risks with ActivePython OEM Edition.