From 907e87a212f6238c32a101bf60468d3df6a814e4 Mon Sep 17 00:00:00 2001 From: Bruno Oliveira Date: Tue, 30 Jan 2024 13:05:52 -0300 Subject: [PATCH] Use ruff instead of black and reorder-python-imports (#239) Unfortunately black and reorder-python-imports are no longer compatible between each other: https://github.com/asottile/reorder-python-imports/issues/367 https://github.com/asottile/reorder-python-imports/issues/366 https://github.com/psf/black/issues/4175 Take this opportunity to try out ruff. Closes #231 --- .pre-commit-config.yaml | 14 ++++++-------- pyproject.toml | 6 ++++++ src/execnet/gateway_base.py | 5 +++-- src/execnet/gateway_io.py | 3 +-- src/execnet/rsync_remote.py | 2 +- src/execnet/script/shell.py | 2 +- testing/test_threadpool.py | 3 +-- 7 files changed, 19 insertions(+), 16 deletions(-) diff --git a/.pre-commit-config.yaml b/.pre-commit-config.yaml index 0cd053b4..cb1a9c0d 100644 --- a/.pre-commit-config.yaml +++ b/.pre-commit-config.yaml @@ -3,10 +3,6 @@ repos: rev: v2.2.6 hooks: - id: codespell -- repo: https://github.com/psf/black - rev: 23.11.0 - hooks: - - id: black - repo: https://github.com/asottile/blacken-docs rev: 1.16.0 hooks: @@ -23,11 +19,13 @@ repos: hooks: - id: pyupgrade args: [--py37-plus] -- repo: https://github.com/asottile/reorder-python-imports - rev: v3.12.0 +- repo: https://github.com/astral-sh/ruff-pre-commit + rev: v0.1.14 hooks: - - id: reorder-python-imports - args: ['--application-directories=execnet', --py37-plus] + - id: ruff + args: [ --fix ] + exclude: "^doc/" + - id: ruff-format - repo: https://github.com/PyCQA/doc8 rev: 'v1.1.1' hooks: diff --git a/pyproject.toml b/pyproject.toml index c010499f..9a276f9c 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -45,6 +45,12 @@ testing = [ [project.urls] Homepage = "https://execnet.readthedocs.io/en/latest/" +[tool.ruff.lint] +ignore = ["E741"] + +[tool.ruff.lint.isort] +case-sensitive = true + [tool.hatch.version] source = "vcs" diff --git a/src/execnet/gateway_base.py b/src/execnet/gateway_base.py index 83c23e90..74eacd33 100644 --- a/src/execnet/gateway_base.py +++ b/src/execnet/gateway_base.py @@ -596,7 +596,7 @@ class GatewayReceivedTerminate(Exception): def geterrortext(excinfo, format_exception=traceback.format_exception, sysex=sysex): try: - l = format_exception(*excinfo) + l = format_exception(*excinfo) # noqa:E741 errortext = "".join(l) except sysex: raise @@ -633,6 +633,7 @@ class TimeoutError(IOError): class Channel: "Communication channel between two Python Interpreter execution points." + RemoteError = RemoteError TimeoutError = TimeoutError _INTERNALWAKEUP = 1000 @@ -1543,7 +1544,7 @@ def _save_integral(self, i, short_op, long_op): def save_int(self, i): self._save_integral(i, opcode.INT, opcode.LONGINT) - def save_long(self, l): + def save_long(self, l): # noqa:E741 self._save_integral(l, opcode.LONG, opcode.LONGLONG) def save_float(self, flt): diff --git a/src/execnet/gateway_io.py b/src/execnet/gateway_io.py index c631f8d9..730af868 100644 --- a/src/execnet/gateway_io.py +++ b/src/execnet/gateway_io.py @@ -3,7 +3,6 @@ creates io instances used for gateway io """ -import os import shlex import sys @@ -228,4 +227,4 @@ def control(data): if __name__ == "__channelexec__": - serve_proxy_io(channel) # type: ignore[name-defined] + serve_proxy_io(channel) # type: ignore[name-defined] # noqa:F821 diff --git a/src/execnet/rsync_remote.py b/src/execnet/rsync_remote.py index 4ac1880f..3a8e71e9 100644 --- a/src/execnet/rsync_remote.py +++ b/src/execnet/rsync_remote.py @@ -114,4 +114,4 @@ def receive_directory_structure(path, relcomponents): if __name__ == "__channelexec__": - serve_rsync(channel) # type: ignore[name-defined] + serve_rsync(channel) # type: ignore[name-defined] # noqa:F821 diff --git a/src/execnet/script/shell.py b/src/execnet/script/shell.py index f47cd4d3..a80b80ea 100644 --- a/src/execnet/script/shell.py +++ b/src/execnet/script/shell.py @@ -26,7 +26,7 @@ def clientside(): while 1: r, w, e = select.select(inputlist, [], []) if sys.stdin in r: - line = raw_input() + line = raw_input() # noqa:F821 sock.sendall(line + "\n") if sock in r: line = sock.recv(4096) diff --git a/testing/test_threadpool.py b/testing/test_threadpool.py index 47a226d0..4d1edd8c 100644 --- a/testing/test_threadpool.py +++ b/testing/test_threadpool.py @@ -1,5 +1,4 @@ import os -import sys import pytest from execnet.gateway_base import WorkerPool @@ -61,7 +60,7 @@ def first(): def test_waitfinish_on_reply(pool): - l = [] + l = [] # noqa:E741 reply = pool.spawn(lambda: l.append(1)) reply.waitfinish() assert l == [1]