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

Add airflow config lint cli command for lint the configuration changes from Airflow 2.x to Airflow 3.0 #44908

Merged
merged 6 commits into from
Dec 19, 2024

Conversation

sunank200
Copy link
Collaborator

@sunank200 sunank200 commented Dec 13, 2024

This PR introduces the airflow config lint command as part of the Airflow CLI config commands for migration tooling for Airflow 3.0. The purpose of this command is to help users transition from Airflow 2.x to 3.0 by identifying and providing actionable feedback on removed and renamed configuration parameters.

Implementation details:

  • Identify parameters that are no longer valid in Airflow 3.0 based on 44555
  • Highlights renamed parameters and provides guidance for transitioning to their new names and sections in the lint error.
  • Provider users options to specify sections, options, and ignore lists for granular control.

CLI Usage Examples:

  1. Lint all sections and options:

    airflow config lint
    
  2. Lint a specific sections:

    airflow config lint --section core,webserver
    
  3. Lint a specific sections and options:

    airflow config lint --section smtp --option smtp_user
    
  4. Ignore a specific sections during linting:

    airflow config lint --ignore-section webserver,api
    
  5. Ignore a specific options during linting:

    airflow config lint --ignore-option smtp_user,session_lifetime_days
    
  6. Enable verbose output for detailed feedback:

    airflow config lint --verbose
    

Following is the screenshot of the command used:
Screenshot 2024-12-17 at 2 56 15 AM

closes: #44555
related: #41641


^ Add meaningful description above
Read the Pull Request Guidelines for more information.
In case of fundamental code changes, an Airflow Improvement Proposal (AIP) is needed.
In case of a new dependency, check compliance with the ASF 3rd Party License Policy.
In case of backwards incompatible changes please leave a note in a newsfragment file, named {pr_number}.significant.rst or {issue_number}.significant.rst, in newsfragments.

@potiuk
Copy link
Member

potiuk commented Dec 13, 2024

NAAAAJS

Copy link
Contributor

@amoghrajesh amoghrajesh left a comment

Choose a reason for hiding this comment

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

Awesome, looks really nice!
@sunank200 one comment but thats just a thought. Will it also be possible to add a short README or so in order for someone to deprecate any future options? (Although i think all are done)

Copy link
Member

@gopidesupavan gopidesupavan left a comment

Choose a reason for hiding this comment

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

Awesome :)

@sunank200
Copy link
Collaborator Author

Awesome, looks really nice! @sunank200 one comment but thats just a thought. Will it also be possible to add a short README or so in order for someone to deprecate any future options? (Although i think all are done)

Readme for in how to deprecate options in future? @amoghrajesh can you elaborate on this, please

@amoghrajesh
Copy link
Contributor

Awesome, looks really nice! @sunank200 one comment but thats just a thought. Will it also be possible to add a short README or so in order for someone to deprecate any future options? (Although i think all are done)

Readme for in how to deprecate options in future? @amoghrajesh can you elaborate on this, please

Yeah, that is what I was hinting at. But looking at the state of this PR, it is a good example for how to do it later in future. So I wouldnt ask for that anymore

@uranusjr
Copy link
Member

re: The README topic, I feel at least we should introduce a news fragment on this.

We should probably add a page in documentation that guides people through the migrations. This would be useful for us in blogposts and discussions on Airflow 2-to-3 upgrade path. (This should be a separate PR.)

airflow/cli/cli_config.py Outdated Show resolved Hide resolved
airflow/cli/cli_config.py Outdated Show resolved Hide resolved
@uranusjr uranusjr added the backport-to-v2-10-test Mark PR with this label to backport to v2-10-test branch label Dec 16, 2024
@sunank200 sunank200 requested a review from Lee-W December 17, 2024 06:42
@sunank200 sunank200 force-pushed the airflow-config-lint branch 2 times, most recently from d53876a to 069b1b7 Compare December 17, 2024 06:46
Copy link
Member

@Lee-W Lee-W left a comment

Choose a reason for hiding this comment

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

Overall, looks good. Left 2 nits. I'm planning on merging it later tonight unless anyone wants to take a deeper look

@sunank200 sunank200 requested a review from kaxil December 17, 2024 14:38
@sunank200 sunank200 force-pushed the airflow-config-lint branch 2 times, most recently from c5f8519 to 6218af9 Compare December 17, 2024 15:07
@Lee-W
Copy link
Member

Lee-W commented Dec 18, 2024

@sunank200 One discussion has not yet been resolved. Could you please check whether that has been addressed? If so, I'll merge it. Thanks!

@Lee-W Lee-W merged commit bc813c6 into apache:main Dec 19, 2024
49 checks passed
@Lee-W Lee-W deleted the airflow-config-lint branch December 19, 2024 08:32
Copy link

Backport failed to create: v2-10-test. View the failure log Run details

Status Branch Result
v2-10-test Commit Link

You can attempt to backport this manually by running:

cherry_picker bc813c6 v2-10-test

This should apply the commit to the v2-10-test branch and leave the commit in conflict state marking
the files that need manual conflict resolution.

After you have resolved the conflicts, you can continue the backport process by running:

cherry_picker --continue

LefterisXefteris pushed a commit to LefterisXefteris/airflow that referenced this pull request Jan 5, 2025
…anges from Airflow 2.x to Airflow 3.0 (apache#44908)

* Add ``airflow config lint`` cli command for linting the configuration changes from Airflow 2.x to Airflow 3.0

* Fix doc-string for ConfigChange init

* Add option for multiple sections and options

Add newsfragments

* Refactor RenamedTo to ConfigParameter

rename newfragment as feature

* Add more tests with mocked env variables

* Remove duplicate config changes
agupta01 pushed a commit to agupta01/airflow that referenced this pull request Jan 6, 2025
…anges from Airflow 2.x to Airflow 3.0 (apache#44908)

* Add ``airflow config lint`` cli command for linting the configuration changes from Airflow 2.x to Airflow 3.0

* Fix doc-string for ConfigChange init

* Add option for multiple sections and options

Add newsfragments

* Refactor RenamedTo to ConfigParameter

rename newfragment as feature

* Add more tests with mocked env variables

* Remove duplicate config changes
Lee-W added a commit to astronomer/airflow that referenced this pull request Jan 17, 2025
Lee-W added a commit to astronomer/airflow that referenced this pull request Jan 17, 2025
Lee-W added a commit to astronomer/airflow that referenced this pull request Jan 17, 2025
Lee-W added a commit to astronomer/airflow that referenced this pull request Jan 17, 2025
Lee-W added a commit to astronomer/airflow that referenced this pull request Jan 24, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
area:CLI backport-to-v2-10-test Mark PR with this label to backport to v2-10-test branch
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Airflow 2 to 3 auto migration rules - airflow config (~44080)
8 participants