Literally exactly like Python's unittest but with colors.
Switch branches/tags
Nothing to show
Fetching latest commit…
Cannot retrieve the latest commit at this time.
Failed to load latest commit information.

Join the chat at


This is literally an exact clone of unittest (from Python 2.7), but with colors. (Now also compatible with Python 3!)


You literally use it in the exact same way as unittest.


You can just install it into your path or your sourced virtual environment with this extremely easy command:

pip install redgreenunittest

After that, just reference this package like a normal, regular old python package like this:

import redgreenunittest

If you do want to use it as a direct replacement for unittest without doing any extra work, you can just import like this:

import redgreenunittest as unittest


I assume you mean the Python framework. (Not that movie.) Remember when I said, "exact clone" before? I lied. There is one extra directory called "django" in there that contains a file called ""

If you want to use this as your test runner, and you're already using unittest, you can literally drop this line of code into your file, and it will straight up work if you followed those installation instructions. In fact you could even skip the referencing step since Python is smart.


Go ahead. Run your tests. Colors. It's like we live in the future.

DJANGO < 1.6

Running a Django version pre-1.6? Then you'll want the simple runner.



Ok, so if you're using a vim gui like MacVim or GVim and its shell to run your tests, they're going to look super weird. Sorry. You're boned for colors in that shell. You can use conque if you want. I made it work using zsh and oh-my-zsh and some medium-level vim scripting.

The reason it sucks is because $TERM is set to dumb in the vim gui shell (literally). So if you're using any other shell where $TERM is set to dumb, you're also going to be boned in that case.

You may be boned in other scenarios. My experience in this area is limited. Let me know if you find yourself boned in other situations. I may be able to help, or I can at least make a note in this README.