diff --git a/default.nix b/default.nix index ef04011a..4ec5fa84 100644 --- a/default.nix +++ b/default.nix @@ -19,6 +19,7 @@ python3.pkgs.buildPythonApplication { mypy python3.pkgs.setuptools python3.pkgs.black + python3.pkgs.pylint ruff glibcLocales @@ -39,7 +40,7 @@ python3.pkgs.buildPythonApplication { echo -e "\x1b[32m## run ruff\x1b[0m" ruff . echo -e "\x1b[32m## run mypy\x1b[0m" - mypy --strict nixpkgs_review + mypy nixpkgs_review echo -e "\x1b[32m## run nixpkgs-review --help\x1b[0m" diff --git a/flake.lock b/flake.lock index b895a672..fcb773a7 100644 --- a/flake.lock +++ b/flake.lock @@ -2,11 +2,11 @@ "nodes": { "nixpkgs": { "locked": { - "lastModified": 1691251374, - "narHash": "sha256-NrSns//HR4/U9L5SkmCoJwRCBMOZa89ib2x5yyNR1kM=", + "lastModified": 1697379843, + "narHash": "sha256-RcnGuJgC2K/UpTy+d32piEoBXq2M+nVFzM3ah/ZdJzg=", "owner": "NixOS", "repo": "nixpkgs", - "rev": "e08e100b0c6a6651c3235d1520c53280142d9d5f", + "rev": "12bdeb01ff9e2d3917e6a44037ed7df6e6c3df9d", "type": "github" }, "original": { diff --git a/nixpkgs_review/cli/__init__.py b/nixpkgs_review/cli/__init__.py index c61b69ea..43164031 100644 --- a/nixpkgs_review/cli/__init__.py +++ b/nixpkgs_review/cli/__init__.py @@ -135,7 +135,7 @@ def read_github_token() -> str | None: if token: return token try: - with open(hub_config_path()) as f: + with open(hub_config_path(), encoding="utf-8") as f: for line in f: # Allow substring match as hub uses yaml. Example string we match: # " - oauth_token: ghp_abcdefghijklmnopqrstuvwxyzABCDEF1234\n" diff --git a/nixpkgs_review/cli/post_result.py b/nixpkgs_review/cli/post_result.py index 5e94f49b..415c927f 100644 --- a/nixpkgs_review/cli/post_result.py +++ b/nixpkgs_review/cli/post_result.py @@ -21,6 +21,6 @@ def post_result_command(args: argparse.Namespace) -> None: warn(f"Report not found in {report}. Are you in a nixpkgs-review nix-shell?") sys.exit(1) - with open(report) as f: + with open(report, encoding="utf-8") as f: report_text = f.read() github_client.comment_issue(pr, report_text) diff --git a/nixpkgs_review/cli/wip.py b/nixpkgs_review/cli/wip.py index 6377d7e5..9fba5e11 100644 --- a/nixpkgs_review/cli/wip.py +++ b/nixpkgs_review/cli/wip.py @@ -11,7 +11,7 @@ def wip_command(args: argparse.Namespace) -> Path: allow = AllowedFeatures(args.allow) with Buildenv(allow.aliases, args.extra_nixpkgs_config) as nixpkgs_config: return review_local_revision( - "rev-%s-dirty" % verify_commit_hash("HEAD"), + f"rev-{verify_commit_hash('HEAD')}-dirty", args, allow, nixpkgs_config, diff --git a/nixpkgs_review/nix.py b/nixpkgs_review/nix.py index 718d9678..1e5506c6 100644 --- a/nixpkgs_review/nix.py +++ b/nixpkgs_review/nix.py @@ -297,7 +297,7 @@ def nix_build( def write_shell_expression( filename: Path, attrs: list[str], system: str, nixpkgs_config: Path ) -> None: - with open(filename, "w+") as f: + with open(filename, "w+", encoding="utf-8") as f: f.write( f"""{{ pkgs ? import ./nixpkgs {{ system = \"{system}\"; config = import {nixpkgs_config}; }} }}: with pkgs; diff --git a/nixpkgs_review/report.py b/nixpkgs_review/report.py index 9ad9f4e0..12b77662 100644 --- a/nixpkgs_review/report.py +++ b/nixpkgs_review/report.py @@ -71,7 +71,9 @@ def write_error_logs(attrs: list[Attr], directory: Path) -> None: for path in [f"{attr.drv_path}^*", attr.path]: if not path: continue - with open(logs.ensure().joinpath(attr.name + ".log"), "w+") as f: + with open( + logs.ensure().joinpath(attr.name + ".log"), "w+", encoding="utf-8" + ) as f: nix_log = subprocess.run( [ "nix", @@ -122,10 +124,10 @@ def built_packages(self) -> list[str]: return [a.name for a in self.built] def write(self, directory: Path, pr: int | None) -> None: - with open(directory.joinpath("report.md"), "w+") as f: + with open(directory.joinpath("report.md"), "w+", encoding="utf-8") as f: f.write(self.markdown(pr)) - with open(directory.joinpath("report.json"), "w+") as f: + with open(directory.joinpath("report.json"), "w+", encoding="utf-8") as f: f.write(self.json(pr)) write_error_logs(self.attrs, directory) diff --git a/nixpkgs_review/review.py b/nixpkgs_review/review.py index 1dd34002..278b1ab9 100644 --- a/nixpkgs_review/review.py +++ b/nixpkgs_review/review.py @@ -147,7 +147,7 @@ def apply_unstaged(self, staged: bool = False) -> None: result = subprocess.run(["git", "apply"], cwd=self.worktree_dir(), input=diff) if result.returncode != 0: - warn("Failed to apply diff in %s" % self.worktree_dir()) + warn(f"Failed to apply diff in {self.worktree_dir()}") sys.exit(1) def build_commit( @@ -396,11 +396,10 @@ def list_packages( res = subprocess.run(cmd, stdout=tmp) if res.returncode != 0: raise NixpkgsReviewError( - "Failed to list packages: nix-env failed with exit code %d" - % res.returncode + f"Failed to list packages: nix-env failed with exit code {res.returncode}" ) tmp.flush() - with open(tmp.name) as f: + with open(tmp.name, encoding="utf-8") as f: return parse_packages_xml(f) diff --git a/pyproject.toml b/pyproject.toml index 082fae66..6c9d37a3 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -60,15 +60,36 @@ exclude = ''' [tool.mypy] python_version = "3.10" -warn_redundant_casts = true -disallow_untyped_calls = true -disallow_untyped_defs = true +strict = true no_implicit_optional = true +# Missing type parameters for generic type "CaptureFixture" [type-arg] +disallow_any_generics = false [[tool.mypy.overrides]] -module = "setuptools.*" +module = [ + "setuptools", + "pytest" +] ignore_missing_imports = true -[[tool.mypy.overrides]] -module = "pytest.*" -ignore_missing_imports = true +[tool.pylint.FORMAT] +output-format = "colorized" + +[tool.pylint.messages_control] +disable = [ + # Disable failure for TODO items in the codebase (code will always have TODOs). + "fixme", + + # Annoying. + "line-too-long", + + # Too many missing docstrings. + "missing-docstring", + + # Not very important, maybe fix in the future. + "invalid-name", + "too-many-instance-attributes", + "too-few-public-methods", + "too-many-arguments", + "too-many-locals", +] diff --git a/tests/conftest.py b/tests/conftest.py index 5e0fef45..8ccfee57 100644 --- a/tests/conftest.py +++ b/tests/conftest.py @@ -137,7 +137,6 @@ def nixpkgs() -> Iterator[Nixpkgs]: yield setup_git(nixpkgs_path) -# pytest.fixture is untyped -@pytest.fixture # type: ignore +@pytest.fixture def helpers() -> type[Helpers]: return Helpers diff --git a/tests/test_pr.py b/tests/test_pr.py index 692a6716..3a401659 100644 --- a/tests/test_pr.py +++ b/tests/test_pr.py @@ -2,7 +2,7 @@ import shutil import subprocess -from unittest.mock import MagicMock, mock_open, patch +from unittest.mock import MagicMock, Mock, mock_open, patch import pytest @@ -13,14 +13,14 @@ @patch("nixpkgs_review.utils.shutil.which", return_value=None) -def test_default_to_nix_if_nom_not_found(mock_shutil): +def test_default_to_nix_if_nom_not_found(mock_shutil: Mock) -> None: return_value = nix_nom_tool() assert return_value == "nix" mock_shutil.assert_called_once() @pytest.mark.skipif(not shutil.which("nom"), reason="`nom` not found in PATH") -def test_pr_local_eval(helpers: Helpers, capfd) -> None: +def test_pr_local_eval(helpers: Helpers, capfd: pytest.CaptureFixture) -> None: with helpers.nixpkgs() as nixpkgs: with open(nixpkgs.path.joinpath("pkg1.txt"), "w") as f: f.write("foo") @@ -47,7 +47,9 @@ def test_pr_local_eval(helpers: Helpers, capfd) -> None: @patch("nixpkgs_review.cli.nix_nom_tool", return_value="nix") -def test_pr_local_eval_missing_nom(mock_tool, helpers: Helpers, capfd) -> None: +def test_pr_local_eval_missing_nom( + mock_tool: Mock, helpers: Helpers, capfd: pytest.CaptureFixture +) -> None: with helpers.nixpkgs() as nixpkgs: with open(nixpkgs.path.joinpath("pkg1.txt"), "w") as f: f.write("foo") @@ -74,7 +76,9 @@ def test_pr_local_eval_missing_nom(mock_tool, helpers: Helpers, capfd) -> None: assert "$ nix build" in captured.out -def test_pr_local_eval_without_nom(helpers: Helpers, capfd) -> None: +def test_pr_local_eval_without_nom( + helpers: Helpers, capfd: pytest.CaptureFixture +) -> None: with helpers.nixpkgs() as nixpkgs: with open(nixpkgs.path.joinpath("pkg1.txt"), "w") as f: f.write("foo") diff --git a/tests/test_wip.py b/tests/test_wip.py index dae528cc..8160c0eb 100644 --- a/tests/test_wip.py +++ b/tests/test_wip.py @@ -10,7 +10,7 @@ @pytest.mark.skipif(not shutil.which("nom"), reason="`nom` not found in PATH") -def test_wip_command(helpers: Helpers, capfd) -> None: +def test_wip_command(helpers: Helpers, capfd: pytest.CaptureFixture) -> None: with helpers.nixpkgs() as nixpkgs: with open(nixpkgs.path.joinpath("pkg1.txt"), "w") as f: f.write("foo") @@ -24,7 +24,9 @@ def test_wip_command(helpers: Helpers, capfd) -> None: assert "$ nom build" in captured.out -def test_wip_command_without_nom(helpers: Helpers, capfd) -> None: +def test_wip_command_without_nom( + helpers: Helpers, capfd: pytest.CaptureFixture +) -> None: with helpers.nixpkgs() as nixpkgs: with open(nixpkgs.path.joinpath("pkg1.txt"), "w") as f: f.write("foo")