diff --git a/airflow/models/dagbag.py b/airflow/models/dagbag.py index 9cebbb6858cda..14e4f9b616ebd 100644 --- a/airflow/models/dagbag.py +++ b/airflow/models/dagbag.py @@ -580,7 +580,7 @@ def collect_dags( file_parse_end_dttm = timezone.utcnow() stats.append( FileLoadStat( - file=filepath.replace(settings.DAGS_FOLDER, ""), + file=filepath.replace(str(dag_folder), ""), duration=file_parse_end_dttm - file_parse_start_dttm, dag_num=len(found_dags), task_num=sum(len(dag.tasks) for dag in found_dags), diff --git a/tests/models/test_dagbag.py b/tests/models/test_dagbag.py index f8cbc4d3e6632..8b71ea4244092 100644 --- a/tests/models/test_dagbag.py +++ b/tests/models/test_dagbag.py @@ -848,6 +848,13 @@ def test_dagbag_dag_collection(self): dagbag = DagBag(dag_folder=TEST_DAGS_FOLDER, include_examples=False) assert dagbag.dags + def test_dagbag_collect_dags_stats_have_filepath_without_dag_folder(self): + with conf_vars({("core", "DAGS_FOLDER"): "/different/path"}): + dagbag = DagBag(dag_folder=TEST_DAGS_FOLDER, include_examples=False) + + assert dagbag.dagbag_stats + assert str(TEST_DAGS_FOLDER) not in dagbag.dagbag_stats[0].file + def test_dabgag_captured_warnings(self): dag_file = os.path.join(TEST_DAGS_FOLDER, "test_dag_warnings.py") dagbag = DagBag(dag_folder=dag_file, include_examples=False, collect_dags=False)