========= Changelog ========= - :bug:`-` ``pytest.coverage`` incorrectly concatenated its ``opts`` argument to internal options; this has been fixed. - :release:`2.0.0 <2021-01-24>` - :support:`-` Drop Python 3.4 support. We didn't actually do anything to make the code not work on 3.4, but we've removed some 3.4 related runtime (and development) dependency limitations. Our CI will also no longer test on 3.4. .. warning:: This is technically a backwards incompatible change. - :support:`12` Upgrade our packaging manifest so tests (also docs, requirements files, etc) are included in the distribution archives. Thanks to Tomáš Chvátal for the report. - :support:`21` Only require ``enum34`` under Python 2 to prevent it clashing with the stdlib ``enum`` under Python 3. Credit: Alex Gaynor. - :bug:`- major` ``release.build``'s ``--clean`` flag has been updated: - It now honors configuration like the other flags in this task, specifically ``packaging.clean``. - It now defaults to ``False`` (rationale: most build operations in the wild tend to assume no cleaning by default, so defaulting to the opposite was sometimes surprising). .. warning:: This is a backwards incompatible change. - When ``True``, it applies to both build and dist directories, instead of just build. .. warning:: This is a backwards incompatible change. - :support:`-` Reverse the default value of ``release.build`` and ``release.publish``)'s ``wheel`` argument from ``False`` to ``True``. Included in this change is a new required runtime dependency on the ``wheel`` package. Rationale: at this point in time, most users will be expecting wheels to be available, and not building wheels is likely to be the uncommon case. .. warning:: This is a backwards incompatible change. - :bug:`- major` ``release.build`` and ``release.publish`` had bad kwargs-vs-config logic preventing flags such as ``--wheel`` or ``--python`` from actually working (config defaults always won out, leading to silent ignoring of user input). This has been fixed; config will now only be honored unless the CLI appears to be overriding it. - :support:`-` Replace some old Python 2.6-compatible syntax bits. - :feature:`-` Add a ``warnings`` kwarg/flag to ``pytest.test``, allowing one to call it with ``--no-warnings`` as an inline 'alias' for pytest's own ``--disable-warnings`` flag. - :bug:`- major` Fix minor display bug causing the ``pytest`` task module to append a trailing space to the invocation of pytest itself. - :support:`-` Modify ``release`` task tree to look at ``main`` branches in addition to ``master`` ones, for "are we on a feature release line or a bugfix one?" calculations, etc. - :release:`1.4.0 <2018-06-26>` - :release:`1.3.1 <2018-06-26>` - :release:`1.2.2 <2018-06-26>` - :release:`1.1.1 <2018-06-26>` - :release:`1.0.1 <2018-06-26>` - :bug:`-` Was missing a 'hide output' flag on a subprocess shell call, the result of which was mystery git branch names appearing in the output of ``inv release`` and friends. Fixed now. - :bug:`-` ``checks.blacken`` had a typo regarding its folder selection argument; the CLI/function arg was ``folder`` while the configuration value was ``folders`` (plural). It's been made consistent: the CLI/function argument is now ``folders``. - :feature:`-` Add a ``find_opts`` argument to ``checks.blacken`` for improved control over what files get blackened. - :release:`1.3.0 <2018-06-20>` - :feature:`-` Bump Releases requirement up to 1.6 and leverage its new ability to load Sphinx extensions, in ``packaging.release.prepare`` (which parses Releases changelogs programmatically). Prior to this, projects which needed extensions to build their doctree would throw errors when using the ``packaging.release`` module. - :release:`1.2.1 <2018-06-18>` - :support:`- backported` Remove some apparently non-functional ``setup.py`` logic around conditionally requiring ``enum34``; it was never getting selected and thus breaking a couple modules that relied on it. ``enum34`` is now a hard requirement like the other semi-optional-but-not-really requirements. - :release:`1.2.0 <2018-05-22>` - :feature:`-` Add ``travis.blacken`` which wraps the new ``checks.blacken`` (in diff+check mode, for test output useful for users who cannot themselves simply run black) in addition to performing Travis-oriented Python version checks and pip installation. This is necessary to remove boilerplate around the fact that ``black`` is not even visible to Python versions less than 3.6. - :feature:`-` Break out a generic form of the ``travis.sudo-coverage`` task into ``travis.sudo-run`` which can be used for arbitrary commands run under the ssh/sudo capable user generated by ``travis.make-sudouser``/``travis.make-sshable``. - :feature:`-` Add 'missing' arguments to ``pytest.integration`` so its signature now largely matches ``pytest.test``, which it wraps. - :feature:`-` Add the ``checks`` module, containing ``checks.blacken`` which executes the `black `_ code formatter. Thanks to Chris Rose. - :release:`1.1.0 <2018-05-14>` - :feature:`-` Split out the body of the (sadly incomplete) ``packaging.release.all`` task into the better-named ``packaging.release.prepare``. (``all`` continues to behave as it did, it just now calls ``prepare`` explicitly.) - :release:`1.0.0 <2018-05-08>` - :feature:`-` Pre-history / code primarily for internal consumption