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

[airflow] Move AIR302 to AIR301 and AIR303 to AIR302 #17151

Merged
merged 3 commits into from
Apr 2, 2025

Conversation

Lee-W
Copy link
Contributor

@Lee-W Lee-W commented Apr 2, 2025

Summary

Following up the discussion in #14626 (comment), we're to reorganize airflow rules. Before this discussion happens, we combine required changes and suggested changes in to one single error code.

This PR first rename the original error code to the new error code as we discussed. We will gradually extract suggested changes out of AIR301 and AIR302 to AIR311 and AIR312 in the following PRs

Test Plan

Except for file, error code rename, the test case should work as it used to be.

@Lee-W Lee-W changed the title Reorganize air rules Rename the original AIR302, AIR303 as AIR301 and AIR302 Apr 2, 2025
Copy link
Contributor

github-actions bot commented Apr 2, 2025

ruff-ecosystem results

Linter (stable)

✅ ecosystem check detected no linter changes.

Linter (preview)

ℹ️ ecosystem check detected linter changes. (+178 -178 violations, +0 -0 fixes in 1 projects; 54 projects unchanged)

apache/airflow (+178 -178 violations, +0 -0 fixes)

ruff check --no-cache --exit-zero --ignore RUF9 --no-fix --output-format concise --preview --select ALL

+ airflow-core/tests/unit/decorators/test_bash.py:518:13: AIR302 Import path `airflow.operators.bash` is moved into `standard` provider in Airflow 3.0;
- airflow-core/tests/unit/decorators/test_bash.py:518:13: AIR303 Import path `airflow.operators.bash` is moved into `standard` provider in Airflow 3.0;
+ dev/airflow_perf/dags/perf_dag_1.py:41:10: AIR302 Import path `airflow.operators.bash_operator` is moved into `standard` provider in Airflow 3.0;
- dev/airflow_perf/dags/perf_dag_1.py:41:10: AIR303 Import path `airflow.operators.bash_operator` is moved into `standard` provider in Airflow 3.0;
+ dev/airflow_perf/dags/perf_dag_1.py:48:12: AIR302 Import path `airflow.operators.bash_operator` is moved into `standard` provider in Airflow 3.0;
- dev/airflow_perf/dags/perf_dag_1.py:48:12: AIR303 Import path `airflow.operators.bash_operator` is moved into `standard` provider in Airflow 3.0;
+ dev/airflow_perf/scheduler_dag_execution_timing.py:256:13: AIR301 `airflow.utils.db.create_session` is removed in Airflow 3.0
- dev/airflow_perf/scheduler_dag_execution_timing.py:256:13: AIR302 `airflow.utils.db.create_session` is removed in Airflow 3.0
+ dev/airflow_perf/scheduler_dag_execution_timing.py:303:21: AIR301 `airflow.utils.db.create_session` is removed in Airflow 3.0
- dev/airflow_perf/scheduler_dag_execution_timing.py:303:21: AIR302 `airflow.utils.db.create_session` is removed in Airflow 3.0
+ performance/src/performance_dags/performance_dag/performance_dag.py:244:9: AIR301 [*] `schedule_interval` is removed in Airflow 3.0
- performance/src/performance_dags/performance_dag/performance_dag.py:244:9: AIR302 [*] `schedule_interval` is removed in Airflow 3.0
+ performance/src/performance_dags/performance_dag/performance_dag.py:95:13: AIR302 Import path `airflow.operators.bash` is moved into `standard` provider in Airflow 3.0;
- performance/src/performance_dags/performance_dag/performance_dag.py:95:13: AIR303 Import path `airflow.operators.bash` is moved into `standard` provider in Airflow 3.0;
+ providers/alibaba/tests/unit/alibaba/cloud/log/test_oss_task_handler.py:189:67: AIR301 `filename_template` is removed in Airflow 3.0
- providers/alibaba/tests/unit/alibaba/cloud/log/test_oss_task_handler.py:189:67: AIR302 `filename_template` is removed in Airflow 3.0
+ providers/amazon/src/airflow/providers/amazon/aws/links/base_aws.py:41:19: AIR301 `airflow.models.baseoperatorlink.BaseOperatorLink` is removed in Airflow 3.0
- providers/amazon/src/airflow/providers/amazon/aws/links/base_aws.py:41:19: AIR302 `airflow.models.baseoperatorlink.BaseOperatorLink` is removed in Airflow 3.0
+ providers/amazon/tests/system/amazon/aws/example_appflow.py:102:5: AIR301 `airflow.models.baseoperator.chain` is removed in Airflow 3.0
- providers/amazon/tests/system/amazon/aws/example_appflow.py:102:5: AIR302 `airflow.models.baseoperator.chain` is removed in Airflow 3.0
+ providers/amazon/tests/system/amazon/aws/example_appflow_run.py:182:5: AIR301 `airflow.models.baseoperator.chain` is removed in Airflow 3.0
- providers/amazon/tests/system/amazon/aws/example_appflow_run.py:182:5: AIR302 `airflow.models.baseoperator.chain` is removed in Airflow 3.0
+ providers/amazon/tests/system/amazon/aws/example_athena.py:159:5: AIR301 `airflow.models.baseoperator.chain` is removed in Airflow 3.0
- providers/amazon/tests/system/amazon/aws/example_athena.py:159:5: AIR302 `airflow.models.baseoperator.chain` is removed in Airflow 3.0
+ providers/amazon/tests/system/amazon/aws/example_azure_blob_to_s3.py:65:5: AIR301 `airflow.models.baseoperator.chain` is removed in Airflow 3.0
- providers/amazon/tests/system/amazon/aws/example_azure_blob_to_s3.py:65:5: AIR302 `airflow.models.baseoperator.chain` is removed in Airflow 3.0
+ providers/amazon/tests/system/amazon/aws/example_batch.py:258:5: AIR301 `airflow.models.baseoperator.chain` is removed in Airflow 3.0
- providers/amazon/tests/system/amazon/aws/example_batch.py:258:5: AIR302 `airflow.models.baseoperator.chain` is removed in Airflow 3.0
+ providers/amazon/tests/system/amazon/aws/example_bedrock.py:113:5: AIR301 `airflow.models.baseoperator.chain` is removed in Airflow 3.0
- providers/amazon/tests/system/amazon/aws/example_bedrock.py:113:5: AIR302 `airflow.models.baseoperator.chain` is removed in Airflow 3.0
+ providers/amazon/tests/system/amazon/aws/example_bedrock.py:114:5: AIR301 `airflow.models.baseoperator.chain` is removed in Airflow 3.0
- providers/amazon/tests/system/amazon/aws/example_bedrock.py:114:5: AIR302 `airflow.models.baseoperator.chain` is removed in Airflow 3.0
+ providers/amazon/tests/system/amazon/aws/example_bedrock.py:146:5: AIR301 `airflow.models.baseoperator.chain` is removed in Airflow 3.0
- providers/amazon/tests/system/amazon/aws/example_bedrock.py:146:5: AIR302 `airflow.models.baseoperator.chain` is removed in Airflow 3.0
... 162 additional changes omitted for rule AIR302
+ providers/amazon/tests/system/amazon/aws/example_bedrock.py:147:5: AIR301 `airflow.models.baseoperator.chain` is removed in Airflow 3.0
+ providers/amazon/tests/system/amazon/aws/example_bedrock.py:208:5: AIR301 `airflow.models.baseoperator.chain` is removed in Airflow 3.0
+ providers/amazon/tests/system/amazon/aws/example_bedrock_retrieve_and_generate.py:111:5: AIR301 `airflow.models.baseoperator.chain` is removed in Airflow 3.0
+ providers/amazon/tests/system/amazon/aws/example_bedrock_retrieve_and_generate.py:112:5: AIR301 `airflow.models.baseoperator.chain` is removed in Airflow 3.0
... 157 additional changes omitted for rule AIR301
- providers/edge/src/airflow/providers/edge/example_dags/integration_test.py:116:24: AIR303 Import path `airflow.operators.bash` is moved into `standard` provider in Airflow 3.0;
... 317 additional changes omitted for project

Changes by rule (3 rules affected)

code total + violation - violation + fix - fix
AIR302 178 5 173 0 0
AIR301 173 173 0 0 0
AIR303 5 0 5 0 0

@Lee-W Lee-W force-pushed the reorganize-AIR-rules branch from 57d393d to 3c50c41 Compare April 2, 2025 15:46
@Lee-W Lee-W marked this pull request as ready for review April 2, 2025 15:46
@Lee-W
Copy link
Contributor Author

Lee-W commented Apr 2, 2025

@dhruvmanila This is ready as well 🙌

@dhruvmanila dhruvmanila changed the title Rename the original AIR302, AIR303 as AIR301 and AIR302 [airflow] Move AIR302 to AIR301 and AIR303 to AIR302 Apr 2, 2025
@dhruvmanila dhruvmanila added rule Implementing or modifying a lint rule preview Related to preview mode features labels Apr 2, 2025
@dhruvmanila dhruvmanila merged commit 8833484 into astral-sh:main Apr 2, 2025
22 checks passed
Copy link
Member

@dhruvmanila dhruvmanila left a comment

Choose a reason for hiding this comment

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

(Oops, forgot to approve first but this looks good)

dcreager added a commit that referenced this pull request Apr 3, 2025
* origin/main: (35 commits)
  [red-knot] Callable types are disjoint from literals (#17160)
  [red-knot] Fix inference for `pow` between two literal integers (#17161)
  [red-knot] Add GitHub PR annotations when mdtests fail in CI (#17150)
  [red-knot] Fix equivalence of differently ordered unions that contain `Callable` types (#17145)
  [red-knot] Add initial set of tests for unreachable code (#17159)
  [`airflow`] Move `AIR302` to `AIR301` and `AIR303` to `AIR302` (#17151)
  ruff_db: simplify lifetimes on `DiagnosticDisplay`
  [red-knot] Detect division-by-zero in unions and intersections (#17157)
  [`airflow`] Add autofix infrastructure to `AIR302` name checks (#16965)
  [`flake8-bandit`] Mark `str` and `list[str]` literals as trusted input (`S603`) (#17136)
  [`airflow`] Add autofix for `AIR302` attribute checks (#16977)
  [`airflow`] Extend `AIR302` with additional symbols (#17085)
  [`airflow`] Move `AIR301` to `AIR002` (#16978)
  [`airflow`] Add autofix for `AIR302` method checks (#16976)
  ruff_db: switch diagnostic rendering over to `std::fmt::Display`
  [red-knot] Add 'Goto type definition' to the playground (#17055)
  red_knot_ide: update snapshots
  red_knot_python_semantic: remove comment about `TypeCheckDiagnostic`
  ruff_db: delete most of the old diagnostic code
  red_knot: use `Diagnostic` inside of red knot
  ...
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
preview Related to preview mode features rule Implementing or modifying a lint rule
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants