From d6e618f26b95a12ad1413d14b4755a5ff87df5db Mon Sep 17 00:00:00 2001 From: Jed Cunningham <66968678+jedcunningham@users.noreply.github.com> Date: Thu, 5 Dec 2024 14:16:06 -0700 Subject: [PATCH] Add DagFolderDagBundle to expose the DAG folder as a bundle (#44699) Why not simply use LocalDagBundle? This keeps the config for the traditional `[core] dags_folder` in the Airflow config system. --- airflow/dag_processing/bundles/dagfolder.py | 28 +++++++++++++++++++++ tests/dag_processing/test_dag_bundles.py | 8 ++++++ 2 files changed, 36 insertions(+) create mode 100644 airflow/dag_processing/bundles/dagfolder.py diff --git a/airflow/dag_processing/bundles/dagfolder.py b/airflow/dag_processing/bundles/dagfolder.py new file mode 100644 index 0000000000000..40ba649644558 --- /dev/null +++ b/airflow/dag_processing/bundles/dagfolder.py @@ -0,0 +1,28 @@ +# Licensed to the Apache Software Foundation (ASF) under one +# or more contributor license agreements. See the NOTICE file +# distributed with this work for additional information +# regarding copyright ownership. The ASF licenses this file +# to you under the Apache License, Version 2.0 (the +# "License"); you may not use this file except in compliance +# with the License. You may obtain a copy of the License at +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, +# software distributed under the License is distributed on an +# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY +# KIND, either express or implied. See the License for the +# specific language governing permissions and limitations +# under the License. + +from __future__ import annotations + +from airflow import settings +from airflow.dag_processing.bundles.local import LocalDagBundle + + +class DagsFolderDagBundle(LocalDagBundle): + """A bundle for the DAGs folder.""" + + def __init__(self, **kwargs): + super().__init__(local_folder=settings.DAGS_FOLDER, **kwargs) diff --git a/tests/dag_processing/test_dag_bundles.py b/tests/dag_processing/test_dag_bundles.py index 8ad72d1df6937..65be620fe5ec1 100644 --- a/tests/dag_processing/test_dag_bundles.py +++ b/tests/dag_processing/test_dag_bundles.py @@ -24,6 +24,7 @@ from git import Repo from airflow.dag_processing.bundles.base import BaseDagBundle +from airflow.dag_processing.bundles.dagfolder import DagsFolderDagBundle from airflow.dag_processing.bundles.git import GitDagBundle from airflow.dag_processing.bundles.local import LocalDagBundle from airflow.exceptions import AirflowException @@ -72,6 +73,13 @@ def test_none_for_version(self): assert bundle.get_current_version() is None +class TestDagsFolderDagBundle: + @conf_vars({("core", "dags_folder"): "/tmp/somewhere/dags"}) + def test_path(self): + bundle = DagsFolderDagBundle(name="test") + assert bundle.path == Path("/tmp/somewhere/dags") + + GIT_DEFAULT_BRANCH = "main"