From 5bef558f639375b90e0b293338aa0d27430b5e15 Mon Sep 17 00:00:00 2001 From: Chethan UK Date: Fri, 3 Jun 2022 00:33:54 +0100 Subject: [PATCH] Migrate JDBC example DAGs to new design #22450 --- airflow/providers/jdbc/example_dags/__init__.py | 16 ---------------- docs/apache-airflow-providers-jdbc/index.rst | 2 +- .../apache-airflow-providers-jdbc/operators.rst | 4 ++-- .../providers/jdbc}/example_jdbc_queries.py | 17 ++++++++++++++++- 4 files changed, 19 insertions(+), 20 deletions(-) delete mode 100644 airflow/providers/jdbc/example_dags/__init__.py rename {airflow/providers/jdbc/example_dags => tests/system/providers/jdbc}/example_jdbc_queries.py (79%) diff --git a/airflow/providers/jdbc/example_dags/__init__.py b/airflow/providers/jdbc/example_dags/__init__.py deleted file mode 100644 index 13a83393a9124..0000000000000 --- a/airflow/providers/jdbc/example_dags/__init__.py +++ /dev/null @@ -1,16 +0,0 @@ -# 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. diff --git a/docs/apache-airflow-providers-jdbc/index.rst b/docs/apache-airflow-providers-jdbc/index.rst index c46fc1e43a880..2fd17d9d5e1ee 100644 --- a/docs/apache-airflow-providers-jdbc/index.rst +++ b/docs/apache-airflow-providers-jdbc/index.rst @@ -39,7 +39,7 @@ Content :maxdepth: 1 :caption: Resources - Example DAGs + Example DAGs PyPI Repository Installing from sources diff --git a/docs/apache-airflow-providers-jdbc/operators.rst b/docs/apache-airflow-providers-jdbc/operators.rst index f725a3996d979..3045f8cb35669 100644 --- a/docs/apache-airflow-providers-jdbc/operators.rst +++ b/docs/apache-airflow-providers-jdbc/operators.rst @@ -69,7 +69,7 @@ commands against a database (or data storage) accessible via a JDBC driver. The :doc:`JDBC Connection ` must be passed as ``jdbc_conn_id``. -.. exampleinclude:: /../../airflow/providers/jdbc/example_dags/example_jdbc_queries.py +.. exampleinclude:: /../../tests/system/providers/jdbc/example_jdbc_queries.py :language: python :start-after: [START howto_operator_jdbc] :end-before: [END howto_operator_jdbc] @@ -87,7 +87,7 @@ Templating You can use :ref:`Jinja templates ` to parameterize ``sql``. -.. exampleinclude:: /../../airflow/providers/jdbc/example_dags/example_jdbc_queries.py +.. exampleinclude:: /../../tests/system/providers/jdbc/example_jdbc_queries.py :language: python :start-after: [START howto_operator_jdbc_template] :end-before: [END howto_operator_jdbc_template] diff --git a/airflow/providers/jdbc/example_dags/example_jdbc_queries.py b/tests/system/providers/jdbc/example_jdbc_queries.py similarity index 79% rename from airflow/providers/jdbc/example_dags/example_jdbc_queries.py rename to tests/system/providers/jdbc/example_jdbc_queries.py index 5be0598c4c503..2bb5e088dbbbb 100644 --- a/airflow/providers/jdbc/example_dags/example_jdbc_queries.py +++ b/tests/system/providers/jdbc/example_jdbc_queries.py @@ -18,6 +18,7 @@ """Example DAG demonstrating the usage of the JdbcOperator.""" +import os from datetime import datetime, timedelta from airflow import DAG @@ -28,8 +29,11 @@ from airflow.operators.dummy import DummyOperator as EmptyOperator # type: ignore from airflow.providers.jdbc.operators.jdbc import JdbcOperator +ENV_ID = os.environ.get("SYSTEM_TESTS_ENV_ID") +DAG_ID = "example_jdbc_operator" + with DAG( - dag_id='example_jdbc_operator', + dag_id=DAG_ID, schedule_interval='0 0 * * *', start_date=datetime(2021, 1, 1), dagrun_timeout=timedelta(minutes=60), @@ -58,3 +62,14 @@ # [END howto_operator_jdbc] delete_data >> insert_data >> run_this_last + + from tests.system.utils.watcher import watcher + + # This test needs watcher in order to properly mark success/failure + # when "tearDown" task with trigger rule is part of the DAG + list(dag.tasks) >> watcher() + +from tests.system.utils import get_test_run # noqa: E402 + +# Needed to run the example DAG with pytest (see: tests/system/README.md#run_via_pytest) +test_run = get_test_run(dag)