Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Run all my doctests for all python modules in a folder without seeing failures because of bad imports

I've started integrating doctests into my modules. (Hooray!) These tend to be files which started as scripts, and are now are a few functions with CLI apps in the __name__=='__main__', so I don't want to put the running of the tests there. I tried nosetests --with-doctest, but get lots of failures I don't want to see, because during test discovery this import modules which don't contain doctests but do require importing things I don't have installed on this system, or should be run within special python installations. Is there a way I can run just all of my doctests?

I've considered a hotkey in vim to run "import doctest; doctest.testfile(currentFilename)" to run my doctests in the current module, and another script that runs all the tests - what do other doctest users do? Or should I be using something other than doctest?

like image 518
Thomas Avatar asked Sep 06 '10 18:09

Thomas


People also ask

What is the correct way to run all Doctests in a given file from the command line?

The tests in the text file can be run from the command line, just as with the Python source modules. $ python -m doctest -v doctest_in_help.


2 Answers

You can also create unittests that wrap desired doctests modules, it is a native feature of doctests: http://docs.python.org/2/library/doctest.html#unittest-api.

import unittest
import doctest 
import my_module_with_doctests

def load_tests(loader, tests, ignore):
    tests.addTests(doctest.DocTestSuite(my_module_with_doctests))
    return tests
like image 154
jb. Avatar answered Oct 07 '22 21:10

jb.


I think nose is the way. You should either exclude the problematic modules explicitly with -e or catch the missing imports in your code with constructs like this:

try:
    import simplejson as json
except ImportError:
    import json

Update:

Another option is to provide mock replacements for the missing modules. Let's say your code has something like this:

import myfunkymodule

and you're trying run your tests in a system where myfunkymodule is missing. You could create a mock_modules/myfunkymodule.py file with mock implementations of the stuff you need from it (perhaps using MiniMock, which I highly recommend if you are using doctest). You could then run nose like this:

$ PYTHONPATH=path_to/mock_modules nosetests --with-doctest
like image 27
Martin Blech Avatar answered Oct 07 '22 21:10

Martin Blech