debian packaging for Python jsonschema
Go to file
Julian Berman f672988e2c
Need to preserve backwards compat for RefResolvers without the new methods.
2015-03-21 22:08:54 -04:00
benchmarks Probably should combine these at some point, but for now move them. 2015-03-15 12:27:15 -04:00
docs Fix Draft4Validator example code in validate.rst 2015-01-07 13:56:02 +11:00
json Merge commit '45cf1fb8a6a0b7ea1ab8de8ea9fc7addb0ffd149' 2014-12-07 12:22:37 -05:00
jsonschema Need to preserve backwards compat for RefResolvers without the new methods. 2015-03-21 22:08:54 -04:00
.gitignore Er, green doesn't work on 2.6, and make running right out of a checkout easier. 2015-03-15 14:00:10 -04:00
.travis.yml I give up. 2015-03-15 18:20:00 -04:00
CHANGELOG.rst Release notes for v2.4.0 2014-08-18 20:53:47 -04:00
COPYING Update copyright. 2013-02-17 15:32:44 -05:00
MANIFEST.in Switch to vcversioner, use repoze.lru only on 2.6, and add extras_require for format. 2015-03-15 11:45:34 -04:00
README.rst It's hard to be enthusiastic about tox anymore. 2015-03-14 21:23:13 -04:00
setup.cfg Build universal wheels. 2013-11-23 20:25:50 -05:00
setup.py Switch to vcversioner, use repoze.lru only on 2.6, and add extras_require for format. 2015-03-15 11:45:34 -04:00
tox.ini Er, green doesn't work on 2.6, and make running right out of a checkout easier. 2015-03-15 14:00:10 -04:00
version.txt Pass in caches instead of arguments. 2015-03-21 21:56:50 -04:00

README.rst

.. image:: https://travis-ci.org/Julian/jsonschema.svg
==========
jsonschema
==========

``jsonschema`` is an implementation of `JSON Schema <http://json-schema.org>`_
for Python (supporting 2.6+ including Python 3).

.. code-block:: python

    >>> from jsonschema import validate

    >>> # A sample schema, like what we'd get from json.load()
    >>> schema = {
    ...     "type" : "object",
    ...     "properties" : {
    ...         "price" : {"type" : "number"},
    ...         "name" : {"type" : "string"},
    ...     },
    ... }

    >>> # If no exception is raised by validate(), the instance is valid.
    >>> validate({"name" : "Eggs", "price" : 34.99}, schema)

    >>> validate(
    ...     {"name" : "Eggs", "price" : "Invalid"}, schema
    ... )                                   # doctest: +IGNORE_EXCEPTION_DETAIL
    Traceback (most recent call last):
        ...
    ValidationError: 'Invalid' is not of type 'number'


Features
--------

* Full support for
  `Draft 3 <https://python-jsonschema.readthedocs.org/en/latest/validate/#jsonschema.Draft3Validator>`_
  **and** `Draft 4 <https://python-jsonschema.readthedocs.org/en/latest/validate/#jsonschema.Draft4Validator>`_
  of the schema.

* `Lazy validation <https://python-jsonschema.readthedocs.org/en/latest/validate/#jsonschema.IValidator.iter_errors>`_
  that can iteratively report *all* validation errors.

* Small and extensible

* `Programmatic querying <https://python-jsonschema.readthedocs.org/en/latest/errors/#module-jsonschema>`_
  of which properties or items failed validation.


Release Notes
-------------

* A simple CLI was added for validation
* Validation errors now keep full absolute paths and absolute schema paths in
  their ``absolute_path`` and ``absolute_schema_path`` attributes. The ``path``
  and ``schema_path`` attributes are deprecated in favor of ``relative_path``
  and ``relative_schema_path``\ .

*Note:* Support for Python 3.2 was dropped in this release, and installation
now uses setuptools.


Running the Test Suite
----------------------

If you have ``tox`` installed (perhaps via ``pip install tox`` or your
package manager), running``tox`` in the directory of your source checkout will
run ``jsonschema``'s test suite on all of the versions of Python ``jsonschema``
supports. Note that you'll need to have all of those versions installed in
order to run the tests on each of them, otherwise ``tox`` will skip (and fail)
the tests on that version.

Of course you're also free to just run the tests on a single version with your
favorite test runner. The tests live in the ``jsonschema.tests`` package.


Community
---------

There's a `mailing list <https://groups.google.com/forum/#!forum/jsonschema>`_
for this implementation on Google Groups.

Please join, and feel free to send questions there.


Contributing
------------

I'm Julian Berman.

``jsonschema`` is on `GitHub <http://github.com/Julian/jsonschema>`_.

Get in touch, via GitHub or otherwise, if you've got something to contribute,
it'd be most welcome!

You can also generally find me on Freenode (nick: ``tos9``) in various
channels, including ``#python``.

If you feel overwhelmingly grateful, you can woo me with beer money on
`Gittip <https://www.gittip.com/Julian/>`_ or via Google Wallet with the email
in my GitHub profile.