Skip to content
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

dev(ruff): added flake8-comprehensions and flake8-annotations to ruff #12399

Conversation

sagar-salvi-apptware
Copy link
Contributor

Checklist

  • The PR conforms to DataHub's Contributing Guideline (particularly Commit Message Format)
  • Links to related issues (if applicable)
  • Tests for the changes have been added/updated (if applicable)
  • Docs related to the changes have been added/updated (if applicable). If a new feature has been added a Usage Guide has been added for the same.
  • For any breaking change/potential downtime/deprecation/big changes an entry has been made in Updating DataHub

@sagar-salvi-apptware sagar-salvi-apptware changed the title fix(ingest/ruff): added flake8-comprehensions and flake8-annotations to ruff dev(ruff): added flake8-comprehensions and flake8-annotations to ruff Jan 20, 2025
@github-actions github-actions bot added the ingestion PR or Issue related to the ingestion of metadata label Jan 20, 2025
Copy link

codecov bot commented Jan 20, 2025

Copy link
Collaborator

@hsheth2 hsheth2 left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The large list of ignored rules does not seem right to me

"C401", # Unnecessary generator
"C403", # Unnecessary list comprehension
"C408", # Unnecessary `list()` call
"C416", # Unnecessary Comprehension
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

What's the reasoning behind adding C4 if we're going to ignore a large fraction of the rules?

Also, many of the rules are auto-fixable. If these are genuinely rules that we want, we should just fix all the existing code

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Hi @hsheth2 ,

The main reason for adding this is to improve the readability and quality of list, set, and dict comprehensions.

Out of the 19 C4 rules:

  • 10 are supported and have been implemented.
  • 4 can be addressed either now or later.
  • 5 are not needed at the moment.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The PR has been updated to address support for C401 and C403.
Changes for C408 and C416 require more extensive modifications and we can handled at a later stage.

Thanks.

@sagar-salvi-apptware sagar-salvi-apptware force-pushed the fix/ING-791-added-flake8-compr-annotations branch from 2f4f2cb to f265f36 Compare January 21, 2025 06:36
@@ -38,10 +40,18 @@ extend-ignore = [
"E203", # Ignore whitespace before ':' (matches Black)
"B019", # Allow usages of functools.lru_cache
"B008", # Allow function call in argument defaults
"COM812", # Avoid conflicts with formatter
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

why did we need to add this here?

"C410", # Ignore Unnecessary list literal passed to `list()`
"C414", # Ignore Unnecessary `reversed()` call within `sorted()`
"C417", # Ignore Unnecessary `map()` usage (rewrite using a list comprehension)
"C419", # Ignore Unnecessary list comprehension
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

seems like all of these should also be in the "enable later" section

we should also explain why each "enable later" rule was not enabled now

@@ -113,9 +113,9 @@ def check_path_specs_and_infer_platform(
raise ValueError("path_specs must not be empty")

# Check that all path specs have the same platform.
guessed_platforms = set(
guessed_platforms = {
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

imo explicitly saying set here is way more clear - I actually dislike this change

in general - I don't like any of the changes that replace set() calls with { x, y } set literal syntax

@hsheth2
Copy link
Collaborator

hsheth2 commented Jan 21, 2025

Was thinking about this a bit more - I don't think we want these rule sets yet.

@hsheth2 hsheth2 closed this Jan 21, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
ingestion PR or Issue related to the ingestion of metadata
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants