Basically, growl notifications (or other callbacks) when tests break or pass. Does anything like this exist?
If not, it should be pretty easy to write.. Easiest way would be to..
- run
python-autotest myfile1.py myfile2.py etc.py
- Check if files-to-be-monitored have been modified (possibly just if they've been saved).
- Run any tests in those files.
- If a test fails, but in the previous run it passed, generate a growl alert. Same with tests that fail then pass.
- Wait, and repeat steps 2-5.
The problem I can see there is if the tests are in a different file. The simple solution would be to run all the tests after each save.. but with slower tests, this might take longer than the time between saves, and/or could use a lot of CPU power etc..
The best way to do it would be to actually see what bits of code have changed, if function abc() has changed, only run tests that interact with this.. While this would be great, I think it'd be extremely complex to implement?
To summarise:
- Is there anything like the Ruby tool
autotest
(part of the ZenTest package), but for Python code? - How do you check which functions have changed between two revisions of a script?
- Is it possible to determine which functions a command will call? (Somewhat like a reverse traceback)