choderalab / assaytools

Modeling and Bayesian analysis of fluorescence and absorbance assays.
http://assaytools.readthedocs.org
GNU Lesser General Public License v2.1
18 stars 11 forks source link

Add ipython notebook testing #3

Open jhprinz opened 9 years ago

jhprinz commented 9 years ago

Add the testing script from openpathsampling (opentis) and integrate into travis testing.

jchodera commented 9 years ago

This was added by #4, but how do I add this to travis for testing?

jhprinz commented 9 years ago

Ah. It works similar to nosetest. Just put the line

- python ipnbdoctest.py [options] xyz_notebook.ipynb

This will then start a kernel, run all cells and check if they pass. If you put the option --strict then also the output has to match. It takes care of changing memory addresses and UUIDs automatically. If it passes the tool exits with 0 signaling travis that the test passed. Otherwise it exits with 1 and travis assumes it failed.

It's a standalone script that requires 'ipython-notebook' and

import os,sys
import base64
import re
import argparse

This is the usage syntax:

>>> ipython jan-hendrikprinz$ python ipnbdoctest.py -h
usage: ipnbdoctest.py [-h] [--timeout TIMEOUT] [--strict] [--fail-if-timeout]
                      file.ipynb

Run all cell in an ipython notebook as a test and check whether these
successfully execute and compares their output to the one inside the notebook

positional arguments:
  file.ipynb         the notebook to be checked

optional arguments:
  -h, --help         show this help message and exit
  --timeout TIMEOUT  the default timeout time in seconds for a cell
                     evaluation. Default is 300s.
  --strict           if set to true then the default test is that cell have to
                     match otherwise a diff will not be considered a failed
                     test
  --fail-if-timeout  if set to true then a timeout is considered a failed test

The output looks like this: exampleoutputipynbtest