From 983b66c132959482a24d498485b36e1d0beff14e Mon Sep 17 00:00:00 2001 From: Casper da Costa-Luis Date: Sun, 3 Oct 2021 15:39:35 +0100 Subject: [PATCH 01/16] add efficient `__contains__` --- tests/tests_tqdm.py | 11 +++++++++++ tqdm/std.py | 4 ++++ 2 files changed, 15 insertions(+) diff --git a/tests/tests_tqdm.py b/tests/tests_tqdm.py index 99f570774..405f5bec5 100644 --- a/tests/tests_tqdm.py +++ b/tests/tests_tqdm.py @@ -1973,3 +1973,14 @@ def test_closed(): for i in trange(9, file=our_file, miniters=1, mininterval=0): if i == 5: our_file.close() + + +def test_contains(capsys): + """Test __contains__ doesn't iterate""" + with tqdm(_range(9)) as t: + assert 9 not in t + assert all(i in t for i in range(9)) + out, err = capsys.readouterr() + assert not out + assert ' 0%' in err + assert '100%' not in err diff --git a/tqdm/std.py b/tqdm/std.py index e81c83680..03d9ce5da 100644 --- a/tqdm/std.py +++ b/tqdm/std.py @@ -1131,6 +1131,10 @@ def __len__(self): else self.iterable.__length_hint__() if hasattr(self.iterable, "__length_hint__") else getattr(self, "total", None)) + def __contains__(self, item): + contains = getattr(self.iterable, '__contains__', None) + return contains(item) if contains is not None else item in self.__iter__() + def __enter__(self): return self From 4c7ad3a65adf5b7cbc789f8d13c8128148e7a771 Mon Sep 17 00:00:00 2001 From: Casper da Costa-Luis Date: Sun, 3 Oct 2021 15:54:40 +0100 Subject: [PATCH 02/16] add `__reversed__()` --- tests/tests_tqdm.py | 10 ++++++++++ tqdm/std.py | 11 +++++++++++ 2 files changed, 21 insertions(+) diff --git a/tests/tests_tqdm.py b/tests/tests_tqdm.py index 405f5bec5..b70146fec 100644 --- a/tests/tests_tqdm.py +++ b/tests/tests_tqdm.py @@ -1975,6 +1975,16 @@ def test_closed(): our_file.close() +def test_reversed(capsys): + """Test reversed()""" + for _ in reversed(tqdm(_range(9))): + pass + out, err = capsys.readouterr() + assert not out + assert ' 0%' in err + assert '100%' in err + + def test_contains(capsys): """Test __contains__ doesn't iterate""" with tqdm(_range(9)) as t: diff --git a/tqdm/std.py b/tqdm/std.py index 03d9ce5da..a71a65d55 100644 --- a/tqdm/std.py +++ b/tqdm/std.py @@ -1131,6 +1131,17 @@ def __len__(self): else self.iterable.__length_hint__() if hasattr(self.iterable, "__length_hint__") else getattr(self, "total", None)) + def __reversed__(self): + try: + orig = self.iterable + except AttributeError: + raise TypeError("'tqdm' object is not reversible") + else: + self.iterable = reversed(self.iterable) + return self.__iter__() + finally: + self.iterable = orig + def __contains__(self, item): contains = getattr(self.iterable, '__contains__', None) return contains(item) if contains is not None else item in self.__iter__() From eae707752c90e242061e8a34a7280a3fe7e8e91c Mon Sep 17 00:00:00 2001 From: Casper da Costa-Luis Date: Sun, 3 Oct 2021 16:01:32 +0100 Subject: [PATCH 03/16] ci: minor framework update --- .github/workflows/test.yml | 4 +--- 1 file changed, 1 insertion(+), 3 deletions(-) diff --git a/.github/workflows/test.yml b/.github/workflows/test.yml index cbd958de4..9b00d5c9f 100644 --- a/.github/workflows/test.yml +++ b/.github/workflows/test.yml @@ -10,8 +10,6 @@ jobs: runs-on: ubuntu-latest steps: - uses: actions/checkout@v2 - with: - fetch-depth: 0 - uses: actions/setup-python@v2 - name: set PYSHA run: echo "PYSHA=$(python -VV | sha256sum | cut -d' ' -f1)" >> $GITHUB_ENV @@ -22,7 +20,7 @@ jobs: - name: dependencies run: pip install -U pre-commit - uses: reviewdog/action-setup@v1 - - if: github.event_name != 'schedule' + - if: github.event_name == 'push' || github.event_name == 'pull_request' name: comment run: | if [[ $EVENT == pull_request ]]; then From 3ad2549adc8f4a6997e5ddccbaae1d2ebb268930 Mon Sep 17 00:00:00 2001 From: Casper da Costa-Luis Date: Sun, 3 Oct 2021 16:43:37 +0100 Subject: [PATCH 04/16] CLI: replace `pkg_resources` => `importlib` --- tqdm/cli.py | 23 ++++++++++++----------- 1 file changed, 12 insertions(+), 11 deletions(-) diff --git a/tqdm/cli.py b/tqdm/cli.py index b5a16142b..02653b2c6 100644 --- a/tqdm/cli.py +++ b/tqdm/cli.py @@ -245,19 +245,20 @@ def write(_): if manpath or comppath: from os import path from shutil import copyfile - - from pkg_resources import Requirement, resource_filename - - def cp(src, dst): - """copies from src path to dst""" - copyfile(src, dst) - log.info("written:" + dst) + try: + from importlib import resources + except ImportError: # py<3.9 + import importlib_resources as resources + + def cp(name, dst): + """copy resource `name` to `dst`""" + with resources.path('tqdm', name) as src: + copyfile(src, dst) + log.info("written:%s", dst) if manpath is not None: - cp(resource_filename(Requirement.parse('tqdm'), 'tqdm/tqdm.1'), - path.join(manpath, 'tqdm.1')) + cp('tqdm.1', path.join(manpath, 'tqdm.1')) if comppath is not None: - cp(resource_filename(Requirement.parse('tqdm'), 'tqdm/completion.sh'), - path.join(comppath, 'tqdm_completion.sh')) + cp('completion.sh', path.join(comppath, 'tqdm_completion.sh')) sys.exit(0) if tee: stdout_write = stdout.write From 6c930f5d84a30a3c4dc74ff0e1081af7939ae44a Mon Sep 17 00:00:00 2001 From: Casper da Costa-Luis Date: Sun, 3 Oct 2021 16:55:22 +0100 Subject: [PATCH 05/16] fix deps & tests --- setup.cfg | 1 + tests/tests_tqdm.py | 4 ++-- tqdm/cli.py | 8 ++++---- 3 files changed, 7 insertions(+), 6 deletions(-) diff --git a/setup.cfg b/setup.cfg index 8637b38d0..e3f1e2f5d 100644 --- a/setup.cfg +++ b/setup.cfg @@ -77,6 +77,7 @@ setup_requires=setuptools>=42; setuptools_scm[toml]>=3.4 python_requires=>=2.7, !=3.0.*, !=3.1.*, !=3.2.*, !=3.3.* install_requires= colorama; platform_system == 'Windows' + importlib_resources; python_version < "3.7" tests_require=tox include_package_data=True packages=find: diff --git a/tests/tests_tqdm.py b/tests/tests_tqdm.py index b70146fec..bba457aa2 100644 --- a/tests/tests_tqdm.py +++ b/tests/tests_tqdm.py @@ -1987,9 +1987,9 @@ def test_reversed(capsys): def test_contains(capsys): """Test __contains__ doesn't iterate""" - with tqdm(_range(9)) as t: + with tqdm(list(range(9))) as t: assert 9 not in t - assert all(i in t for i in range(9)) + assert all(i in t for i in _range(9)) out, err = capsys.readouterr() assert not out assert ' 0%' in err diff --git a/tqdm/cli.py b/tqdm/cli.py index 02653b2c6..6cf24d432 100644 --- a/tqdm/cli.py +++ b/tqdm/cli.py @@ -245,15 +245,15 @@ def write(_): if manpath or comppath: from os import path from shutil import copyfile - try: - from importlib import resources - except ImportError: # py<3.9 + try: # py<3.7 import importlib_resources as resources + except ImportError: + from importlib import resources def cp(name, dst): """copy resource `name` to `dst`""" with resources.path('tqdm', name) as src: - copyfile(src, dst) + copyfile(str(src), dst) log.info("written:%s", dst) if manpath is not None: cp('tqdm.1', path.join(manpath, 'tqdm.1')) From 6cb00522d255a4d363f02d90df871a1615f2e4e9 Mon Sep 17 00:00:00 2001 From: Casper da Costa-Luis Date: Fri, 18 Feb 2022 00:25:04 +0000 Subject: [PATCH 06/16] cli: warn on positional arg --- tests/tests_main.py | 1 + tqdm/cli.py | 10 ++++++---- 2 files changed, 7 insertions(+), 4 deletions(-) diff --git a/tests/tests_main.py b/tests/tests_main.py index c02c896bb..0523cc795 100644 --- a/tests/tests_main.py +++ b/tests/tests_main.py @@ -45,6 +45,7 @@ def test_pipes(): # actual test: assert norm(ls_out) == norm(out) assert b"it/s" in err + assert b"Error" not in err if sys.version_info[:2] >= (3, 8): diff --git a/tqdm/cli.py b/tqdm/cli.py index 6cf24d432..6ba08ebd6 100644 --- a/tqdm/cli.py +++ b/tqdm/cli.py @@ -185,9 +185,8 @@ def main(fp=sys.stderr, argv=None): otd[0].replace('_', '-'), otd[0], *otd[1:]) for otd in opt_types_desc if otd[0] not in UNSUPPORTED_OPTS) - d = """Usage: - tqdm [--help | options] - + help_short = "Usage:\n tqdm [--help | options]\n" + d = help_short + """ Options: -h, --help Print this help and exit. -v, --version Print version and exit. @@ -200,6 +199,9 @@ def main(fp=sys.stderr, argv=None): elif any(v in argv for v in ('-h', '--help')): sys.stdout.write(d + '\n') sys.exit(0) + elif argv and argv[0][:2] != '--': + sys.stderr.write( + "Error:Unknown argument:{0}\n{1}".format(argv[0], help_short)) argv = RE_SHLEX.split(' '.join(["tqdm"] + argv)) opts = dict(zip(argv[1::3], argv[3::3])) @@ -223,7 +225,7 @@ def main(fp=sys.stderr, argv=None): if sum((delim_per_char, update, update_to)) > 1: raise TqdmKeyError("Can only have one of --bytes --update --update_to") except Exception: - fp.write('\nError:\nUsage:\n tqdm [--help | options]\n') + fp.write("\nError:\n" + help_short) for i in sys.stdin: sys.stdout.write(i) raise From 01ae86bd09ee1757bb09f26135446cbf18050e84 Mon Sep 17 00:00:00 2001 From: Casper da Costa-Luis Date: Sun, 27 Feb 2022 21:19:41 +0000 Subject: [PATCH 07/16] pre-commit: update hooks --- .pre-commit-config.yaml | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/.pre-commit-config.yaml b/.pre-commit-config.yaml index f6597d93d..95b4a82f5 100644 --- a/.pre-commit-config.yaml +++ b/.pre-commit-config.yaml @@ -2,7 +2,7 @@ default_language_version: python: python3 repos: - repo: https://github.com/pre-commit/pre-commit-hooks - rev: v4.0.1 + rev: v4.1.0 hooks: - id: check-added-large-files - id: check-case-conflict @@ -52,7 +52,7 @@ repos: - flake8-string-format - flake8-type-annotations - repo: https://github.com/PyCQA/isort - rev: 5.9.3 + rev: 5.10.1 hooks: - id: isort - repo: https://github.com/kynan/nbstripout From 7cdbfee224f94c8bc63dceaab42637962f2f2a04 Mon Sep 17 00:00:00 2001 From: Casper da Costa-Luis Date: Sun, 27 Feb 2022 21:19:56 +0000 Subject: [PATCH 08/16] autonotebook: check for ipywidgets - closes #1218 - fixes #1082 - fixes #1217 --- tqdm/autonotebook.py | 8 ++++++-- tqdm/notebook.py | 8 ++++---- 2 files changed, 10 insertions(+), 6 deletions(-) diff --git a/tqdm/autonotebook.py b/tqdm/autonotebook.py index b032061bf..1f2258146 100644 --- a/tqdm/autonotebook.py +++ b/tqdm/autonotebook.py @@ -8,6 +8,7 @@ """ import os import sys +from warnings import warn try: get_ipython = sys.modules['IPython'].get_ipython @@ -15,11 +16,14 @@ raise ImportError("console") if 'VSCODE_PID' in os.environ: # pragma: no cover raise ImportError("vscode") + from .notebook import WARN_NOIPYW, IProgress + if IProgress is None: + from .std import TqdmWarning + warn(WARN_NOIPYW, TqdmWarning, stacklevel=2) + raise ImportError('ipywidgets') except Exception: from .std import tqdm, trange else: # pragma: no cover - from warnings import warn - from .notebook import tqdm, trange from .std import TqdmExperimentalWarning warn("Using `tqdm.autonotebook.tqdm` in notebook mode." diff --git a/tqdm/notebook.py b/tqdm/notebook.py index 1f488d25f..ea44c9d00 100644 --- a/tqdm/notebook.py +++ b/tqdm/notebook.py @@ -71,6 +71,9 @@ __author__ = {"github.com/": ["lrq3000", "casperdcl", "alexanderkuk"]} __all__ = ['tqdm_notebook', 'tnrange', 'tqdm', 'trange'] +WARN_NOIPYW = ("IProgress not found. Please update jupyter and ipywidgets." + " See https://ipywidgets.readthedocs.io/en/stable" + "/user_install.html") class TqdmHBox(HBox): @@ -112,10 +115,7 @@ def status_printer(_, total=None, desc=None, ncols=None): # Prepare IPython progress bar if IProgress is None: # #187 #451 #558 #872 - raise ImportError( - "IProgress not found. Please update jupyter and ipywidgets." - " See https://ipywidgets.readthedocs.io/en/stable" - "/user_install.html") + raise ImportError(WARN_NOIPYW) if total: pbar = IProgress(min=0, max=total) else: # No total? Show info style bar with no progress tqdm status From a14ea74a81be2bc0abe5b64e45e57cbd1d2687b1 Mon Sep 17 00:00:00 2001 From: Casper da Costa-Luis Date: Sun, 27 Feb 2022 22:06:39 +0000 Subject: [PATCH 09/16] tests: fix nbval --- Makefile | 4 ++-- tox.ini | 2 +- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/Makefile b/Makefile index f0d1c0e61..796f8b07f 100644 --- a/Makefile +++ b/Makefile @@ -62,11 +62,11 @@ testsetup: python setup.py make none testnb: - pytest tests_notebook.ipynb --nbval --current-env -W=ignore --sanitize-with=setup.cfg --cov=tqdm.notebook --cov-report=term + pytest tests_notebook.ipynb --nbval --nbval-current-env -W=ignore --nbval-sanitize-with=setup.cfg --cov=tqdm.notebook --cov-report=term testcoverage: @make coverclean - pytest tests_notebook.ipynb --cov=tqdm --cov-report= --nbval --current-env --sanitize-with=setup.cfg -W=ignore + pytest tests_notebook.ipynb --cov=tqdm --cov-report= --nbval --nbval-current-env --nbval-sanitize-with=setup.cfg -W=ignore pytest -k "not perf" --cov=tqdm --cov-report=xml --cov-report=term --cov-append --cov-fail-under=80 testperf: diff --git a/tox.ini b/tox.ini index 506336d71..89c315c0a 100644 --- a/tox.ini +++ b/tox.ini @@ -54,7 +54,7 @@ deps= py3{6,7,8,9,10}: rich tf: tensorflow!=2.5.0 commands= - py3{6,7,8,9,10}: pytest --cov=tqdm --cov-report= tests_notebook.ipynb --nbval --current-env -W=ignore --sanitize-with=setup.cfg + py3{6,7,8,9,10}: pytest --cov=tqdm --cov-report= tests_notebook.ipynb --nbval --nbval-current-env -W=ignore --nbval-sanitize-with=setup.cfg pytest --cov=tqdm --cov-report=xml --cov-report=term --cov-append -k "not perf" {[core]commands} allowlist_externals=codacy From 2190b1b76d4c496a75a5e37560c5f24edfff6a74 Mon Sep 17 00:00:00 2001 From: Casper da Costa-Luis Date: Sun, 27 Feb 2022 22:08:18 +0000 Subject: [PATCH 10/16] tests: add py3.10 --- .github/workflows/check.yml | 6 ------ .github/workflows/test.yml | 2 +- setup.cfg | 1 + 3 files changed, 2 insertions(+), 7 deletions(-) diff --git a/.github/workflows/check.yml b/.github/workflows/check.yml index 1e4432333..eddd4ba9e 100644 --- a/.github/workflows/check.yml +++ b/.github/workflows/check.yml @@ -19,8 +19,6 @@ jobs: with: fetch-depth: 0 - uses: actions/setup-python@v2 - with: - python-version: '3.x' - run: pip install -U tox - run: tox env: @@ -34,8 +32,6 @@ jobs: with: fetch-depth: 0 - uses: actions/setup-python@v2 - with: - python-version: '3.x' - name: Install run: | pip install -U wheel @@ -70,8 +66,6 @@ jobs: with: fetch-depth: 0 - uses: actions/setup-python@v2 - with: - python-version: '3.x' - name: Install run: | pip install -U wheel diff --git a/.github/workflows/test.yml b/.github/workflows/test.yml index 9b00d5c9f..68f27fa5b 100644 --- a/.github/workflows/test.yml +++ b/.github/workflows/test.yml @@ -40,7 +40,7 @@ jobs: strategy: matrix: os: [ubuntu] - python: [2.7, 3.5, 3.6, 3.7, 3.8, 3.9] + python: [2.7, 3.5, 3.6, 3.7, 3.8, 3.9, '3.10'] include: - os: macos python: 2.7 diff --git a/setup.cfg b/setup.cfg index e3f1e2f5d..e5a358e21 100644 --- a/setup.cfg +++ b/setup.cfg @@ -52,6 +52,7 @@ classifiers= Programming Language :: Python :: 3.7 Programming Language :: Python :: 3.8 Programming Language :: Python :: 3.9 + Programming Language :: Python :: 3.10 Programming Language :: Python :: Implementation Programming Language :: Python :: Implementation :: IronPython Programming Language :: Python :: Implementation :: PyPy From c1e7acebad76c0a6d17ce005d46e55f06bda1c09 Mon Sep 17 00:00:00 2001 From: Casper da Costa-Luis Date: Sun, 27 Feb 2022 22:17:01 +0000 Subject: [PATCH 11/16] tests: coverage warning - vis https://github.com/pytest-dev/pytest-cov/issues/369 --- setup.cfg | 1 + 1 file changed, 1 insertion(+) diff --git a/setup.cfg b/setup.cfg index e5a358e21..04ee0896b 100644 --- a/setup.cfg +++ b/setup.cfg @@ -141,5 +141,6 @@ omit= tqdm/contrib/telegram.py tqdm/contrib/utils_worker.py relative_files=True +disable_warnings=include-ignored [coverage:report] show_missing=True From 6426c55b0f546a51be6e60034f34fbcaa87f679b Mon Sep 17 00:00:00 2001 From: Casper da Costa-Luis Date: Sun, 27 Feb 2022 22:35:15 +0000 Subject: [PATCH 12/16] cli: fix py3.9 `importlib` usage --- tqdm/cli.py | 7 +++++-- 1 file changed, 5 insertions(+), 2 deletions(-) diff --git a/tqdm/cli.py b/tqdm/cli.py index 6ba08ebd6..693b95379 100644 --- a/tqdm/cli.py +++ b/tqdm/cli.py @@ -254,8 +254,11 @@ def write(_): def cp(name, dst): """copy resource `name` to `dst`""" - with resources.path('tqdm', name) as src: - copyfile(str(src), dst) + if hasattr(resources, 'files'): + copyfile(str(resources.files('tqdm') / name), dst) + else: # py<3.9 + with resources.path('tqdm', name) as src: + copyfile(str(src), dst) log.info("written:%s", dst) if manpath is not None: cp('tqdm.1', path.join(manpath, 'tqdm.1')) From 6ba43f2631a18f8bfe2cd1bb2071c507e88ce6d8 Mon Sep 17 00:00:00 2001 From: Casper da Costa-Luis Date: Thu, 17 Feb 2022 19:49:00 +0000 Subject: [PATCH 13/16] tests: fix pytest-asyncio usage --- setup.cfg | 2 +- tox.ini | 7 +++++-- 2 files changed, 6 insertions(+), 3 deletions(-) diff --git a/setup.cfg b/setup.cfg index 04ee0896b..e43ab21a7 100644 --- a/setup.cfg +++ b/setup.cfg @@ -124,7 +124,7 @@ markers= slow python_files=tests_*.py tests_*.ipynb testpaths=tests -addopts=-v --tb=short -rxs -W=error --durations=0 --durations-min=0.1 +addopts=-v --tb=short -rxs -W=error --durations=0 --durations-min=0.1 --asyncio-mode=strict [regex1] regex: (?<= )[\s\d.]+(it/s|s/it) replace: ??.??it/s diff --git a/tox.ini b/tox.ini index 89c315c0a..49ffb4243 100644 --- a/tox.ini +++ b/tox.ini @@ -54,8 +54,10 @@ deps= py3{6,7,8,9,10}: rich tf: tensorflow!=2.5.0 commands= - py3{6,7,8,9,10}: pytest --cov=tqdm --cov-report= tests_notebook.ipynb --nbval --nbval-current-env -W=ignore --nbval-sanitize-with=setup.cfg - pytest --cov=tqdm --cov-report=xml --cov-report=term --cov-append -k "not perf" + py36: pytest --cov=tqdm --cov-report= tests_notebook.ipynb --nbval --nbval-current-env -W=ignore --nbval-sanitize-with=setup.cfg -o addopts= -v --tb=short -rxs -W=error --durations=0 --durations-min=0.1 + py3{7,8,9,10}: pytest --cov=tqdm --cov-report= tests_notebook.ipynb --nbval --nbval-current-env -W=ignore --nbval-sanitize-with=setup.cfg + py3{0,1,2,3,4,5,6}: pytest --cov=tqdm --cov-report=xml --cov-report=term --cov-append -k "not perf" -o addopts= -v --tb=short -rxs -W=error --durations=0 --durations-min=0.1 + py3{7,8,9,10}: pytest --cov=tqdm --cov-report=xml --cov-report=term --cov-append -k "not perf" {[core]commands} allowlist_externals=codacy @@ -72,6 +74,7 @@ deps={[core]deps} deps= pytest pytest-timeout + pytest-asyncio commands=pytest -k perf [testenv:setup.py] From 2a9f1d23d3033c40ba9568285a144d711aa7d02b Mon Sep 17 00:00:00 2001 From: Casper da Costa-Luis Date: Sun, 27 Feb 2022 23:12:46 +0000 Subject: [PATCH 14/16] tests: fix pytest-nbval, tidy versions --- tox.ini | 9 +++++---- 1 file changed, 5 insertions(+), 4 deletions(-) diff --git a/tox.ini b/tox.ini index 49ffb4243..f5d43eded 100644 --- a/tox.ini +++ b/tox.ini @@ -25,12 +25,13 @@ PLATFORM= [core] deps= + py3{4,5,6}: pytest<7 pytest pytest-cov pytest-timeout py3{7,8,9,10}: pytest-asyncio py3{6,7,8,9,10}: ipywidgets - py3{6,7,8,9,10}: git+https://github.com/casperdcl/nbval.git@named_cells#egg=nbval + py3{6,7,8,9,10}: git+https://github.com/casperdcl/nbval.git@master#egg=nbval coverage coveralls codecov @@ -48,15 +49,15 @@ deps= matplotlib numpy pandas + tf: tensorflow!=2.5.0 + !py27-keras: keras py27-keras: keras<2.5 py27-tf: protobuf<3.18 - !py27-keras: keras py3{6,7,8,9,10}: rich - tf: tensorflow!=2.5.0 commands= py36: pytest --cov=tqdm --cov-report= tests_notebook.ipynb --nbval --nbval-current-env -W=ignore --nbval-sanitize-with=setup.cfg -o addopts= -v --tb=short -rxs -W=error --durations=0 --durations-min=0.1 py3{7,8,9,10}: pytest --cov=tqdm --cov-report= tests_notebook.ipynb --nbval --nbval-current-env -W=ignore --nbval-sanitize-with=setup.cfg - py3{0,1,2,3,4,5,6}: pytest --cov=tqdm --cov-report=xml --cov-report=term --cov-append -k "not perf" -o addopts= -v --tb=short -rxs -W=error --durations=0 --durations-min=0.1 + py3{4,5,6}: pytest --cov=tqdm --cov-report=xml --cov-report=term --cov-append -k "not perf" -o addopts= -v --tb=short -rxs -W=error --durations=0 --durations-min=0.1 py3{7,8,9,10}: pytest --cov=tqdm --cov-report=xml --cov-report=term --cov-append -k "not perf" {[core]commands} allowlist_externals=codacy From 02b29234f88272778b879b3da7589cbb9ce13dfd Mon Sep 17 00:00:00 2001 From: Casper da Costa-Luis Date: Mon, 28 Feb 2022 01:02:06 +0000 Subject: [PATCH 15/16] tests: drop py3.6 nbval --- tox.ini | 7 +++---- 1 file changed, 3 insertions(+), 4 deletions(-) diff --git a/tox.ini b/tox.ini index f5d43eded..5360fef15 100644 --- a/tox.ini +++ b/tox.ini @@ -25,13 +25,13 @@ PLATFORM= [core] deps= - py3{4,5,6}: pytest<7 pytest + py3{4,5,6}: pytest<7 pytest-cov pytest-timeout py3{7,8,9,10}: pytest-asyncio py3{6,7,8,9,10}: ipywidgets - py3{6,7,8,9,10}: git+https://github.com/casperdcl/nbval.git@master#egg=nbval + py3{7,8,9,10}: git+https://github.com/casperdcl/nbval.git@master#egg=nbval coverage coveralls codecov @@ -55,9 +55,8 @@ deps= py27-tf: protobuf<3.18 py3{6,7,8,9,10}: rich commands= - py36: pytest --cov=tqdm --cov-report= tests_notebook.ipynb --nbval --nbval-current-env -W=ignore --nbval-sanitize-with=setup.cfg -o addopts= -v --tb=short -rxs -W=error --durations=0 --durations-min=0.1 + py3{4,5,6}: pytest --cov=tqdm --cov-report=xml --cov-report=term -k "not perf" -o addopts= -v --tb=short -rxs -W=error --durations=0 --durations-min=0.1 py3{7,8,9,10}: pytest --cov=tqdm --cov-report= tests_notebook.ipynb --nbval --nbval-current-env -W=ignore --nbval-sanitize-with=setup.cfg - py3{4,5,6}: pytest --cov=tqdm --cov-report=xml --cov-report=term --cov-append -k "not perf" -o addopts= -v --tb=short -rxs -W=error --durations=0 --durations-min=0.1 py3{7,8,9,10}: pytest --cov=tqdm --cov-report=xml --cov-report=term --cov-append -k "not perf" {[core]commands} allowlist_externals=codacy From a6139189856349e96b5bfad30e0c296d44861fb1 Mon Sep 17 00:00:00 2001 From: Casper da Costa-Luis Date: Mon, 28 Feb 2022 01:52:05 +0000 Subject: [PATCH 16/16] tests: pin py3.5 keras --- tox.ini | 1 + 1 file changed, 1 insertion(+) diff --git a/tox.ini b/tox.ini index 5360fef15..d77a5a880 100644 --- a/tox.ini +++ b/tox.ini @@ -52,6 +52,7 @@ deps= tf: tensorflow!=2.5.0 !py27-keras: keras py27-keras: keras<2.5 + py35-keras: keras<2.7 py27-tf: protobuf<3.18 py3{6,7,8,9,10}: rich commands=