Skip to main content

a nose plugin for IPython notebooks

Project description

# nosebook
[![Build Status][build_svg]][build_status] [![PyPI][pypi_svg]][pypi] [![BSD][license_svg]][license]


a [nose](http://nose.readthedocs.org/) plugin for finding and running IPython 3 notebooks as nose tests.

What it can't do in terms of `setup` and `tearDown`, `nosebook` makes up for in simplicity: there is no `%%nose` magic, no metadata required: the notebook on disk is the "gold master".

This makes it ideal for decreasing the burden of keeping documentation up to date with tests by making a single set of notebooks into both rich, multi-format documentation and a simple part of your test suite.


[build_svg]: https://travis-ci.org/bollwyvl/nosebook.svg?branch=master
[build_status]: https://travis-ci.org/bollwyvl/nosebook
[pypi_svg]: https://pypip.in/version/nosebook/badge.svg?style=flat
[pypi]: https://pypi.python.org/pypi/nosebook
[license_svg]: https://pypip.in/license/nose-watcher/badge.svg
[license]: ./LICENSE

## How does it work?
Each notebook found according to [`nosebook-match`](#nosebook-match) is started with a fresh kernel, based on the kernel specified in the notebook. If the kernel is not installed, no tests will be run and the error will be logged.

Each `code` cell that matches [`nosebook-match-cell`](#nosebook-match-cell) will be executed against the kernel in the order in which it appears in the notebook: other cells e.g. `markdown`, `raw`, are ignored.

The number and content of outputs has to __match exactly__, with the following parts of each output stripped:

- execution/prompt numbers, i.e. `[1]:`
- tracebacks

Non-deterministic output, such as with `_repr_` methods that include the memory location of the instance, will obviously not match every time. You can use [`nosebook-scrub`](#nosebook-scrub) to rewrite or remove offending content.

## Related work
- [`ipython_nose`](http://github.com/taavi/ipython_nose) allows you to use a notebook as a nose runner, with traditional `test_whatever` methods. You can sort of emulate this behavior with [`nosebook-match-cell`](#nosebook-match-cel)... as long as you check in passing tests!

## Configuring `nosetests` to use `nosebook`
These options can be specified in your [nose config file](./.noserc), or as long-form command line arguments, i.e. `--with-nosebook`.

#### `with-nosebook`
`nosetests` will look for notebooks that seem like tests, as configured with [`nosebook-match`](#nosebook-match).

_Default: False_


# Basic usage
!nosetests --with-nosebook

#### `nosebook-match`
A regular expression that tells nosebook what should be a testable notebook.

_Default: `.*[Tt]est.*.ipynb$`_


# Run against all notebooks... probably not a good idea, but maybe a great idea
!nosetests --with-nosebook --nosebook-match .*.ipynb

#### `nosebook-match-cell`
A regular expression that will be replaced throughout the expected outputs and generated outputs.

_Default: None_


# will run cells where tests are defined... but you should probably run them, too
!nosetests --with-nosebook --nosebook-match .*Simple.* --nosebook-match-cell '(def|class).*[Tt]est'

#### `nosebook-scrub`
A regular expression that will be replaced throughout the expected outputs and generated outputs.

_Default: None_


# you can't fail if you don't try
!nosetests --with-nosebook --nosebook-scrub .+

For multiple scrub values, you can pass a JSON-formatted list of regular expressions or object of pattern-replacement pairs that will be replaced. When passed in via the command line, you'll have to escape special characters: using a `.noserc` config file makes this easier.


# there are only 10 kinds of tests...
!nosetests --with-nosebook --nosebook-scrub='["0", "1"]'


# 0 is equally good
!nosetests --with-nosebook --nosebook-scrub='{"\\d+": "0"}'

## Contributing
[Issues](https://github.com/bollwyvl/nosebook/issues) and [pull requests](https://github.com/bollwyvl/nosebook/pulls) welcome!

## License
`nosebook` is released as free software under the [BSD 3-Clause license](./LICENSE).

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

nosebook-0.3.0.tar.gz (8.5 kB view details)

Uploaded Source

Built Distribution

nosebook-0.3.0-py2.py3-none-any.whl (8.2 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file nosebook-0.3.0.tar.gz.

File metadata

  • Download URL: nosebook-0.3.0.tar.gz
  • Upload date:
  • Size: 8.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for nosebook-0.3.0.tar.gz
Algorithm Hash digest
SHA256 acd5746218c5e805a8e5cf031d8e50820fc1f569855f5c72326526ec4077e704
MD5 055f4ec0fe8db3dac1e7c1f19489b1e9
BLAKE2b-256 26478fa7958f3acf6aa2acaaaaa949d4f9d6d3029c16da60c9ec02d7e5e76a75

See more details on using hashes here.

File details

Details for the file nosebook-0.3.0-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for nosebook-0.3.0-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 9000b5dc1988b72a4590bf3e78eec5a6169bcd83fa1406cb55c18e63a5cc19f0
MD5 964ae6483e05d81cc1d1df675df0f27c
BLAKE2b-256 a262ea936e8e736b9c7231573f8c8a0da0aa36acec22526ae855807e627fcf80

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