- Switched the release process to use python2 for everything, because python3 isn't installed in all TravisCI environments.
- Fix some minor issues in help strings that I discovered while working on "Python Testing with Green"
- Updated the release process so that instead of using a confusing mix of python2 and python3 to test and release, we just use python3.
- Fixed a bug that caused a strange extra test result to be output when your test tried to access a member of an object that didn't exist. Fixes #150.
- The
-R, --quiet-coverage
flag can be used to run coverage without printing the coverage report to stdout. Contributed by Martin Larralde. PR #149. Resolves feature request #148.
-
Improved file object compatibility of GreenStream. Code that now tries to access the writelines() function on sys.stdout or sys.stderr should no longer crash. Fixes #146.
-
Explicitly tell coverage to include missing line numbers to restore the default behavior that changed in coverage 4.1 and later.
-
Fix crash that would occur on Python 2.7.0, 2.7.1, 2.7.2, and 2.7.3. Reported by Christopher Gurnee. Fixes #137.
-
Fix print statements inside of tests on Windows with Python 2.7. Contributed by Christopher Gurnee. PR #138.
-
Remove TravisCI builds for Xcode 7.1, since they no longer support those builds. Unfortunately, the other OS X builds on Travis are broken for some reason that doesn't exist on real OS X. If anyone has any ideas, please share.
-
Remaining OS X builds on TravisCI are failing right now trying to execute PyPy itself (library linking errors). Since the tests work fine on actual OS X installations, I'm going to ignore the failing builds and shake my hand furiously at TravisCI.
-
Expose
green.version.__version__
asgreen.__version__
. Reported by Bryant Mairs. Fixes #128. -
Fix a crash that could occur if the test loader loaded an unrunnable object. Contributed by Eli Skeggs. PR #125.
-
Fixed a source of a double-submission bug that was being worked around internally. Contributed by Eli Skeggs. PR #126.
- No tests being loaded is now reported as an error, rather than a pass. This should help people more quickly discover when they have a typo in their command-line resulting in no tests being loaded. Contributed by Douglas Thor. Fixes #123.
-
On Windows we now mangle non-ascii output into ascii output, because...Windows. Contributed by MinchinWeb. Fixes #119.
-
We now run TravisCI builds for OS X 10.10 and 10.11. We had already been manually running tests on the latest OS X, but now TravisCI will do it for us.
- The built-in unittest module (stupidly) reports crashes in setUpClass() in a completely different way than any other failure or crash in unittest. Now we handle that way. Fixes #121.
-
Added
-W/--disable-windows
to disable converting colors to windows format. Useful for fake windows terminal environments that want the normal posix color codes. Contributed by Douglas Thor. -
Minor documentation update. Contributed by Thijs Triemstra.
-
Experimented with a coding style contributed by John Vandenberg. Decided we're not yet ready for that much structure. Maybe someday in the future.
-
Added
-q/--quiet-stdout
output option. Instead of capturing the stdout and stderr and presenting it in the summary of results, discard it completly for successful tests. --allow-stdout option overrides it. Contributed by nMustaki. -
Fixed Windows build due to URL change for
get-pip.py
. Contributed by nMustaki.
-
Python 3.5 support is now real, including automated builds for every commit. We now compensate for Python 3.5's new behavior of creating a dummy TestCase when failing to load a test target via a dotted name. All tests now pass on Python 3.5 for the first time! Lets keep it that way. I'm crossing my fingers that this might fix #93, #96, or #98 (which I'll work on next if it didn't). Fixes #99.
-
When the summary output of a test case is longer than the terminal width and wraps to the next line, we now rewind the cursor back to the original spot when rewriting in the final color. This means no more "duplicate" lines in verbose output with narrow terminal windows. Fixes #84.
- Intercept and handle coverage 4.x's new exception that occurs if there is no coverage to report.
- Fixed the new
-u/--include-patterns
to actually break apart the comma-separated list into separate entries. It was already working fine if you only included a single pattern.
-
Removed official Python 3.4+ support on Windows, due to AppVeyor's aggravating fail-4-times-out-of-5 behavior which I can't replicate at all on real windows. If someone wants to help find the problem so we can have consistent builds, I would be happy to restore official Python 3.4+ support on Windows. In practice, everything functions fine on Windows as far as I can tell, but this will drift in the future without builds to let us know what breaks.
-
Added
-u/--include-patterns
argument to pass through a list of include patterns to coverage. See the help docs for more info. -
Fixed a crash during handling a crash in loader code due to incorrect string formatting - contributed by jayvdb
-
Green can now be run as a module with
python -m green
syntax - contributed by krisztianfekete, fixes #91 -
Fixed the text describing the ordering of the screenshots - reported by robertlagrant
- Fixed help documentation for
-s/--processes
to account for changes made in the 2.0.0 overhaul. Fixes #83.
- Green no longer follows symlinks during discovery, to avoid infinite discovering.
-
Green no longer ignores config files when run as through django. Fixes #79 and #82.
-
Green no longer crashes when run through django when no tests are present.
-
Coverage output now appears before the summary, so that long coverage lists don't make it difficult to tell whether tests passed or not.
-
Fixed a bug that would cause a crash if a python package with an invalid (and thus un-importable) name existed within the discovery scope.
-
Updated the readme: swapped the features and screenshots section, swapped the positioning of the two screenshots.
- Fixed a bug that was causing crashes when subclassing Twisted's version of TestCase.
- When you use Python 2.7 and your failing test has a traceback that refers to a line that has unicode literals in it, green will now catch the resulting UnicodeDecodeError raised while trying to format the traceback and tell you the module it was trying to import and that it couldn't display the correct traceback due to the presence of a unicode literal. Resolves #77.
-
Captured stdout and stderr is reported properly once again. Regression in 2.0.0. Resolves issue #76.
-
Better capturing and reporting of exceptions that escape the testing framework.
-
Added screenshots to the readme file. Resolves issue #78.
-
Put the gitter badge inline with the other badges on the readme.
-
Ignore build failures on the alpha OS X builders TravisCI suddenly (and finally) turned on for us. They don't even have python installed yet...
-
Use a consistent tagline for the project everywhere ("Green is a clean, colorful, fast python test runner.")
-
Handled the case where a module could be discovered by directory searching by the main process but not by module name by the subprocess. Instead of crashing the subprocess and hanging, we now handle it and report it as an importing problem. One cause of this problem is forgetting your init.py Fixes issue #74.
-
Improved some of our own unit tests to follow more best practices. Fixes issue #62.;
-
BREAKING CHANGE: Major overhaul of the multiprocessing system. Tests always run in a separate worker process, even when only one process is specified. The default number of processes is now the number of logical processors detected instead of 1. Entire modules are now run in the same worker process by default to avoid both the overhead of multiple processes loading the same module and the overhead of running module and class setUp/tearDown multiple times redundantly. Classes or methods specified individually on the command-line will still be run in their own worker process. A ton of credit for this feature needs to go to Sam Spilsbury, who put in considerable time and effort to actually code up the initial pull request. Fixes issues #68, #70.
-
BREAKING CHANGE: Due the fact that no one uses it that I can tell and I don't want to maintain it, the
-m/--html
option has been removed. -
BREAKING CHANGE:
-o/--omit-patterns
now adds patterns to the default coverage omit list instead of replacing the default list. -
-O/--clear-omit
was added to clear the default coverage omit list. -
-k/--no-skip-report
was added to suppress the skip report if desired. -
Added a gitter chatroom link to the readme.
-
Support for acquiring and releasing arbitrary resources via the
-i/--initializer
and-z/--finalizer
options. Use it to setup/teardown things that an individual worker process will need exclusive access to apart from the other worker processes. -
We're back at 100% self-test coverage again. Yay!!!
-
Twisted's skip functionality is caught and recorded as skips instead of failures, if your
TestCase
subclassestwisted.trial.unittest.TestCase
and sets the class attribute.skip
toTrue
, or a test raisestwisted.trial.unittest.SkipTest
. -
Better handling of outside-of-test exceptions that occur inside worker processes.
-
We now capture stderr that is emitted during tests and present it after tests have run, just like we do with stdout.
-
Capturing stdout in worker processes more consistently works (no known bugs left).
-
The headers for stdout and stderr are now yellow, for better color scheme consistency (and so they don't get confused with skip headers).
-
Skip report headers now display the dotted test name in bold, just like other headers do. We are so consistent!
-
Fixed the skip report so it goes to the stream instead of stdout.
-
Disabled the annoying "Coverage.py warning: No data was collected." message that started happening a lot, even though coverage was working just fine.
-
Colors now work on AppVeyor builds, all hail the pretty colors! (Ironically, they don't support Windows ansi colors, they wrote their own interpreters for posix-style color escape codes.)
-
We now "close" the process pool instead of "terminating" it, which results in much better behavior in pypy and Windows, especially for things like tearDown stuff.
-
Added support for pypy3. Fiixes issue #63.
-
Disabled the virtual-env aspect of test_versions when run in Travis-CI, which is already in a virtualenv.
-
Virtualenv directories are now skipped during test discovery, so you can now use discovery on projects that contain one or more virtualenv directories inside of them.
-
Green always runs tests in a separate process now, though by default it still (currently) defaults to only one separate process, to maximize compatibility with large suites that already assume tests are run sequentially.
-
Green will now catch exceptions that the test framework doesn't handle and report them as test failures. Specifically, if your test case subclasses
testtools.TestCase
from the populartesttools
project, thenSystemExit
exceptions will escape the TestCase. Green will catch these exceptions and report them as failures. The one special-case is KeyboardInterrupt, which Green catches and interprets as a desire to terminate testing, and stops the test run. -
Changed the
-m/--html
help text to be a deprecation warning. If you would like this feature to stay, please create an issue stating so at https://github.com/CleanCut/green/issues/new
-
Added a deprecation warning for the
-m/--html
option. Unless I get some credible requests to leave the functionality, then I am going to proceed with removing it under the assumption that no one uses it (and I don't want to maintain complex, unused code). -
Investigated an issue with
SystemExit
andKeyboardInterrupt
halting the python process when your test subclassestesttools.TestCase
. Turns out that that is a design decision made by the testtools devs that they want those exceptions to stop everything. So we won't interfere with their desires. If you don't like the behavior, either stop subclassingtesttools.TestCase
or simply catch those two exceptions in your own tests.
-
Switched to cyan instead of blue on Windows only.
-
Stubbed in the beginnings of support for designating initialization to run in each process to obtain whatever resources might be needed by a single process (like its own database, for example).
- Fixed a regression that caused the
-a/--allow-stdout
cli option and corresponding config option to be ignored. Fixes issue #58.
-
Don't do the interactive print/reprint a test line behavior when we're not connected to a terminal. Contributed by Sam Spilsbury. Issue #52. Pull request #53.
-
Fixed a rather largeish bug that caused all configuration files to be ignored. Issue #56. Thanks for Monty Hindman for finding and reporting the bug.
-
The
g
script has been improved so that wildcards are passed through without local expansion.g
is is used by developers to try out changes to green itself in-place without installing it. Contributed by Monty Hindman. Pull request #57. -
Switch to Travis CI's docker builders for faster builds. Contributed by Sam Spilsbury. Issue #54. Pull request #55.
-
Cleaned up the formatting of dates on this changelog file.
-
Removed Python 3.3 builders on Linux, now that they're failing. Official support for Python 3.3 was dropped on 31 August 2014. It may still work in various use cases, but no guarantees.
-
Fixed
test_versions
again. The regex for non-Travis CI builds had broken, so that only the default python was being tested on development setups.
-
BREAKING CHANGE:
--omit
was renamed to--omit-patterns
for consistency with how other pattern-related options are named. -
BREAKING CHANGE:
--pattern
was renamed to--file-pattern
for consistency with how other pattern-related options are named. -
Added
-n
/--test-pattern
option to further refine which tests are actually run. Thanks to Monty Hindman for a pull request that got this feature going. -
Tweaked Travis CI builds
-
Fixed issue where command-line arguments could not override config arguments to set options back to default values. Reported by Monty Hindman. Issue #47.
-
Converted this changelog file to markdown format.
-
The tag to use for questions on StackOverflow was changed to python-green to avoid being too generic. The tag has a nice wiki entry and an initial question to get things going. Contributed by Mikko Ohtamaa. Pull request #43.
-
Added
-p/--pattern
option to specify the file pattern to search for tests under instead of the default patterntest*py
. Contributed by Monty Hindman. Issue #41. Pull request #42. -
Green now supports nose-parameterized. Contributed by Sam Spilsbury. Issue #39. Pull request #40.
-
Fixed a crash that could occur in PyPy 2.5
-
Fixed a crash that could occur during automated build testing with pip 6.x
-
Colorama is now a dependency on all platforms (dropping python-termstyle as a dependency is planned).
- When run in completions mode (
green --completions
), import errors in potential modules are ignored, so that the completions list is still generated instead of producing crash output.
- Output sent to stdout is now captured and then presented along with the list
of tracebacks. This can be disabled with
-a/--allow-stdout
. Issue #29.
-
Added
-f/--failfast
to stop executing tests after the first error, failure, or unexpected successes. -
Simplified the usage line in the help output.
-
You can press Ctrl-C once while tests are running to cleanly terminate the test run.
-
Some internal refactoring.
-
Python 3.3 is no longer supported on Windows. It might work still--it's just not supported.
-
Windows CI with AppVeyor is now passing.
- File handles are now explicitly closed in setup.py. Contributed by Simeon Visser.
- Trying to import a module by name that raises an exception during import now manufactures a test that reports an ImportError instead of just silently ignoring the file. Issue #31.
- Automated generation of the CLI documentation.
- Improved the suggest command for Bash-/Zsh-completion integration.
- Improved the README file.
- Fixed a crash that could occur if an exception was raised during a test case's setUpClass() or tearDownClass()
- We now explicitly terminate the thread pool and join() it. This makes self unit tests much easier to clean up on Windows, where the processes would block deletion of temporary directories.
- Set up continuous integration for Windows using AppVeyor. Thanks to ionelmc for the tip! Issue #11.
- We now use the fully-dotted test name at the start of each traceback in the error listing. Issue #28.
- PyPy libraries are now omitted from coverage by default.
- More cleanup on internal tests.
- Django integration! Issue #21. There are two ways to use green while running Django unit tests:
1) To just try it out, use the --testrunner option:
./manage.py test --testrunner=green.djangorunner.DjangoRunner
2) Make it persistent by adding the following line to your settings.py:
TEST_RUNNER=green.djangorunner.DjangoRunner
(Use green config files to customize the output)
-
Switched from using stderr to stdout. This makes piping output to another program much easier, and reserves stderr for actual errors running green itself.
-
Improved the exception output when a test module cannot be imported.
-
Updated the Travis config to make use of the Makefile
-
Updated the Makefile with more and better organized test targets.
-
Added a test_versions script that can be run on developer clones. It will auto-detect all versions of python (in the form of pythonX.Y) in $PATH and run many permutations of self tests on each version.
-
Fixed a crash that could occur if discovery did not find any tests and processes was set higher than one.
-
Fixed lots of tests so that they would succeed in all environments.
-
Internal refactoring of argument parsing and configuration handling.
- Fixed the new tests that failed if you ran them in-place on an installed version of green. Forgot to check the build status before I did the last release!
- Bash-completion and ZSH-completion support for options and test targets. Issue #7.
- Multiline docstrings (with -vv or -vvv) on test methods are now handled correctly. Initial whitespace is first stripped. Then lines are combined into one space-separated string until the first blank line. Issue #26.
-
Implemented custom test discovery code instead of relying on built-in unittest.discover(). So far, the new implementation mimics the built-in behavior except for fixing issue #14 (which unblocks #7). This enables working on #25 and any other bugs or behavior that was locked inside of unittest's quirky discovery implementation that we want to fix in the future.
-
Fixed travis config to exclude the example project in builds.
-
Reduced debug timestamp precision from microsecond- to second-based.
-
Exclude colorama from coverage reporting for the sake of Windows users.
-
Added some additional internal debug output.
-
Centralized internal debugging output.
-
"make clean" now cleans all
.coverage*
files in the project tree. -
Many new internal tests.
- Configuration file support, originally contributed by Tom Barron - Issues #20, #23, #24
-
Color works on Windows - Issues #18, #19
-
Self-tests run against installed versions automatically - Issue #10
-
Installation process is now tested automatically - Issue #9
-
Switched to "branch-based development"
-
Added an "example" directory with an example project with unit tests
-
Added the CHANGELOG (this file)
-
Improved the README.md file a lot based on feedback from reddit.
- Fixed MANIFEST so that installation didn't crash
-
Colorful - Terminal output makes good use of color when the terminal supports it.
-
Clean - Low redundancy in output. Result stats for each test is lined up in a vertical column.
-
Fast - Can run tests in independent processes.
-
Powerful - Multi-target + auto-discovery.
-
Traditional - Use the normal
unittest
classes and methods for your unit tests. -
Descriptive - Four verbosity levels, from just dots to full docstring output.
-
Thorough - Built-in, optional integration with coverage
-
Modern - Supports Python 2.7, 3.3, 3.4, and PyPy
-
Portable - Completely supports OS X, Linux, and BSDs (and maybe Windows).
-
Flexible - Optional HTML output.
- There were lots of versions before 1.0 was released (54 published releases, actually). No one heard about it before 1.0 though, so we didn't bother tracking individual releases.