This is an automated email from the ASF dual-hosted git repository. kaxilnaik pushed a commit to branch v3-0-test in repository https://gitbox.apache.org/repos/asf/airflow.git
commit a1ed1494491f81dd2f39cda41f8bef6b8cfc6a5a Author: Kaxil Naik <[email protected]> AuthorDate: Fri Aug 22 00:41:30 2025 +0100 Bump Airflow to 3.0.6 and Task SDK to 1.0.6 --- README.md | 12 ++++++------ airflow-core/docs/installation/supported-versions.rst | 2 +- airflow-core/docs/start.rst | 2 +- airflow-core/pyproject.toml | 4 ++-- airflow-core/src/airflow/__init__.py | 2 +- docker-stack-docs/README.md | 10 +++++----- .../extending/add-airflow-configuration/Dockerfile | 2 +- .../docker-examples/extending/add-apt-packages/Dockerfile | 2 +- .../extending/add-build-essential-extend/Dockerfile | 2 +- .../docker-examples/extending/add-providers/Dockerfile | 2 +- .../extending/add-pypi-packages-constraints/Dockerfile | 2 +- .../extending/add-pypi-packages-uv/Dockerfile | 2 +- .../docker-examples/extending/add-pypi-packages/Dockerfile | 2 +- .../extending/add-requirement-packages/Dockerfile | 2 +- .../docker-examples/extending/custom-providers/Dockerfile | 2 +- .../docker-examples/extending/embedding-dags/Dockerfile | 2 +- .../extending/writable-directory/Dockerfile | 2 +- docker-stack-docs/entrypoint.rst | 14 +++++++------- generated/PYPI_README.md | 10 +++++----- pyproject.toml | 6 +++--- scripts/ci/prek/supported_versions.py | 2 +- task-sdk/pyproject.toml | 2 +- task-sdk/src/airflow/sdk/__init__.py | 2 +- 23 files changed, 45 insertions(+), 45 deletions(-) diff --git a/README.md b/README.md index 0ba46bb06b8..8fa9ee27d1d 100644 --- a/README.md +++ b/README.md @@ -99,7 +99,7 @@ Airflow is not a streaming solution, but it is often used to process real-time d Apache Airflow is tested with: -| | Main version (dev) | Stable version (3.0.5) | +| | Main version (dev) | Stable version (3.0.6) | |------------|------------------------|------------------------| | Python | 3.9, 3.10, 3.11, 3.12 | 3.9, 3.10, 3.11, 3.12 | | Platform | AMD64/ARM64(\*) | AMD64/ARM64(\*) | @@ -177,15 +177,15 @@ them to the appropriate format and workflow that your tool requires. ```bash -pip install 'apache-airflow==3.0.5' \ - --constraint "https://raw.githubusercontent.com/apache/airflow/constraints-3.0.5/constraints-3.9.txt" +pip install 'apache-airflow==3.0.6' \ + --constraint "https://raw.githubusercontent.com/apache/airflow/constraints-3.0.6/constraints-3.9.txt" ``` 2. Installing with extras (i.e., postgres, google) ```bash -pip install 'apache-airflow[postgres,google]==3.0.5' \ - --constraint "https://raw.githubusercontent.com/apache/airflow/constraints-3.0.5/constraints-3.9.txt" +pip install 'apache-airflow[postgres,google]==3.0.6' \ + --constraint "https://raw.githubusercontent.com/apache/airflow/constraints-3.0.6/constraints-3.9.txt" ``` For information on installing provider distributions, check @@ -299,7 +299,7 @@ Apache Airflow version life cycle: | Version | Current Patch/Minor | State | First Release | Limited Maintenance | EOL/Terminated | |-----------|-----------------------|-----------|-----------------|-----------------------|------------------| -| 3 | 3.0.5 | Supported | Apr 22, 2025 | TBD | TBD | +| 3 | 3.0.6 | Supported | Apr 22, 2025 | TBD | TBD | | 2 | 2.11.0 | Supported | Dec 17, 2020 | Oct 22, 2025 | Apr 22, 2026 | | 1.10 | 1.10.15 | EOL | Aug 27, 2018 | Dec 17, 2020 | June 17, 2021 | | 1.9 | 1.9.0 | EOL | Jan 03, 2018 | Aug 27, 2018 | Aug 27, 2018 | diff --git a/airflow-core/docs/installation/supported-versions.rst b/airflow-core/docs/installation/supported-versions.rst index e06a0302b0b..8193b1d6223 100644 --- a/airflow-core/docs/installation/supported-versions.rst +++ b/airflow-core/docs/installation/supported-versions.rst @@ -29,7 +29,7 @@ Apache Airflow® version life cycle: ========= ===================== ========= =============== ===================== ================ Version Current Patch/Minor State First Release Limited Maintenance EOL/Terminated ========= ===================== ========= =============== ===================== ================ -3 3.0.5 Supported Apr 22, 2025 TBD TBD +3 3.0.6 Supported Apr 22, 2025 TBD TBD 2 2.11.0 Supported Dec 17, 2020 Oct 22, 2025 Apr 22, 2026 1.10 1.10.15 EOL Aug 27, 2018 Dec 17, 2020 June 17, 2021 1.9 1.9.0 EOL Jan 03, 2018 Aug 27, 2018 Aug 27, 2018 diff --git a/airflow-core/docs/start.rst b/airflow-core/docs/start.rst index 5d2f5ea5dd5..adef170aed1 100644 --- a/airflow-core/docs/start.rst +++ b/airflow-core/docs/start.rst @@ -66,7 +66,7 @@ This quick start guide will help you bootstrap an Airflow standalone instance on :substitutions: - AIRFLOW_VERSION=3.0.5 + AIRFLOW_VERSION=3.0.6 # Extract the version of Python you have installed. If you're currently using a Python version that is not supported by Airflow, you may want to set this manually. # See above for supported versions. diff --git a/airflow-core/pyproject.toml b/airflow-core/pyproject.toml index f7f4baa5518..69cf7bbd247 100644 --- a/airflow-core/pyproject.toml +++ b/airflow-core/pyproject.toml @@ -59,7 +59,7 @@ classifiers = [ ] # Version is defined in src/airflow/__init__.py and it is automatically synchronized by pre-commit -version = "3.0.5" +version = "3.0.6" dependencies = [ "a2wsgi>=1.10.8", @@ -139,7 +139,7 @@ dependencies = [ # Does not work with it Tracked in https://github.com/fsspec/universal_pathlib/issues/276 "universal-pathlib>=0.2.2,!=0.2.4", "uuid6>=2024.7.10", - "apache-airflow-task-sdk<1.1.0,>=1.0.5", + "apache-airflow-task-sdk<1.1.0,>=1.0.6", # pre-installed providers "apache-airflow-providers-common-compat>=1.6.0", "apache-airflow-providers-common-io>=1.5.3", diff --git a/airflow-core/src/airflow/__init__.py b/airflow-core/src/airflow/__init__.py index 43dd4984ffb..7bceb276ea4 100644 --- a/airflow-core/src/airflow/__init__.py +++ b/airflow-core/src/airflow/__init__.py @@ -25,7 +25,7 @@ # lib.) This is required by some IDEs to resolve the import paths. __path__ = __import__("pkgutil").extend_path(__path__, __name__) # type: ignore -__version__ = "3.0.5" +__version__ = "3.0.6" import os diff --git a/docker-stack-docs/README.md b/docker-stack-docs/README.md index c47b90c7cf7..92b6712e221 100644 --- a/docker-stack-docs/README.md +++ b/docker-stack-docs/README.md @@ -31,12 +31,12 @@ Every time a new version of Airflow is released, the images are prepared in the [apache/airflow DockerHub](https://hub.docker.com/r/apache/airflow) for all the supported Python versions. -You can find the following images there (Assuming Airflow version `3.0.5`): +You can find the following images there (Assuming Airflow version `3.0.6`): * `apache/airflow:latest` - the latest released Airflow image with default Python version (3.12 currently) * `apache/airflow:latest-pythonX.Y` - the latest released Airflow image with specific Python version -* `apache/airflow:3.0.5` - the versioned Airflow image with default Python version (3.12 currently) -* `apache/airflow:3.0.5-pythonX.Y` - the versioned Airflow image with specific Python version +* `apache/airflow:3.0.6` - the versioned Airflow image with default Python version (3.12 currently) +* `apache/airflow:3.0.6-pythonX.Y` - the versioned Airflow image with specific Python version Those are "reference" regular images. They contain the most common set of extras, dependencies and providers that are often used by the users and they are good to "try-things-out" when you want to just take Airflow for a spin, @@ -47,8 +47,8 @@ via [Building the image](https://airflow.apache.org/docs/docker-stack/build.html * `apache/airflow:slim-latest` - the latest released Airflow image with default Python version (3.12 currently) * `apache/airflow:slim-latest-pythonX.Y` - the latest released Airflow image with specific Python version -* `apache/airflow:slim-3.0.5` - the versioned Airflow image with default Python version (3.12 currently) -* `apache/airflow:slim-3.0.5-pythonX.Y` - the versioned Airflow image with specific Python version +* `apache/airflow:slim-3.0.6` - the versioned Airflow image with default Python version (3.12 currently) +* `apache/airflow:slim-3.0.6-pythonX.Y` - the versioned Airflow image with specific Python version The Apache Airflow image provided as convenience package is optimized for size, and it provides just a bare minimal set of the extras and dependencies installed and in most cases diff --git a/docker-stack-docs/docker-examples/extending/add-airflow-configuration/Dockerfile b/docker-stack-docs/docker-examples/extending/add-airflow-configuration/Dockerfile index 132127b895a..dd6b490833a 100644 --- a/docker-stack-docs/docker-examples/extending/add-airflow-configuration/Dockerfile +++ b/docker-stack-docs/docker-examples/extending/add-airflow-configuration/Dockerfile @@ -15,7 +15,7 @@ # This is an example Dockerfile. It is not intended for PRODUCTION use # [START Dockerfile] -FROM apache/airflow:3.0.5 +FROM apache/airflow:3.0.6 ENV AIRFLOW__CORE__LOAD_EXAMPLES=True ENV AIRFLOW__DATABASE__SQL_ALCHEMY_CONN=my_conn_string # [END Dockerfile] diff --git a/docker-stack-docs/docker-examples/extending/add-apt-packages/Dockerfile b/docker-stack-docs/docker-examples/extending/add-apt-packages/Dockerfile index 533da548c09..7904ee67577 100644 --- a/docker-stack-docs/docker-examples/extending/add-apt-packages/Dockerfile +++ b/docker-stack-docs/docker-examples/extending/add-apt-packages/Dockerfile @@ -15,7 +15,7 @@ # This is an example Dockerfile. It is not intended for PRODUCTION use # [START Dockerfile] -FROM apache/airflow:3.0.5 +FROM apache/airflow:3.0.6 USER root RUN apt-get update \ && apt-get install -y --no-install-recommends \ diff --git a/docker-stack-docs/docker-examples/extending/add-build-essential-extend/Dockerfile b/docker-stack-docs/docker-examples/extending/add-build-essential-extend/Dockerfile index 34d102983e4..dc371686738 100644 --- a/docker-stack-docs/docker-examples/extending/add-build-essential-extend/Dockerfile +++ b/docker-stack-docs/docker-examples/extending/add-build-essential-extend/Dockerfile @@ -15,7 +15,7 @@ # This is an example Dockerfile. It is not intended for PRODUCTION use # [START Dockerfile] -FROM apache/airflow:3.0.5 +FROM apache/airflow:3.0.6 USER root RUN apt-get update \ && apt-get install -y --no-install-recommends \ diff --git a/docker-stack-docs/docker-examples/extending/add-providers/Dockerfile b/docker-stack-docs/docker-examples/extending/add-providers/Dockerfile index 467cd5a0382..f7a2966d3e4 100644 --- a/docker-stack-docs/docker-examples/extending/add-providers/Dockerfile +++ b/docker-stack-docs/docker-examples/extending/add-providers/Dockerfile @@ -15,7 +15,7 @@ # This is an example Dockerfile. It is not intended for PRODUCTION use # [START Dockerfile] -FROM apache/airflow:3.0.5 +FROM apache/airflow:3.0.6 USER root RUN apt-get update \ && apt-get install -y --no-install-recommends \ diff --git a/docker-stack-docs/docker-examples/extending/add-pypi-packages-constraints/Dockerfile b/docker-stack-docs/docker-examples/extending/add-pypi-packages-constraints/Dockerfile index 405de585072..a2528b34fef 100644 --- a/docker-stack-docs/docker-examples/extending/add-pypi-packages-constraints/Dockerfile +++ b/docker-stack-docs/docker-examples/extending/add-pypi-packages-constraints/Dockerfile @@ -15,6 +15,6 @@ # This is an example Dockerfile. It is not intended for PRODUCTION use # [START Dockerfile] -FROM apache/airflow:3.0.5 +FROM apache/airflow:3.0.6 RUN pip install --no-cache-dir "apache-airflow==${AIRFLOW_VERSION}" lxml --constraint "${HOME}/constraints.txt" # [END Dockerfile] diff --git a/docker-stack-docs/docker-examples/extending/add-pypi-packages-uv/Dockerfile b/docker-stack-docs/docker-examples/extending/add-pypi-packages-uv/Dockerfile index 37e41f03517..7c0ce22fe3e 100644 --- a/docker-stack-docs/docker-examples/extending/add-pypi-packages-uv/Dockerfile +++ b/docker-stack-docs/docker-examples/extending/add-pypi-packages-uv/Dockerfile @@ -15,7 +15,7 @@ # This is an example Dockerfile. It is not intended for PRODUCTION use # [START Dockerfile] -FROM apache/airflow:3.0.5 +FROM apache/airflow:3.0.6 # The `uv` tools is Rust packaging tool that is much faster than `pip` and other installer # Support for uv as installation tool is experimental diff --git a/docker-stack-docs/docker-examples/extending/add-pypi-packages/Dockerfile b/docker-stack-docs/docker-examples/extending/add-pypi-packages/Dockerfile index d41440c40e5..0d70f5ed4e9 100644 --- a/docker-stack-docs/docker-examples/extending/add-pypi-packages/Dockerfile +++ b/docker-stack-docs/docker-examples/extending/add-pypi-packages/Dockerfile @@ -15,6 +15,6 @@ # This is an example Dockerfile. It is not intended for PRODUCTION use # [START Dockerfile] -FROM apache/airflow:3.0.5 +FROM apache/airflow:3.0.6 RUN pip install --no-cache-dir "apache-airflow==${AIRFLOW_VERSION}" lxml # [END Dockerfile] diff --git a/docker-stack-docs/docker-examples/extending/add-requirement-packages/Dockerfile b/docker-stack-docs/docker-examples/extending/add-requirement-packages/Dockerfile index 8f921418c72..37c191c8889 100644 --- a/docker-stack-docs/docker-examples/extending/add-requirement-packages/Dockerfile +++ b/docker-stack-docs/docker-examples/extending/add-requirement-packages/Dockerfile @@ -15,7 +15,7 @@ # This is an example Dockerfile. It is not intended for PRODUCTION use # [START Dockerfile] -FROM apache/airflow:3.0.5 +FROM apache/airflow:3.0.6 COPY requirements.txt / RUN pip install --no-cache-dir "apache-airflow==${AIRFLOW_VERSION}" -r /requirements.txt # [END Dockerfile] diff --git a/docker-stack-docs/docker-examples/extending/custom-providers/Dockerfile b/docker-stack-docs/docker-examples/extending/custom-providers/Dockerfile index 1f856342296..658121a46af 100644 --- a/docker-stack-docs/docker-examples/extending/custom-providers/Dockerfile +++ b/docker-stack-docs/docker-examples/extending/custom-providers/Dockerfile @@ -15,6 +15,6 @@ # This is an example Dockerfile. It is not intended for PRODUCTION use # [START Dockerfile] -FROM apache/airflow:3.0.5 +FROM apache/airflow:3.0.6 RUN pip install "apache-airflow==${AIRFLOW_VERSION}" --no-cache-dir apache-airflow-providers-docker==2.5.1 # [END Dockerfile] diff --git a/docker-stack-docs/docker-examples/extending/embedding-dags/Dockerfile b/docker-stack-docs/docker-examples/extending/embedding-dags/Dockerfile index 4b3ded597c8..e66a8edc268 100644 --- a/docker-stack-docs/docker-examples/extending/embedding-dags/Dockerfile +++ b/docker-stack-docs/docker-examples/extending/embedding-dags/Dockerfile @@ -15,7 +15,7 @@ # This is an example Dockerfile. It is not intended for PRODUCTION use # [START Dockerfile] -FROM apache/airflow:3.0.5 +FROM apache/airflow:3.0.6 COPY --chown=airflow:root test_dag.py /opt/airflow/dags diff --git a/docker-stack-docs/docker-examples/extending/writable-directory/Dockerfile b/docker-stack-docs/docker-examples/extending/writable-directory/Dockerfile index 6ac647edbcf..36237f82757 100644 --- a/docker-stack-docs/docker-examples/extending/writable-directory/Dockerfile +++ b/docker-stack-docs/docker-examples/extending/writable-directory/Dockerfile @@ -15,7 +15,7 @@ # This is an example Dockerfile. It is not intended for PRODUCTION use # [START Dockerfile] -FROM apache/airflow:3.0.5 +FROM apache/airflow:3.0.6 RUN umask 0002; \ mkdir -p ~/writeable-directory # [END Dockerfile] diff --git a/docker-stack-docs/entrypoint.rst b/docker-stack-docs/entrypoint.rst index e723bdbd65c..d4ab8a5d645 100644 --- a/docker-stack-docs/entrypoint.rst +++ b/docker-stack-docs/entrypoint.rst @@ -132,7 +132,7 @@ if you specify extra arguments. For example: .. code-block:: bash - docker run -it apache/airflow:3.0.5-python3.9 bash -c "ls -la" + docker run -it apache/airflow:3.0.6-python3.9 bash -c "ls -la" total 16 drwxr-xr-x 4 airflow root 4096 Jun 5 18:12 . drwxr-xr-x 1 root root 4096 Jun 5 18:12 .. @@ -144,7 +144,7 @@ you pass extra parameters. For example: .. code-block:: bash - > docker run -it apache/airflow:3.0.5-python3.9 python -c "print('test')" + > docker run -it apache/airflow:3.0.6-python3.9 python -c "print('test')" test If first argument equals to ``airflow`` - the rest of the arguments is treated as an Airflow command @@ -152,13 +152,13 @@ to execute. Example: .. code-block:: bash - docker run -it apache/airflow:3.0.5-python3.9 airflow webserver + docker run -it apache/airflow:3.0.6-python3.9 airflow webserver If there are any other arguments - they are simply passed to the "airflow" command .. code-block:: bash - > docker run -it apache/airflow:3.0.5-python3.9 help + > docker run -it apache/airflow:3.0.6-python3.9 help usage: airflow [-h] GROUP_OR_COMMAND ... Positional Arguments: @@ -363,7 +363,7 @@ database and creating an ``admin/admin`` Admin user with the following command: --env "_AIRFLOW_DB_MIGRATE=true" \ --env "_AIRFLOW_WWW_USER_CREATE=true" \ --env "_AIRFLOW_WWW_USER_PASSWORD=admin" \ - apache/airflow:3.0.5-python3.9 webserver + apache/airflow:3.0.6-python3.9 webserver .. code-block:: bash @@ -372,7 +372,7 @@ database and creating an ``admin/admin`` Admin user with the following command: --env "_AIRFLOW_DB_MIGRATE=true" \ --env "_AIRFLOW_WWW_USER_CREATE=true" \ --env "_AIRFLOW_WWW_USER_PASSWORD_CMD=echo admin" \ - apache/airflow:3.0.5-python3.9 webserver + apache/airflow:3.0.6-python3.9 webserver The commands above perform initialization of the SQLite database, create admin user with admin password and Admin role. They also forward local port ``8080`` to the webserver port and finally start the webserver. @@ -412,6 +412,6 @@ Example: --env "_AIRFLOW_DB_MIGRATE=true" \ --env "_AIRFLOW_WWW_USER_CREATE=true" \ --env "_AIRFLOW_WWW_USER_PASSWORD_CMD=echo admin" \ - apache/airflow:3.0.5-python3.9 webserver + apache/airflow:3.0.6-python3.9 webserver This method is only available starting from Docker image of Airflow 2.1.1 and above. diff --git a/generated/PYPI_README.md b/generated/PYPI_README.md index 889b900862c..1d5056e73b1 100644 --- a/generated/PYPI_README.md +++ b/generated/PYPI_README.md @@ -56,7 +56,7 @@ Use Airflow to author workflows as directed acyclic graphs (DAGs) of tasks. The Apache Airflow is tested with: -| | Main version (dev) | Stable version (3.0.5) | +| | Main version (dev) | Stable version (3.0.6) | |------------|------------------------|------------------------| | Python | 3.9, 3.10, 3.11, 3.12 | 3.9, 3.10, 3.11, 3.12 | | Platform | AMD64/ARM64(\*) | AMD64/ARM64(\*) | @@ -130,15 +130,15 @@ them to the appropriate format and workflow that your tool requires. ```bash -pip install 'apache-airflow==3.0.5' \ - --constraint "https://raw.githubusercontent.com/apache/airflow/constraints-3.0.5/constraints-3.9.txt" +pip install 'apache-airflow==3.0.6' \ + --constraint "https://raw.githubusercontent.com/apache/airflow/constraints-3.0.6/constraints-3.9.txt" ``` 2. Installing with extras (i.e., postgres, google) ```bash -pip install 'apache-airflow[postgres,google]==3.0.5' \ - --constraint "https://raw.githubusercontent.com/apache/airflow/constraints-3.0.5/constraints-3.9.txt" +pip install 'apache-airflow[postgres,google]==3.0.6' \ + --constraint "https://raw.githubusercontent.com/apache/airflow/constraints-3.0.6/constraints-3.9.txt" ``` For information on installing provider distributions, check diff --git a/pyproject.toml b/pyproject.toml index 009b7516851..27297a55279 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -59,11 +59,11 @@ classifiers = [ ] # Version is defined in src/airflow/__init__.py and it is automatically synchronized by pre-commit -version = "3.0.5" +version = "3.0.6" dependencies = [ - "apache-airflow-task-sdk<1.1.0,>=1.0.5", - "apache-airflow-core==3.0.5", + "apache-airflow-task-sdk<1.1.0,>=1.0.6", + "apache-airflow-core==3.0.6", ] packages = [] diff --git a/scripts/ci/prek/supported_versions.py b/scripts/ci/prek/supported_versions.py index 02f2808cf3c..3873127ca0e 100755 --- a/scripts/ci/prek/supported_versions.py +++ b/scripts/ci/prek/supported_versions.py @@ -34,7 +34,7 @@ HEADERS = ( ) SUPPORTED_VERSIONS = ( - ("3", "3.0.5", "Supported", "Apr 22, 2025", "TBD", "TBD"), + ("3", "3.0.6", "Supported", "Apr 22, 2025", "TBD", "TBD"), ("2", "2.11.0", "Supported", "Dec 17, 2020", "Oct 22, 2025", "Apr 22, 2026"), ("1.10", "1.10.15", "EOL", "Aug 27, 2018", "Dec 17, 2020", "June 17, 2021"), ("1.9", "1.9.0", "EOL", "Jan 03, 2018", "Aug 27, 2018", "Aug 27, 2018"), diff --git a/task-sdk/pyproject.toml b/task-sdk/pyproject.toml index 39ca2666d9d..0eede2dcd82 100644 --- a/task-sdk/pyproject.toml +++ b/task-sdk/pyproject.toml @@ -46,7 +46,7 @@ classifiers = [ ] dependencies = [ - "apache-airflow-core<3.1.0,>=3.0.5", + "apache-airflow-core<3.1.0,>=3.0.6", "attrs>=24.2.0, !=25.2.0", "fsspec>=2023.10.0", "httpx>=0.27.0", diff --git a/task-sdk/src/airflow/sdk/__init__.py b/task-sdk/src/airflow/sdk/__init__.py index ad818354acb..048b8beab1f 100644 --- a/task-sdk/src/airflow/sdk/__init__.py +++ b/task-sdk/src/airflow/sdk/__init__.py @@ -55,7 +55,7 @@ __all__ = [ "teardown", ] -__version__ = "1.0.5" +__version__ = "1.0.6" if TYPE_CHECKING: from airflow.sdk.bases.notifier import BaseNotifier
