diff --git a/.codecov.yml b/.codecov.yml index 64dd7001c..f82b11d36 100644 --- a/.codecov.yml +++ b/.codecov.yml @@ -26,5 +26,4 @@ comment: require_changes: no ignore: - - "tox/_verlib.py" # vendored in and not internally tested - - "tox/__main__.py" + - "src/tox/_verlib.py" # vendored in and not internally tested diff --git a/.gitignore b/.gitignore index 056b7e126..d4627d2ce 100644 --- a/.gitignore +++ b/.gitignore @@ -26,3 +26,4 @@ htmlcov py27/ .*_cache +_draft.rst diff --git a/CHANGELOG.rst b/CHANGELOG.rst index 76024f6b2..ff34f2a06 100644 --- a/CHANGELOG.rst +++ b/CHANGELOG.rst @@ -1,7 +1,4 @@ -CHANGELOG -========= - -Versions follow `Semantic Versioning `_ (..). +Versions follow `Semantic Versioning `_ (``..``). Backward incompatible (breaking) changes will only be introduced in major versions with advance notice in the **Deprecations** section of releases. @@ -23,6 +20,8 @@ on Github: folder. If necessary, the generated text can be edited afterwards to e.g. merge rc changes into the final release notes. +.. include:: ../_draft.rst + .. towncrier release notes start 3.0.0 (2018-04-02) @@ -92,8 +91,8 @@ Features ``platform.machine()``. (`#740 `_) -Documentation improvements -^^^^^^^^^^^^^^^^^^^^^^^^^^ +Documentation +^^^^^^^^^^^^^ - Change favicon to the vector beach ball - by @hazalozturk (`#748 `_) @@ -101,8 +100,8 @@ Documentation improvements (`#639 `_) -Miscellaneous / trivial changes -^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ +Miscellaneous +^^^^^^^^^^^^^ - Running ``tox`` without a ``setup.py`` now has a more friendly error message and gives troubleshooting suggestions - by @Volcyy. @@ -119,8 +118,8 @@ Miscellaneous / trivial changes 2.9.1 (2017-09-29) ------------------ -Misc -^^^^ +Miscellaneous +^^^^^^^^^^^^^ - integrated new release process and fixed changelog rendering for pypi.org - by `@obestwalter `_. @@ -146,8 +145,8 @@ Bugfixes (`#571 `_) -Misc -^^^^ +Miscellaneous +^^^^^^^^^^^^^ - `#635 `_ inherit from correct exception - by `@obestwalter `_ @@ -159,8 +158,8 @@ Misc by `@obestwalter `_. -Improved Documentation -^^^^^^^^^^^^^^^^^^^^^^ +Documentation +^^^^^^^^^^^^^ - add `towncrier `_ to allow adding changelog entries with the pull requests without generating merge conflicts; diff --git a/changelog/19.feature.rst b/changelog/19.feature.rst index 3639b2801..6ef459bc3 100644 --- a/changelog/19.feature.rst +++ b/changelog/19.feature.rst @@ -1,3 +1,3 @@ Add support for multiple PyPy versions using default factors. This allows you to use, for example, ``pypy27`` knowing that the correct intepreter will be -used by default - by @stephenfin +used by default - by :user:`stephenfin` diff --git a/changelog/477.bugfix.rst b/changelog/477.bugfix.rst index 39e12987f..2dc3f4fa6 100644 --- a/changelog/477.bugfix.rst +++ b/changelog/477.bugfix.rst @@ -2,4 +2,4 @@ Add ``ignore_basepython_conflict``, which determines whether conflicting ``basepython`` settings for environments containing default factors, such as ``py27`` or ``django18-py35``, should be ignored or result in warnings. This was a common source of misconfiguration and is rarely, if ever, desirable from -a user perspective - by @stephenfin +a user perspective - by :user:`stephenfin` diff --git a/changelog/706.bugfix.rst b/changelog/706.bugfix.rst index b0827db66..01acd68b7 100644 --- a/changelog/706.bugfix.rst +++ b/changelog/706.bugfix.rst @@ -1 +1 @@ -Fix bug with incorrectly defactorized dependencies - by @bartsanchez +Fix bug with incorrectly defactorized dependencies (deps passed to pip were not de-factorized) - by :user:`bartsanchez` diff --git a/changelog/754.misc.rst b/changelog/754.misc.rst index 90c0d6f45..9aeeb6562 100644 --- a/changelog/754.misc.rst +++ b/changelog/754.misc.rst @@ -1 +1 @@ -filter out unwanted files in package - by @obestwalter +filter out unwanted files in package - by :user:`obestwalter` diff --git a/changelog/794.feature.rst b/changelog/794.feature.rst index 085334b92..046a6ae3b 100644 --- a/changelog/794.feature.rst +++ b/changelog/794.feature.rst @@ -2,4 +2,4 @@ Add support to explicitly invoke interpreter directives for environments with long path lengths. In the event that ``tox`` cannot invoke scripts with a system-limited shebang (e.x. a Linux host running a Jenkins Pipeline), a user can set the environment variable ``TOX_LIMITED_SHEBANG`` to workaround the -system's limitation (e.x. ``export TOX_LIMITED_SHEBANG=1``) - by @jdknight +system's limitation (e.x. ``export TOX_LIMITED_SHEBANG=1``) - by :user:`jdknight` diff --git a/changelog/797.doc.rst b/changelog/797.doc.rst index ad4d96935..6464c9c2e 100644 --- a/changelog/797.doc.rst +++ b/changelog/797.doc.rst @@ -1 +1 @@ -extend the plugin documentation and make lot of small fixes and improvements - by @obestwalter +extend the plugin documentation and make lot of small fixes and improvements - by :user:`obestwalter` diff --git a/changelog/798.feature.rst b/changelog/798.feature.rst index 87caabf30..25eba60e2 100644 --- a/changelog/798.feature.rst +++ b/changelog/798.feature.rst @@ -1 +1 @@ -introduce a constants module to be used internally and as experimental API - by @obestwalter +introduce a constants module to be used internally and as experimental API - by :user:`obestwalter` diff --git a/changelog/799.doc.rst b/changelog/799.doc.rst index c3031d682..ba23f96df 100644 --- a/changelog/799.doc.rst +++ b/changelog/799.doc.rst @@ -1 +1 @@ -tidy up tests - remove unused fixtures, update old cinstructs, etc. - by @obestwalter +tidy up tests - remove unused fixtures, update old cinstructs, etc. - by :user:`obestwalter` diff --git a/changelog/800.misc.rst b/changelog/800.misc.rst index 6fddb9740..c614256c7 100644 --- a/changelog/800.misc.rst +++ b/changelog/800.misc.rst @@ -1 +1 @@ -make the already existing implicit API explicit - by @obestwalter +make the already existing implicit API explicit - by :user:`obestwalter` diff --git a/changelog/801.misc.rst b/changelog/801.misc.rst index 8f148d676..158474878 100644 --- a/changelog/801.misc.rst +++ b/changelog/801.misc.rst @@ -1 +1 @@ -improve tox quickstart and corresponding tests - @obestwalter +improve tox quickstart and corresponding tests - by :user:`obestwalter` diff --git a/changelog/802.misc.rst b/changelog/802.misc.rst index facd8bb2b..85dfebb26 100644 --- a/changelog/802.misc.rst +++ b/changelog/802.misc.rst @@ -1 +1 @@ -tweak codecov settings via .codecov.yml - by @obestwalter +tweak codecov settings via .codecov.yml - by :user:`obestwalter` diff --git a/changelog/856.feature.rst b/changelog/856.feature.rst index 0cf2b18d4..e6776c68f 100644 --- a/changelog/856.feature.rst +++ b/changelog/856.feature.rst @@ -1 +1,2 @@ -Make ``py2`` and ``py3`` aliases also resolve via ``py`` on windows +Make ``py2`` and ``py3`` aliases also resolve via ``py`` on windows by :user:`asottile`. This enables the following things: +``tox -e py2`` and ``tox -e py3`` work on windows (they already work on posix); and setting ``basepython=python2`` or ``basepython=python3`` now works on windows. diff --git a/changelog/859.doc.rst b/changelog/859.doc.rst new file mode 100644 index 000000000..34728b0fa --- /dev/null +++ b/changelog/859.doc.rst @@ -0,0 +1 @@ +Various improvements to documentation: open browser once documentation generation is done, show Github/Travis info on documentation page, remove duplicate header for changelog, generate unreleased news as DRAFT on top of changelog, make the changelog page more compact and readable (width up to 1280px) by :user:`gaborbernat` diff --git a/changelog/examples.rst b/changelog/examples.rst index 746d86de1..a1c120470 100644 --- a/changelog/examples.rst +++ b/changelog/examples.rst @@ -2,17 +2,17 @@ file ``544.doc.rst``:: - explain everything much better - by @passionate_technicalwriter + explain everything much better - by :user:`passionate_technicalwriter` file ``544.feature.rst``:: - ``tox --version`` now shows information about all registered plugins - by @obestwalter + ``tox --version`` now shows information about all registered plugins - by :user:`obestwalter` file ``571.bugfix.rst``:: ``skip_install`` overrides ``usedevelop`` (``usedevelop`` is an option to choose the installation type if the package is installed and `skip_install` determines if it should be - installed at all) - by @ferdonline + installed at all) - by :user:`ferdonline` .. see tox/pyproject.toml for all available categories diff --git a/doc/_static/custom.css b/doc/_static/custom.css new file mode 100644 index 000000000..524487594 --- /dev/null +++ b/doc/_static/custom.css @@ -0,0 +1,52 @@ +div.document { + width: 100%; + max-width: 1520px; +} + +div.body { + max-width: 1280px; +} + +img, div.figure { + margin: 0 !important +} + +ul > li { + text-align: justify; +} + +ul > li > p { + margin-bottom: 0; + +} + +div.body code.descclassname { + display: none +} + +.wy-table-responsive table td { + white-space: normal !important; +} + +.wy-table-responsive { + overflow: visible !important; +} + +div.toctree-wrapper.compound > ul > li { + margin: 0; + padding: 0 +} + +code.docutils.literal { + background-color: #ECF0F3; + padding: 0 1px; +} + +div#changelog-history h3{ + margin-top: 10px; +} + +div#changelog-history h2{ + font-style: italic; + font-weight: bold; +} diff --git a/doc/img/tox.png b/doc/_static/img/tox.png similarity index 100% rename from doc/img/tox.png rename to doc/_static/img/tox.png diff --git a/doc/img/tox.svg b/doc/_static/img/tox.svg similarity index 100% rename from doc/img/tox.svg rename to doc/_static/img/tox.svg diff --git a/doc/img/toxfavi.ico b/doc/_static/img/toxfavi.ico similarity index 100% rename from doc/img/toxfavi.ico rename to doc/_static/img/toxfavi.ico diff --git a/doc/_static/sphinxdoc.css b/doc/_static/sphinxdoc.css deleted file mode 100644 index 78de68eaa..000000000 --- a/doc/_static/sphinxdoc.css +++ /dev/null @@ -1,339 +0,0 @@ -/* - * sphinxdoc.css_t - * ~~~~~~~~~~~~~~~ - * - * Sphinx stylesheet -- sphinxdoc theme. Originally created by - * Armin Ronacher for Werkzeug. - * - * :copyright: Copyright 2007-2010 by the Sphinx team, see AUTHORS. - * :license: BSD, see LICENSE for details. - * - */ - -@import url("basic.css"); - -/* -- page layout ----------------------------------------------------------- */ - -body { - font-family: 'Lucida Grande', 'Lucida Sans Unicode', 'Geneva', - 'Verdana', sans-serif; - font-size: 1.1em; - letter-spacing: -0.01em; - line-height: 150%; - text-align: center; - background-color: #BFD1D4; - color: black; - padding: 0; - border: 1px solid #aaa; - - margin: 0px 80px 0px 80px; - min-width: 740px; -} - -div.document { - background-color: white; - text-align: left; - background-image: url(contents.png); - background-repeat: repeat-x; -} - -div.bodywrapper { - margin: 0 240px 0 0; - border-right: 1px solid #ccc; -} - -div.body { - margin: 0; - padding: 0.5em 20px 20px 20px; -} - -div.related { - font-size: 0.8em; -} - -div.related ul { - background-image: url(navigation.png); - height: 2em; - border-top: 1px solid #ddd; - border-bottom: 1px solid #ddd; -} - -div.related ul li { - margin: 0; - padding: 0; - height: 2em; - float: left; -} - -div.related ul li.right { - float: right; - margin-right: 5px; -} - -div.related ul li a { - margin: 0; - padding: 0 5px 0 5px; - line-height: 1.75em; - color: #EE9816; -} - -div.related ul li a:hover { - color: #3CA8E7; -} - -div.sphinxsidebarwrapper { - padding: 0; -} - -div.sphinxsidebar { - margin: 0; - padding: 0.5em 15px 15px 0; - width: 210px; - float: right; - font-size: 1em; - text-align: left; -} - -div.sphinxsidebar h3, div.sphinxsidebar h4 { - margin: 1em 0 0.5em 0; - font-size: 1em; - padding: 0.1em 0 0.1em 0.5em; - color: white; - border: 1px solid #86989B; - background-color: #AFC1C4; -} - -div.sphinxsidebar h3 a { - color: white; -} - -div.sphinxsidebar ul { - padding-left: 1.5em; - margin-top: 7px; - padding: 0; - line-height: 130%; -} - -div.sphinxsidebar ul ul { - margin-left: 20px; -} - -div.footer { - background-color: #E3EFF1; - color: #86989B; - padding: 3px 8px 3px 0; - clear: both; - font-size: 0.8em; - text-align: right; -} - -div.footer a { - color: #86989B; - text-decoration: underline; -} - -/* -- body styles ----------------------------------------------------------- */ - -p { - margin: 0.8em 0 0.5em 0; -} - -a { - color: #CA7900; - text-decoration: none; -} - -a:hover { - color: #2491CF; -} - -div.body a { - text-decoration: underline; -} - -h1 { - margin: 0; - padding: 0.7em 0 0.3em 0; - font-size: 1.5em; - color: #11557C; -} - -h2 { - margin: 1.3em 0 0.2em 0; - font-size: 1.35em; - padding: 0; -} - -h3 { - margin: 1em 0 -0.3em 0; - font-size: 1.2em; -} - -div.body h1 a, div.body h2 a, div.body h3 a, div.body h4 a, div.body h5 a, div.body h6 a { - color: black!important; -} - -h1 a.anchor, h2 a.anchor, h3 a.anchor, h4 a.anchor, h5 a.anchor, h6 a.anchor { - display: none; - margin: 0 0 0 0.3em; - padding: 0 0.2em 0 0.2em; - color: #aaa!important; -} - -h1:hover a.anchor, h2:hover a.anchor, h3:hover a.anchor, h4:hover a.anchor, -h5:hover a.anchor, h6:hover a.anchor { - display: inline; -} - -h1 a.anchor:hover, h2 a.anchor:hover, h3 a.anchor:hover, h4 a.anchor:hover, -h5 a.anchor:hover, h6 a.anchor:hover { - color: #777; - background-color: #eee; -} - -a.headerlink { - color: #c60f0f!important; - font-size: 1em; - margin-left: 6px; - padding: 0 4px 0 4px; - text-decoration: none!important; -} - -a.headerlink:hover { - background-color: #ccc; - color: white!important; -} - -cite, code, tt { - font-family: 'Consolas', 'Deja Vu Sans Mono', - 'Bitstream Vera Sans Mono', monospace; - font-size: 0.95em; - letter-spacing: 0.01em; -} - -tt { - background-color: #f2f2f2; - border-bottom: 1px solid #ddd; - color: #333; -} - -tt.descname, tt.descclassname, tt.xref { - border: 0; -} - -hr { - border: 1px solid #abc; - margin: 2em; -} - -a tt { - border: 0; - color: #CA7900; -} - -a tt:hover { - color: #2491CF; -} - -pre { - font-family: 'Consolas', 'Deja Vu Sans Mono', - 'Bitstream Vera Sans Mono', monospace; - font-size: 0.95em; - letter-spacing: 0.015em; - line-height: 120%; - padding: 0.5em; - border: 1px solid #ccc; - background-color: #f8f8f8; -} - -pre a { - color: inherit; - text-decoration: underline; -} - -td.linenos pre { - padding: 0.5em 0; -} - -div.quotebar { - background-color: #f8f8f8; - max-width: 350px; - float: right; - padding: 2px 7px; - border: 1px solid #ccc; -} - -div.topic { - background-color: #f8f8f8; -} - -table { - border-collapse: collapse; - margin: 0 -0.5em 0 -0.5em; -} - -table td, table th { - padding: 0.2em 0.5em 0.2em 0.5em; -} - -div.admonition, div.warning { - font-size: 0.9em; - margin: 1em 0 1em 0; - border: 1px solid #86989B; - background-color: #f7f7f7; - padding: 0; -} - -div.admonition p, div.warning p { - margin: 0.5em 1em 0.5em 1em; - padding: 0; -} - -div.admonition pre, div.warning pre { - margin: 0.4em 1em 0.4em 1em; -} - -div.admonition p.admonition-title, -div.warning p.admonition-title { - margin: 0; - padding: 0.1em 0 0.1em 0.5em; - color: white; - border-bottom: 1px solid #86989B; - font-weight: bold; - background-color: #AFC1C4; -} - -div.warning { - border: 1px solid #940000; -} - -div.warning p.admonition-title { - background-color: #CF0000; - border-bottom-color: #940000; -} - -div.admonition ul, div.admonition ol, -div.warning ul, div.warning ol { - margin: 0.1em 0.5em 0.5em 3em; - padding: 0; -} - -div.versioninfo { - margin: 1em 0 0 0; - border: 1px solid #ccc; - background-color: #DDEAF0; - padding: 8px; - line-height: 1.3em; - font-size: 0.9em; -} - -.viewcode-back { - font-family: 'Lucida Grande', 'Lucida Sans Unicode', 'Geneva', - 'Verdana', sans-serif; -} - -div.viewcode-block:target { - background-color: #f4debf; - border-top: 1px solid #ac9; - border-bottom: 1px solid #ac9; -} diff --git a/doc/conf.py b/doc/conf.py index 07924c374..dfb0c12b8 100644 --- a/doc/conf.py +++ b/doc/conf.py @@ -1,16 +1,37 @@ import os -import sys +import re +import subprocess from datetime import date +from pathlib import Path from pkg_resources import get_distribution -sys.path.insert(0, os.path.dirname(__file__)) extensions = [ "sphinx.ext.autodoc", "sphinx.ext.extlinks", "sphinx.ext.intersphinx", "sphinx.ext.viewcode", ] +ROOT_SRC_TREE_DIR = Path(__file__).parents[1] + + +def generate_draft_news(): + home = "https://github.com" + issue = "{}/issue".format(home) + fragments_path = ROOT_SRC_TREE_DIR / "changelog" + for pattern, replacement in ( + (r"[^`]@([^,\s]+)", r"`@\1 <{}/\1>`_".format(home)), + (r"[^`]#([\d]+)", r"`#pr\1 <{}/\1>`_".format(issue)), + ): + for path in fragments_path.glob("*.rst"): + path.write_text(re.sub(pattern, replacement, path.read_text())) + changelog = subprocess.check_output( + ["towncrier", "--draft", "--version", "DRAFT"], cwd=str(ROOT_SRC_TREE_DIR) + ) + (ROOT_SRC_TREE_DIR / "_draft.rst").write_bytes(changelog) + + +generate_draft_news() project = u"tox" _full_version = get_distribution(project).version @@ -28,11 +49,23 @@ templates_path = ["_templates"] pygments_style = "sphinx" + html_theme = "alabaster" -html_logo = "img/tox.png" -html_favicon = "img/toxfavi.ico" -html_static_path = ["_static"] +html_theme_options = { + "logo": "img/tox.png", + "github_user": "tox-dev", + "github_repo": "tox", + "description": "standardise testing in Python", + "github_banner": "true", + "travis_button": "true", + "badge_branch": "master", + "fixed_sidebar": "false", +} +html_sidebars = { + "**": ["about.html", "localtoc.html", "relations.html", "searchbox.html", "donate.html"] +} html_show_sourcelink = False +html_static_path = ["_static"] htmlhelp_basename = "{}doc".format(project) latex_documents = [("index", "tox.tex", u"{} Documentation".format(project), author, "manual")] man_pages = [("index", project, u"{} Documentation".format(project), [author], 1)] diff --git a/pyproject.toml b/pyproject.toml index 7ad12363f..deec89010 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -1,3 +1,10 @@ +[build-system] +requires = [ + "setuptools >= 35.0.2", + "setuptools_scm >= 2.0.0, <3", + "wheel >= 0.29.0", +] + [tool.towncrier] package = "tox" filename = "CHANGELOG.rst" @@ -32,10 +39,10 @@ [[tool.towncrier.type]] directory = "doc" - name = "Documentation improvements" + name = "Documentation" showcontent = true [[tool.towncrier.type]] directory = "misc" - name = "Miscellaneous / trivial changes" + name = "Miscellaneous" showcontent = true diff --git a/readthedocs.yml b/readthedocs.yml new file mode 100644 index 000000000..ceba07a66 --- /dev/null +++ b/readthedocs.yml @@ -0,0 +1,7 @@ +build: + image: latest +python: + version: 3.6 + pip_install: true + extra_requirements: + - docs diff --git a/setup.py b/setup.py index 9a30a85ac..eb81e8dec 100644 --- a/setup.py +++ b/setup.py @@ -59,7 +59,7 @@ def main(): "pytest-timeout", "pytest-xdist", ], - "docs": ["sphinx >= 1.6.3, < 2", "towncrier >= 17.8.0"], + "docs": ["sphinx >= 1.7.5, < 2", "towncrier >= 18.5.0"], "publish": ["devpi", "twine"], }, classifiers=[ diff --git a/tox.ini b/tox.ini index 362bb511b..5ec621180 100644 --- a/tox.ini +++ b/tox.ini @@ -26,6 +26,7 @@ basepython = python3.6 extras = docs changedir = {toxinidir} commands = sphinx-build -d "{toxworkdir}/docs_doctree" doc "{toxworkdir}/docs_out" --color -W -bhtml {posargs} + python -c 'print("documentation available under file://{toxworkdir}/docs_out/index.html")' [testenv:fix-lint] description = format the code base to adhere to our styles, and complain about what we cannot do automatically