From 9eb30bf59ec67829bfae7ea843a17fb4fdb444bc Mon Sep 17 00:00:00 2001 From: johnthagen Date: Fri, 2 Jul 2021 12:37:35 -0400 Subject: [PATCH 1/4] Upgrade Python dependencies --- dev-requirements.in | 1 + dev-requirements.txt | 79 ++++++++++++++++++++++---------------------- pyproject.toml | 6 ++++ setup.cfg | 5 --- 4 files changed, 46 insertions(+), 45 deletions(-) delete mode 100644 setup.cfg diff --git a/dev-requirements.in b/dev-requirements.in index 8edf070896..aa10a78bc3 100644 --- a/dev-requirements.in +++ b/dev-requirements.in @@ -2,6 +2,7 @@ tox # Type Checking. mypy +types-requests # Linting. flake8 diff --git a/dev-requirements.txt b/dev-requirements.txt index 213fb2e5ca..c0b6a64311 100644 --- a/dev-requirements.txt +++ b/dev-requirements.txt @@ -1,5 +1,5 @@ # -# This file is autogenerated by pip-compile +# This file is autogenerated by pip-compile with python 3.9 # To update, run: # # pip-compile dev-requirements.in @@ -8,72 +8,69 @@ appdirs==1.4.4 # via # black # virtualenv -black==21.5b1 +black==21.6b0 # via -r dev-requirements.in -click==8.0.0 +click==8.0.1 # via # black # mkdocs - # nltk colorama==0.4.4 # via # click # tox -distlib==0.3.1 +distlib==0.3.2 # via virtualenv filelock==3.0.12 # via # tox # virtualenv -flake8-polyfill==1.0.2 - # via pep8-naming flake8==3.9.2 # via # -r dev-requirements.in # flake8-polyfill -future==0.18.2 - # via lunr -humanfriendly==9.1 +flake8-polyfill==1.0.2 + # via pep8-naming +ghp-import==2.0.1 + # via mkdocs +humanfriendly==9.2 # via -r dev-requirements.in +importlib-metadata==4.6.0 + # via mkdocs isort==5.8.0 # via -r dev-requirements.in jinja2==2.11.3 # via # -r dev-requirements.in # mkdocs -joblib==1.0.1 - # via nltk -livereload==2.6.3 - # via mkdocs -lunr[languages]==0.5.8 - # via mkdocs markdown==3.3.4 # via # mkdocs # mkdocs-material # pymdown-extensions -markupsafe==2.0.0 +markupsafe==2.0.1 # via jinja2 mccabe==0.6.1 # via flake8 -mkdocs-material-extensions==1.0.1 +mergedeep==1.3.4 + # via mkdocs +mkdocs==1.2.1 # via mkdocs-material -mkdocs-material==7.1.4 +mkdocs-material==7.1.9 # via # -r dev-requirements.in # mkdocs-material-extensions -mkdocs==1.1.2 +mkdocs-material-extensions==1.0.1 # via mkdocs-material +mypy==0.910 + # via -r dev-requirements.in mypy-extensions==0.4.3 # via # black # mypy -mypy==0.812 - # via -r dev-requirements.in -nltk==3.6.2 - # via lunr packaging==20.9 - # via tox + # via + # mkdocs + # tox pathspec==0.8.1 # via black pep8-naming==0.11.1 @@ -94,33 +91,35 @@ pyparsing==2.4.7 # via packaging pyreadline==2.1 # via humanfriendly +python-dateutil==2.8.1 + # via ghp-import pyyaml==5.4.1 - # via mkdocs -regex==2021.4.4 # via - # black - # nltk + # mkdocs + # pyyaml-env-tag +pyyaml-env-tag==0.1 + # via mkdocs +regex==2021.7.1 + # via black six==1.16.0 # via - # livereload - # lunr + # python-dateutil # tox # virtualenv toml==0.10.2 # via # black + # mypy # tox -tornado==6.1 - # via - # livereload - # mkdocs tox==3.23.1 # via -r dev-requirements.in -tqdm==4.60.0 - # via nltk -typed-ast==1.4.3 - # via mypy +types-requests==2.25.0 + # via -r dev-requirements.in typing-extensions==3.10.0.0 # via mypy -virtualenv==20.4.6 +virtualenv==20.4.7 # via tox +watchdog==2.1.3 + # via mkdocs +zipp==3.4.1 + # via importlib-metadata diff --git a/pyproject.toml b/pyproject.toml index de3bf21866..8ec3823144 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -1,3 +1,9 @@ +[tool.mypy] +ignore_missing_imports = true +warn_unused_configs = true +disallow_untyped_defs = true +no_implicit_optional = true + [tool.black] line-length = 99 target-version = ["py37", "py38", "py39"] diff --git a/setup.cfg b/setup.cfg deleted file mode 100644 index ff7ef94197..0000000000 --- a/setup.cfg +++ /dev/null @@ -1,5 +0,0 @@ -[mypy] -warn_unused_configs = True -ignore_missing_imports = True -disallow_untyped_defs = True -no_implicit_optional = True From 1d8f96fcb80e7dff4a9b42b621daef9717a3bca0 Mon Sep 17 00:00:00 2001 From: johnthagen Date: Fri, 2 Jul 2021 12:41:03 -0400 Subject: [PATCH 2/4] Explicitly pin isort to avoid upstream issue with not skipping gitignore --- dev-requirements.in | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/dev-requirements.in b/dev-requirements.in index aa10a78bc3..ebfd990603 100644 --- a/dev-requirements.in +++ b/dev-requirements.in @@ -10,7 +10,8 @@ pep8-naming # Formatting. black -isort +# Pin until this issue is fixed: https://github.com/PyCQA/isort/issues/1762 +isort==5.8.0 # Documentation. mkdocs-material From a72c2c8049d232d7d7d1a7642004ad16f21c4d5d Mon Sep 17 00:00:00 2001 From: johnthagen Date: Fri, 2 Jul 2021 12:46:10 -0400 Subject: [PATCH 3/4] Update MkDocs configuration --- docs/user_guide/mkdocs.yml | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/docs/user_guide/mkdocs.yml b/docs/user_guide/mkdocs.yml index 629c21d1bf..9372ff4f64 100644 --- a/docs/user_guide/mkdocs.yml +++ b/docs/user_guide/mkdocs.yml @@ -1,4 +1,3 @@ -site_name: The Combine strict: true theme: name: material @@ -11,6 +10,9 @@ theme: language: en # Disable pulling Google fonts from the Internet, to support offline networks. font: false +site_name: The Combine +site_url: "" +use_directory_urls: false repo_url: https://github.com/sillsdev/TheCombine repo_name: sillsdev/TheCombine copyright: © 2019-2021 SIL International From 11202a2270e87a230dd2b8e9deb025041a4f1091 Mon Sep 17 00:00:00 2001 From: johnthagen Date: Fri, 2 Jul 2021 12:57:45 -0400 Subject: [PATCH 4/4] Enable mypy strict mode --- certmgr/scripts/letsencrypt_cert.py | 2 +- certmgr/scripts/utils.py | 2 +- deploy/bin/clean_repo.py | 4 +++- .../roles/combine_maintenance/files/aws_backup.py | 6 +++--- .../roles/combine_maintenance/files/combine_app.py | 14 +++++++------- .../roles/combine_maintenance/files/maint_utils.py | 2 +- pyproject.toml | 4 +--- 7 files changed, 17 insertions(+), 17 deletions(-) diff --git a/certmgr/scripts/letsencrypt_cert.py b/certmgr/scripts/letsencrypt_cert.py index 57ae50e4fb..ce8cd4a7cb 100644 --- a/certmgr/scripts/letsencrypt_cert.py +++ b/certmgr/scripts/letsencrypt_cert.py @@ -73,7 +73,7 @@ def create(self) -> None: is_letsencrypt_cert = False if self.nginx_cert_dir.is_symlink(): link_target = os.readlink(self.nginx_cert_dir) - if link_target == self.cert_dir: + if link_target == str(self.cert_dir): is_letsencrypt_cert = True # if we do not have a certificate from letsencrypt, then we: diff --git a/certmgr/scripts/utils.py b/certmgr/scripts/utils.py index 6aaf49a8a9..065e9dd602 100644 --- a/certmgr/scripts/utils.py +++ b/certmgr/scripts/utils.py @@ -67,7 +67,7 @@ def update_link(src: Path, dest: Path) -> None: """ if dest.is_symlink(): link_target = os.readlink(dest) - if link_target != src: + if link_target != str(src): dest.unlink() dest.symlink_to(src) elif not dest.exists(): diff --git a/deploy/bin/clean_repo.py b/deploy/bin/clean_repo.py index 2641b1f786..a6b2b4ed9a 100755 --- a/deploy/bin/clean_repo.py +++ b/deploy/bin/clean_repo.py @@ -11,6 +11,8 @@ aws configure """ +from __future__ import annotations + import argparse import json import re @@ -56,7 +58,7 @@ def parse_args() -> argparse.Namespace: return parser.parse_args() -def run_aws_cmd(aws_cmd: List[str], verbose: bool = False) -> subprocess.CompletedProcess: +def run_aws_cmd(aws_cmd: List[str], verbose: bool = False) -> subprocess.CompletedProcess[str]: """Run an AWS command and print the command and results if verbose is set.""" if verbose: print(aws_cmd) diff --git a/deploy/roles/combine_maintenance/files/aws_backup.py b/deploy/roles/combine_maintenance/files/aws_backup.py index e7a16d56d8..4d41a5407d 100644 --- a/deploy/roles/combine_maintenance/files/aws_backup.py +++ b/deploy/roles/combine_maintenance/files/aws_backup.py @@ -16,17 +16,17 @@ def __init__(self, *, bucket: str, profile: str) -> None: self.profile = profile self.bucket = bucket - def push(self, src: Path, dest: str) -> subprocess.CompletedProcess: + def push(self, src: Path, dest: str) -> subprocess.CompletedProcess[str]: """Push a file to the AWS S3 bucket.""" s3_uri = f"s3://{self.bucket}/{dest}" return run_cmd(["aws", "s3", "cp", str(src), s3_uri, "--profile", self.profile]) - def pull(self, src: str, dest: Path) -> subprocess.CompletedProcess: + def pull(self, src: str, dest: Path) -> subprocess.CompletedProcess[str]: """Push a file to the AWS S3 bucket.""" s3_uri = f"s3://{self.bucket}/{src}" return run_cmd(["aws", "s3", "cp", s3_uri, str(dest), "--profile", self.profile]) - def list(self) -> subprocess.CompletedProcess: + def list(self) -> subprocess.CompletedProcess[str]: """List the objects in the S3 bucket.""" return run_cmd( ["aws", "s3", "ls", f"s3://{self.bucket}", "--recursive", "--profile", self.profile] diff --git a/deploy/roles/combine_maintenance/files/combine_app.py b/deploy/roles/combine_maintenance/files/combine_app.py index 015381191e..680419f159 100644 --- a/deploy/roles/combine_maintenance/files/combine_app.py +++ b/deploy/roles/combine_maintenance/files/combine_app.py @@ -29,7 +29,7 @@ class CombineApp: def __init__(self, compose_file_path: Path) -> None: """Initialize the CombineApp from the configuration file.""" - if compose_file_path == "": + if str(compose_file_path) == "": self.compose_opts = [] else: self.compose_opts = ["-f", str(compose_file_path)] @@ -45,7 +45,7 @@ def exec( *, exec_opts: Optional[List[str]] = None, check_results: bool = True, - ) -> subprocess.CompletedProcess: + ) -> subprocess.CompletedProcess[str]: """ Run a docker-compose 'exec' command in a Combine container. @@ -109,11 +109,11 @@ def db_cmd(self, cmd: str) -> Optional[Dict[str, Any]]: return result_dict return None - def start(self, services: List[str]) -> subprocess.CompletedProcess: + def start(self, services: List[str]) -> subprocess.CompletedProcess[str]: """Start the specified combine service(s).""" return run_cmd(["docker-compose"] + self.compose_opts + ["start"] + services) - def stop(self, services: List[str]) -> subprocess.CompletedProcess: + def stop(self, services: List[str]) -> subprocess.CompletedProcess[str]: """Stop the specified combine service(s).""" return run_cmd( ["docker-compose"] + self.compose_opts + ["stop", "--timeout", "0"] + services @@ -129,7 +129,7 @@ def get_project_id(self, project_name: str) -> Optional[str]: return None if len(results) == 1: - return results[0]["_id"] + return results[0]["_id"] # type: ignore if len(results) > 1: print(f"More than one project is named {project_name}", file=sys.stderr) sys.exit(1) @@ -141,10 +141,10 @@ def get_user_id(self, user: str) -> Optional[str]: f'db.UsersCollection.findOne({{ username: "{user}"}}, {{ username: 1 }})' ) if results is not None: - return results["_id"] + return results["_id"] # type: ignore results = self.db_cmd( f'db.UsersCollection.findOne({{ email: "{user}"}}, {{ username: 1 }})' ) if results is not None: - return results["_id"] + return results["_id"] # type: ignore return None diff --git a/deploy/roles/combine_maintenance/files/maint_utils.py b/deploy/roles/combine_maintenance/files/maint_utils.py index 870f737ba5..a71db5cd7c 100644 --- a/deploy/roles/combine_maintenance/files/maint_utils.py +++ b/deploy/roles/combine_maintenance/files/maint_utils.py @@ -7,7 +7,7 @@ from typing import List -def run_cmd(cmd: List[str], *, check_results: bool = True) -> subprocess.CompletedProcess: +def run_cmd(cmd: List[str], *, check_results: bool = True) -> subprocess.CompletedProcess[str]: """Run a command with subprocess and catch any CalledProcessErrors.""" try: return subprocess.run( diff --git a/pyproject.toml b/pyproject.toml index 8ec3823144..0ba98b25bf 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -1,8 +1,6 @@ [tool.mypy] ignore_missing_imports = true -warn_unused_configs = true -disallow_untyped_defs = true -no_implicit_optional = true +strict = true [tool.black] line-length = 99