-
Notifications
You must be signed in to change notification settings - Fork 17
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Use Ruff for linting #289
Use Ruff for linting #289
Conversation
32ecbe2
to
4150816
Compare
# XXX: can return a reference and gracefully use task to cancel itself when the upper call stack fails | ||
asyncio.ensure_future(proc.step_until_terminated()) # noqa: RUF006 |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The linter complain is the reference to the coroutine is not returned. I think the standard way is to use the task to do graceful shutdown.
I'll further investigate on it, what I think is the returned reference to the task returned to the function where it is called (ProcessLauncher
) and before this task get run it can be cancelled without other exception from the event loop.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Let me know if you think it is better to not put dev notes in the src code. @agoscinski
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Should be okay but I dont fully understand this comment What does the XXX
mean? Shouldn't ensure_future
return a Future
or Task
? What do you mean with "reference"?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
According to https://docs.python.org/3/library/asyncio-future.html#asyncio.ensure_future, the API is deprecated and using create_task
is in favor. It returns a task, and task is a future like object that can be resolved by running at event loop.
The reference means the task reference as the handler that can pass around to control this created task. At the moment, we did nothing to the task if other issues happened in the event loop. One example in my mind was when the proc.step_until_terminated()
is scheduled in the event loop but not yet run, the event loop needs to be shutdown and the handler here need to call to cancel the task in the event loop first.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
ok and the XXX?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I don’t remember where I got this habit from but there are some archaeology post to read about this https://www.snellman.net/blog/archive/2017-04-17-xxx-fixme/
I think for modern ide it is highlighted as TODO nd FIXME.
0bb21a8
to
d433143
Compare
I move the fix for passing 3.12 tests to #292 so this PR only contains the changes recommended from ruff. It is ready to be review. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks @unkcpz
* Bump version for pytest and pytest tools * Use ruff with aligning to aiida-core ruff config * Update mypy to 1.13.0 * Remove all pylint ignore annotations * Bump ruff to 0.8.0 for sort the imports * Update python version to 3.12 for pre-commit CI * Double quotes for eval inside single quotes f-strings * Exclude tests/.* for ruff linting * Do not fail-fast so tests for different python version independent
* Bump version for pytest and pytest tools * Use ruff with aligning to aiida-core ruff config * Update mypy to 1.13.0 * Remove all pylint ignore annotations * Bump ruff to 0.8.0 for sort the imports * Update python version to 3.12 for pre-commit CI * Double quotes for eval inside single quotes f-strings * Exclude tests/.* for ruff linting * Do not fail-fast so tests for different python version independent
* Bump version for pytest and pytest tools * Use ruff with aligning to aiida-core ruff config * Update mypy to 1.13.0 * Remove all pylint ignore annotations * Bump ruff to 0.8.0 for sort the imports * Update python version to 3.12 for pre-commit CI * Double quotes for eval inside single quotes f-strings * Exclude tests/.* for ruff linting * Do not fail-fast so tests for different python version independent (cherry picked from commit 55e05e9)
* Bump version for pytest and pytest tools * Use ruff with aligning to aiida-core ruff config * Update mypy to 1.13.0 * Remove all pylint ignore annotations * Bump ruff to 0.8.0 for sort the imports * Update python version to 3.12 for pre-commit CI * Double quotes for eval inside single quotes f-strings * Exclude tests/.* for ruff linting * Do not fail-fast so tests for different python version independent (cherry picked from commit 55e05e9)
* Bump version for pytest and pytest tools * Use ruff with aligning to aiida-core ruff config * Update mypy to 1.13.0 * Remove all pylint ignore annotations * Bump ruff to 0.8.0 for sort the imports * Update python version to 3.12 for pre-commit CI * Double quotes for eval inside single quotes f-strings * Exclude tests/.* for ruff linting * Do not fail-fast so tests for different python version independent (cherry picked from commit 55e05e9)
The ruff pre-commit configs are mainly get from
aiida-core
.For the linter complain in tests, I simply add
# noqa
to silent those.test
folder totests