Awesome work Kaxil and everyone else who have helped in getting this one out on time.
The number of commits impresses me! Thanks & Regards, Amogh Desai On Thu, Apr 17, 2025 at 2:12 AM Kaxil Naik <kaxiln...@gmail.com> wrote: > 3.9 is also available now > > apache/airflow:3.0.0rc3-python3.9 > apache/airflow:slim-3.0.0rc3-python3.9 > > On Thu, 17 Apr 2025 at 01:05, Kaxil Naik <kaxiln...@gmail.com> wrote: > > > Docker images are now available: > > > > apache/airflow:slim-3.0.0rc3-python3.10 > > apache/airflow:slim-3.0.0rc3-python3.11 > > apache/airflow:slim-3.0.0rc3-python3.12 > > apache/airflow:3.0.0rc3-python3.10 > > apache/airflow:3.0.0rc3-python3.11 > > apache/airflow:3.0.0rc3-python3.12 > > > > 3.9 images will be available in few minutes -- once > > > https://github.com/apache/airflow/actions/runs/14499577949/job/40676786095 > > succeeds. > > > > > > > > On Wed, 16 Apr 2025 at 22:01, Kaxil Naik <kaxiln...@gmail.com> wrote: > > > >> I have also uploaded docs here: > >> https://airflow3rc3.surge.sh/release_notes.html so it is easier to > check > >> rendered HTML than rst. > >> > >> On Wed, 16 Apr 2025 at 21:29, Kaxil Naik <kaxiln...@gmail.com> wrote: > >> > >>> As last time, docker images will be available in few hours. > >>> > >>> On Wed, 16 Apr 2025 at 21:28, Kaxil Naik <kaxiln...@gmail.com> wrote: > >>> > >>>> Yea 115 commits just to Task SDK & Airflow Core -- and overall > >>>> (providers, ci scripts) 207 commits: > >>>> https://github.com/apache/airflow/compare/3.0.0rc2...3.0.0rc3 > >>>> > >>>> On Wed, 16 Apr 2025 at 21:21, Vikram Koka > <vik...@astronomer.io.invalid> > >>>> wrote: > >>>> > >>>>> Awesome! It's wonderful to see this. > >>>>> > >>>>> Thank you Kaxil, Ash, Elad, Jarek, Rahul and everyone else who > >>>>> contributed > >>>>> to this and made this happen! > >>>>> 115 commits in the last couple of days! Wow! > >>>>> > >>>>> Vikram > >>>>> > >>>>> On Wed, Apr 16, 2025 at 8:49 AM Kaxil Naik <kaxiln...@gmail.com> > >>>>> wrote: > >>>>> > >>>>> > Hey fellow Airflowers, > >>>>> > > >>>>> > I am thrilled to announce the availability of Apache Airflow > >>>>> 3.0.0rc3 & > >>>>> > *Task > >>>>> > SDK 1.0.0rc3* for testing! > >>>>> > > >>>>> > This email is calling for a vote on the release, > >>>>> > which will last at least until 22nd April, 11 am GMT. > >>>>> > and until 3 binding +1 votes have been received. > >>>>> > > >>>>> > Consider this my +1 binding vote. > >>>>> > > >>>>> > Airflow 3.0.0rc3 is available at: > >>>>> > https://dist.apache.org/repos/dist/dev/airflow/3.0.0rc3/ > >>>>> > > >>>>> > "apache-airflow" Meta package: > >>>>> > > >>>>> > > >>>>> > - *apache-airflow-3.0.0-source.tar.gz* is a source release that > >>>>> comes > >>>>> > with INSTALL instructions. > >>>>> > - *apache-airflow-3.0.0.tar.gz* is the binary Python "sdist" > >>>>> release. > >>>>> > - *apache_airflow-3.0.0-py3-none-any.whl* is the binary Python > >>>>> > wheel "binary" release. > >>>>> > > >>>>> > "apache-airflow-core" package > >>>>> > > >>>>> > > >>>>> > - *apache_airflow_core-3.0.0.tar.gz* is the binary Python > "sdist" > >>>>> > release. > >>>>> > - *apache_airflow_3.0.0-py3-none-any.whl* is the binary Python > >>>>> > wheel "binary" release. > >>>>> > > >>>>> > Task SDK 1.0.0rc3 is available at: > >>>>> > https://dist.apache.org/repos/dist/dev/airflow/task-sdk/1.0.0rc3/ > >>>>> > > >>>>> > "apache-airflow-task-sdk" package > >>>>> > > >>>>> > - *apache-airflow-task-sdk-1.0.0-source.tar.gz* is a source > >>>>> release > >>>>> > - *apache_airflow_task_sdk-1.0.0.tar.gz* is the binary Python > >>>>> "sdist" > >>>>> > release. > >>>>> > - *apache_airflow_task_sdk-1.0.0-py3-none-any.whl* is the binary > >>>>> Python > >>>>> > wheel "binary" release. > >>>>> > > >>>>> > > >>>>> > Public keys are available at: > >>>>> > https://dist.apache.org/repos/dist/release/airflow/KEYS > >>>>> > > >>>>> > Please vote accordingly: > >>>>> > > >>>>> > [ ] +1 approve > >>>>> > [ ] +0 no opinion > >>>>> > [ ] -1 disapprove with the reason > >>>>> > > >>>>> > Only votes from PMC members are binding, but all members of the > >>>>> community > >>>>> > are encouraged to test the release and vote with "(non-binding)". > >>>>> > > >>>>> > The test procedure for PMC members is described in: > >>>>> > > >>>>> > > >>>>> > https://github.com/apache/airflow/blob/main/dev/README_RELEASE_AIRFLOW.md\#verify-the-release-candidate-by-pmc-members > >>>>> > > >>>>> > The test procedure for contributors and members of the community > who > >>>>> would > >>>>> > like to test this RC is described in: > >>>>> > > >>>>> > > >>>>> > https://github.com/apache/airflow/blob/main/dev/README_RELEASE_AIRFLOW.md\#verify-the-release-candidate-by-contributors > >>>>> > > >>>>> > Please note that the version number excludes the 'rcX' string, so > >>>>> it's now > >>>>> > simply 3.0.0 for Airflow package and 1.0.0 for Task SDK. This will > >>>>> allow us > >>>>> > to rename the artifact without modifying > >>>>> > the artifact checksums when we actually release. > >>>>> > > >>>>> > Release Notes: > >>>>> > https://github.com/apache/airflow/blob/3.0.0rc3/RELEASE_NOTES.rst > >>>>> > > >>>>> > > >>>>> > *Testing Instructions using PyPI*: > >>>>> > > >>>>> > You can build a virtualenv that installs this and other required > >>>>> packages > >>>>> > (e.g. task sdk), like this: > >>>>> > > >>>>> > ``` > >>>>> > > >>>>> > uv venv > >>>>> > > >>>>> > uv pip install -U apache-airflow --pre > >>>>> > > >>>>> > ``` > >>>>> > > >>>>> > > >>>>> > Constraints files are at > >>>>> > https://github.com/apache/airflow/tree/constraints-3.0.0rc3 > >>>>> > > >>>>> > Get Involved > >>>>> > > >>>>> > We encourage the community to test this release and report any > >>>>> issues or > >>>>> > feedback. Your contributions help us ensure a stable and reliable > >>>>> Airflow > >>>>> > 3.0.0 release. Please report issues using Github at > >>>>> > https://github.com/apache/airflow/issues and mark that this is an > >>>>> issue in > >>>>> > 3.0.0. For an updated list of all known issues in the beta can also > >>>>> be > >>>>> > found in the above link with the label “affected_version:3.0.0rc” > >>>>> > > >>>>> > A huge thank you to all the contributors who have worked on this > >>>>> milestone > >>>>> > release! and a huge thank you to folks who helped out on various > >>>>> release > >>>>> > issues: Ash, Elad, Jarek, Rahul and many others. > >>>>> > Best, > >>>>> > Kaxil > >>>>> > > >>>>> > > >>>>> > Changes to Airflow Core and Task SDK since rc2 (115 commits): > >>>>> > > >>>>> > - Add back-compat for `get_unique_task_id` (#49084) > >>>>> > - Fix `example_dag_decorator` (#49087) > >>>>> > - Update docs on how to run behind a reverse proxy (#49086) > >>>>> > - Use scheme-relative URLs for the UI so https works out of the box > >>>>> more > >>>>> > often (#49106) > >>>>> > - Cope with more "interesting" proxy configurations when accessing > >>>>> the UI > >>>>> > (#49118) > >>>>> > - Fix GetDagRunState and GetTICount response conversion (#49095) > >>>>> > - Update dag version UI (#49088) > >>>>> > - Add min-provider versions in apache-airflow pyproject.toml > (#49103) > >>>>> > - Bump vite (#49126) > >>>>> > - Improve “Fundamental Concepts” Tutorial and Screenshot > Organization > >>>>> > (#49098) > >>>>> > - Remove asset-name-ref and asset-uri-ref node after resolving them > >>>>> > (#49008) > >>>>> > - Remove cgroups extra since the dep has been removed (#49123) > >>>>> > - Fix ExternalTaskSensor task_group_id check condition (#49027) > >>>>> > - Adding type checking assert to cron.get_next (#49127) > >>>>> > - Catch BrokenPipeError gracefully while servicing subprocess > >>>>> (#49128) > >>>>> > - Remove @provide_session from Variable.set/update in models > (#49107) > >>>>> > - Fix bug in Serialization of templated fields set at Runtime > >>>>> (#49144) > >>>>> > - Rewrite data pipeline tutorial to no longer use deprecated > >>>>> > PostgresOperator (#49147) > >>>>> > - Bump trove-classifiers in /airflow-core (#49134) > >>>>> > - Move celery integration tests to celery provider. (#49178) > >>>>> > - Remove dag_version as a create_dagrun argument (#49148) > >>>>> > - Implement `Variable.delete` method in task SDK (#49141) > >>>>> > - chore: use object type hint for __eq__ method (#48900) > >>>>> > - chore: make the __enter__ method return Self instead of the class > >>>>> type > >>>>> > (#48902) > >>>>> > - Fix finding assets in serialized mapped operator (#49210) > >>>>> > - update md5 type hints to respect PEP570 (#49195) > >>>>> > - Move SQS message queue code example from core to provider docs > >>>>> (#49208) > >>>>> > - remove Literal[local] type hint as it is included in str (#49194) > >>>>> > - Collapse Cadwyn migrations (#49116) > >>>>> > - fix(AssetSchedule): fix how asset_expression is accessed (#49214) > >>>>> > - remove superfluous else block (#49199) > >>>>> > - Update taskflow.rst (#47984) > >>>>> > - fix(AssetSchedule): use asset.name if exists (#49225) > >>>>> > - Rename directory for dag processor child process logs (#49227) > >>>>> > - Improve logging of abnormal exit codes for supervised > >>>>> sub-processes. > >>>>> > (#49217) > >>>>> > - Update Object Storage tutorial to match learning path tone > (#49170) > >>>>> > - Nuke orm_deserialize_value refs in docs and docstring (#49220) > >>>>> > - batch processing for updating TI UUIDs (#49015) > >>>>> > - Bump min version of pre-installed providers to latest (#49222) > >>>>> > - feat(dag_dependency): add unresolved asset ref node (#49231) > >>>>> > - Add cross dependencies between airflow-core and task-sdk (#49221) > >>>>> > - add callout for using multiple outputs in step 2 example (#49169) > >>>>> > - Re-add section on getting Context in Taskflow API (#49240) > >>>>> > - Properly allow variable delete from models (#49234) > >>>>> > - Remove `STATE_COLORS` from Airflow Local Setting (#49228) > >>>>> > - Rename edge provider to edgeexecutor provider. (#49184) > >>>>> > - Fix deprecation warning for Variable utility imports from models > >>>>> (#49242) > >>>>> > - Bump Serialized DAG to v2 and handle conversion from v1 (#49020) > >>>>> > - Wrap dictionary iteration with list to prevent dictionary being > >>>>> changed > >>>>> > during iteration. (#49241) > >>>>> > - Cleanup AUTH_TYPE import comments in default_webserver_config.py > >>>>> (#49248) > >>>>> > - Add ref default default node (#49233) > >>>>> > - fix(serialized_dag): return original DagDependency if Asset Alias > >>>>> has not > >>>>> > yet been resolved into asset (#49204) > >>>>> > - docs: update connections how-to with 3.0 screenshots (#49264) > >>>>> > - docs: add light mode screenshots for overview, move dark mode to > >>>>> folder > >>>>> > (#49263) > >>>>> > - docs: update email-config.rst how-to with 3.0 screenshots > (#49269) > >>>>> > - docs: update setup/teardown how-to with 3.0 screenshots (#49268) > >>>>> > - docs: update and clean up "add tags to dags" how-to (#49266) > >>>>> > - simplify isinstance conditions for otel in trigger_tasks method > >>>>> (#49253) > >>>>> > - Load TI related objects when purging TIs without heartbeat > (#49246) > >>>>> > - Update stable rest API docs ref (#49279) > >>>>> > - Use ``default`` in variable.get for task SDK variables (#49278) > >>>>> > - Update airflow config lint to show breaking config changes by > >>>>> default > >>>>> > (#49223) > >>>>> > - Show pending states in historic metrics (#49267) > >>>>> > - Make sure provider's manager is not left in a clean state > (#49283) > >>>>> > - docs: update variables how-to with Airflow 3.0 screenshots > (#49265) > >>>>> > - Move function to methods on models.TaskInstance (#49257) > >>>>> > - docs: remove DAG owner links how-to since no feature parity > >>>>> (#49262) > >>>>> > - Ensure scheduler uses best available serdag for dag run (#49097) > >>>>> > - AIP-38: remove `default_ui_timezone` (#49176) > >>>>> > - Removing init_dagbag from fastapi app (#49285) > >>>>> > - Improvements to rendered API docs (#49287) > >>>>> > - Document upgrading to Airflow 3 (#49271) > >>>>> > - fix(serialized_objects): handle both inlet and outlet in v1 to v2 > >>>>> convert > >>>>> > (#49286) > >>>>> > - Make sure all openapi schemes have distinct names (#49290) > >>>>> > - Remove 1.10 to 2 upgrade docs (#49289) > >>>>> > - Update screenshots in the repo readme to Airflow 3 (#49293) > >>>>> > - Feature/aip 38 add dag warning (#49236) > >>>>> > - add sorting to Pools (#48442) > >>>>> > - fix(serialized_objects): fix how dataset/asset dag_dependency is > >>>>> > converted from v1 to v2 (#49281) > >>>>> > - Remove FAB entry from `NOTICE` (#49063) > >>>>> > - Fix failing tests after subdir path bundle URL merged (#49294) > >>>>> > - Updating docs to reflect latest state of project for AF3 (#49280) > >>>>> > - update _run_inline_trigger to make its logic clearer (#49198) > >>>>> > - Return explicit 404 errors for `/helath` and `/api/v1/*` (#49284) > >>>>> > - Update next run assets and asset expression types (#49137) > >>>>> > - Force query cache to always refetch on opening mark/clear modals > >>>>> (#49298) > >>>>> > - Change default page_size from 100 to 50 (#49243) > >>>>> > - Fix Pool table modelName (#49303) > >>>>> > - API - Fix pool ordering (#49302) > >>>>> > - Pass mapIndex to filter the relevant task instance while clearing > >>>>> mapped > >>>>> > tasks. (#49307) > >>>>> > - Add possibility to have extra project metadata in providers > >>>>> (#49306) > >>>>> > - Fix failing git bundle tests (#49313) > >>>>> > - Split out the /ui routes from the "main" spec file (#49311) > >>>>> > - use enumerate for index variable in for loop in Airflow core > >>>>> (#49252) > >>>>> > - feat (api-airflowctl): Change ExtraLinksResponse to BaseModel > >>>>> (#49250) > >>>>> > - use key in dict instead of key in dict.keys in Airflow core > >>>>> (#49255) > >>>>> > - Use contextlib.suppress(exception) instead of try-except-pass and > >>>>> add > >>>>> > SIM105 ruff rule (#49251) > >>>>> > - Fix DB migrations from 2.10.5 to 3.0.0 for SQlite (#49301) > >>>>> > - fix(serialized_dag): expand DagDependency generation and add > >>>>> fallback > >>>>> > value (#49327) > >>>>> > - remove unnecessary True if <condition> else False (#49256) > >>>>> > - Fix MySQL migration (#49315) > >>>>> > - Remove `subdir` arg from CLI commands (#49317) > >>>>> > - Clairfy that allowed_deserialization_classes is space-separated > >>>>> not just > >>>>> > newlines (#49326) > >>>>> > - Bump minimum ruff version required for upgrade utility (#49341) > >>>>> > - docs: replace webserver with api-server in quick start (#49333) > >>>>> > - Revert "use key in dict instead of key in dict.keys in Airflow > core > >>>>> > (#49255)" (#49322) > >>>>> > - refactor: remove `navbar_logo_text_color` (#49161) > >>>>> > - Improve dag bundle documentation (#49342) > >>>>> > - fix(serialized_object): fix how timetable and schedule_interval > are > >>>>> > handled during v1 to v2 conversion (#49344) > >>>>> > - Don't spend time adding `ti.try_id` only to remove it in a later > >>>>> > migration (#49346)- Make `DatasetOrTimeSchedule` compatible with > >>>>> Airflow > >>>>> > 2.10.x (#49350) > >>>>> > - Improve execution time messages for DAG or Task not found > (#49352) > >>>>> > - Include trigger event payload in asset event (#49345) > >>>>> > - Rename `edge` provider fom `edgeexecutor` to `edge3` provider > >>>>> (#49358) > >>>>> > - Autorefresh dagrun breadcrumb state when dagrun is in pending > >>>>> > state. (#49328) > >>>>> > - refactor: refine schema assignment in `useConnectionTypeMeta` > >>>>> (#49165) > >>>>> > > >>>>> > PS: We will patch some of the docs in the coming days to add more > >>>>> details > >>>>> > in the Release Notes and other Airflow core docs. > >>>>> > > >>>>> > >>>> >