Skip to content

Commit

Permalink
[AIRFLOW-6817] remove imports from airflow/__init__.py, replaced im…
Browse files Browse the repository at this point in the history
…plicit imports with explicit imports, added entry to `UPDATING.MD` - squashed/rebased (apache#7456)
  • Loading branch information
msb217 authored Feb 22, 2020
1 parent 9e63fec commit 4d03e33
Show file tree
Hide file tree
Showing 211 changed files with 391 additions and 376 deletions.
15 changes: 14 additions & 1 deletion UPDATING.md
Original file line number Diff line number Diff line change
Expand Up @@ -61,6 +61,19 @@ https://developers.google.com/style/inclusive-documentation
-->

### Removed sub-package imports from `airflow/__init__.py`

The imports `LoggingMixin`, `conf`, `AirflowException`, and `DAG` have been removed from `airflow/__init__.py`.
All implicit references of these objects will no longer be valid. To migrate, all usages of each old path must be
replaced with its corresponding new path.

| Old Path (Implicit Import) | New Path (Explicit Import) |
|------------------------------|--------------------------------------------------|
| ``airflow.LoggingMixin`` | ``airflow.utils.log.logging_mixin.LoggingMixin`` |
| ``airflow.conf`` | ``airflow.configuration.conf`` |
| ``airflow.AirflowException`` | ``airflow.exceptions.AirflowException`` |
| ``airflow.DAG`` | ``airflow.models.dag.DAG`` |

### Success Callback will be called when a task in marked as success from UI

When a task is marked as success by a used from Airflow UI - on_success_callback will be called
Expand Down Expand Up @@ -1703,7 +1716,7 @@ Type "help", "copyright", "credits" or "license" for more information.
>>> from airflow.settings import *
>>>
>>> from datetime import datetime
>>> from airflow import DAG
>>> from airflow.models.dag import DAG
>>> from airflow.operators.dummy_operator import DummyOperator
>>>
>>> dag = DAG('simple_dag', start_date=datetime(2017, 9, 1))
Expand Down
5 changes: 0 additions & 5 deletions airflow/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -30,13 +30,8 @@
# pylint: disable=wrong-import-position
from typing import Callable, Optional

from airflow import utils
from airflow import settings
from airflow import version
from airflow.utils.log.logging_mixin import LoggingMixin
from airflow.configuration import conf
from airflow.exceptions import AirflowException
from airflow.models.dag import DAG

__version__ = version.version

Expand Down
3 changes: 2 additions & 1 deletion airflow/api/client/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -21,8 +21,9 @@
from importlib import import_module
from typing import Any

from airflow import api, conf
from airflow import api
from airflow.api.client.api_client import Client
from airflow.configuration import conf


def get_current_api_client() -> Client:
Expand Down
5 changes: 4 additions & 1 deletion airflow/cli/commands/dag_command.py
Original file line number Diff line number Diff line change
Expand Up @@ -26,10 +26,13 @@

from tabulate import tabulate

from airflow import DAG, AirflowException, conf, jobs, settings
from airflow import jobs, settings
from airflow.api.client import get_current_api_client
from airflow.configuration import conf
from airflow.exceptions import AirflowException
from airflow.executors.debug_executor import DebugExecutor
from airflow.models import DagBag, DagModel, DagRun, TaskInstance
from airflow.models.dag import DAG
from airflow.utils import cli as cli_utils
from airflow.utils.cli import get_dag, get_dag_by_file_location, process_subdir, sigint_handler
from airflow.utils.dot_renderer import render_dag
Expand Down
3 changes: 2 additions & 1 deletion airflow/cli/commands/db_command.py
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,8 @@
import textwrap
from tempfile import NamedTemporaryFile

from airflow import AirflowException, settings
from airflow import settings
from airflow.exceptions import AirflowException
from airflow.utils import cli as cli_utils, db


Expand Down
5 changes: 4 additions & 1 deletion airflow/cli/commands/task_command.py
Original file line number Diff line number Diff line change
Expand Up @@ -26,9 +26,12 @@

from tabulate import tabulate

from airflow import DAG, AirflowException, conf, jobs, settings
from airflow import jobs, settings
from airflow.configuration import conf
from airflow.exceptions import AirflowException
from airflow.executors.executor_loader import ExecutorLoader
from airflow.models import DagPickle, TaskInstance
from airflow.models.dag import DAG
from airflow.ti_deps.dep_context import DepContext
from airflow.ti_deps.dependencies import SCHEDULER_QUEUED_DEPS
from airflow.utils import cli as cli_utils
Expand Down
5 changes: 3 additions & 2 deletions airflow/cli/commands/webserver_command.py
Original file line number Diff line number Diff line change
Expand Up @@ -28,8 +28,9 @@
import psutil
from daemon.pidfile import TimeoutPIDLockFile

from airflow import AirflowException, conf, settings
from airflow.exceptions import AirflowWebServerTimeout
from airflow import settings
from airflow.configuration import conf
from airflow.exceptions import AirflowException, AirflowWebServerTimeout
from airflow.utils import cli as cli_utils
from airflow.utils.cli import setup_locations, setup_logging
from airflow.www.app import cached_app, create_app
Expand Down
3 changes: 2 additions & 1 deletion airflow/config_templates/airflow_local_settings.py
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,8 @@
from typing import Any, Dict, Union
from urllib.parse import urlparse

from airflow import AirflowException, conf
from airflow.configuration import conf
from airflow.exceptions import AirflowException
from airflow.utils.file import mkdirs

# TODO: Logging format and level should be configured
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,7 @@

from datetime import timedelta

from airflow import DAG
from airflow.models.dag import DAG
from airflow.operators.bash import BashOperator
from airflow.operators.python import PythonOperator
from airflow.utils.dates import days_ago
Expand Down
3 changes: 1 addition & 2 deletions airflow/example_dags/example_trigger_controller_dag.py
Original file line number Diff line number Diff line change
Expand Up @@ -21,8 +21,7 @@
1. 1st DAG (example_trigger_controller_dag) holds a TriggerDagRunOperator, which will trigger the 2nd DAG
2. 2nd DAG (example_trigger_target_dag) which will be triggered by the TriggerDagRunOperator in the 1st DAG
"""

from airflow import DAG
from airflow.models.dag import DAG
from airflow.operators.dagrun_operator import TriggerDagRunOperator
from airflow.utils.dates import days_ago

Expand Down
3 changes: 1 addition & 2 deletions airflow/example_dags/example_xcom.py
Original file line number Diff line number Diff line change
Expand Up @@ -17,8 +17,7 @@
# under the License.

"""Example DAG demonstrating the usage of XComs."""

from airflow import DAG
from airflow.models.dag import DAG
from airflow.operators.python import PythonOperator
from airflow.utils.dates import days_ago

Expand Down
2 changes: 1 addition & 1 deletion airflow/example_dags/tutorial.py
Original file line number Diff line number Diff line change
Expand Up @@ -26,7 +26,7 @@

# [START import_module]
# The DAG object; we'll need this to instantiate a DAG
from airflow import DAG
from airflow.models.dag import DAG
# Operators; we need this to operate!
from airflow.operators.bash import BashOperator
from airflow.utils.dates import days_ago
Expand Down
3 changes: 2 additions & 1 deletion airflow/executors/base_executor.py
Original file line number Diff line number Diff line change
Expand Up @@ -20,10 +20,11 @@
from collections import OrderedDict
from typing import Any, Dict, List, Optional, Set, Tuple, Union

from airflow import LoggingMixin, conf
from airflow.configuration import conf
from airflow.models import TaskInstance
from airflow.models.taskinstance import SimpleTaskInstance, TaskInstanceKeyType
from airflow.stats import Stats
from airflow.utils.log.logging_mixin import LoggingMixin
from airflow.utils.state import State

PARALLELISM: int = conf.getint('core', 'PARALLELISM')
Expand Down
2 changes: 1 addition & 1 deletion airflow/executors/dask_executor.py
Original file line number Diff line number Diff line change
Expand Up @@ -22,8 +22,8 @@
from distributed import Client, Future, as_completed
from distributed.security import Security

from airflow import AirflowException
from airflow.configuration import conf
from airflow.exceptions import AirflowException
from airflow.executors.base_executor import NOT_STARTED_MESSAGE, BaseExecutor, CommandType
from airflow.models.taskinstance import TaskInstanceKeyType

Expand Down
2 changes: 1 addition & 1 deletion airflow/executors/debug_executor.py
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,7 @@
import threading
from typing import Any, Dict, List, Optional

from airflow import conf
from airflow.configuration import conf
from airflow.executors.base_executor import BaseExecutor
from airflow.models.taskinstance import TaskInstance, TaskInstanceKeyType
from airflow.utils.state import State
Expand Down
2 changes: 1 addition & 1 deletion airflow/executors/local_executor.py
Original file line number Diff line number Diff line change
Expand Up @@ -48,7 +48,7 @@
from queue import Empty, Queue # pylint: disable=unused-import # noqa: F401
from typing import Any, List, Optional, Tuple, Union # pylint: disable=unused-import # noqa: F401

from airflow import AirflowException
from airflow.exceptions import AirflowException
from airflow.executors.base_executor import NOT_STARTED_MESSAGE, PARALLELISM, BaseExecutor, CommandType
from airflow.models.taskinstance import ( # pylint: disable=unused-import # noqa: F401
TaskInstanceKeyType, TaskInstanceStateType,
Expand Down
4 changes: 2 additions & 2 deletions airflow/models/baseoperator.py
Original file line number Diff line number Diff line change
Expand Up @@ -674,7 +674,7 @@ def priority_weight_total(self) -> int:

if not self._dag:
return self.priority_weight
from airflow import DAG
from airflow.models.dag import DAG
dag: DAG = self._dag
return self.priority_weight + sum(
map(lambda task_id: dag.task_dict[task_id].priority_weight,
Expand Down Expand Up @@ -1001,7 +1001,7 @@ def get_flat_relatives(self, upstream: bool = False):
"""
if not self._dag:
return set()
from airflow import DAG
from airflow.models.dag import DAG
dag: DAG = self._dag
return list(map(lambda task_id: dag.task_dict[task_id],
self.get_flat_relative_ids(upstream)))
Expand Down
2 changes: 1 addition & 1 deletion airflow/models/serialized_dag.py
Original file line number Diff line number Diff line change
Expand Up @@ -27,8 +27,8 @@
from sqlalchemy import Column, Index, Integer, String, and_
from sqlalchemy.sql import exists

from airflow import DAG
from airflow.models.base import ID_LEN, Base
from airflow.models.dag import DAG
from airflow.serialization.serialized_objects import SerializedDAG
from airflow.settings import json
from airflow.utils import timezone
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,7 @@
"""
from datetime import timedelta

from airflow import DAG
from airflow.models.dag import DAG
from airflow.providers.amazon.aws.operators.emr_create_job_flow import EmrCreateJobFlowOperator
from airflow.providers.amazon.aws.sensors.emr_job_flow import EmrJobFlowSensor
from airflow.utils.dates import days_ago
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,7 @@
"""
from datetime import timedelta

from airflow import DAG
from airflow.models.dag import DAG
from airflow.providers.amazon.aws.operators.emr_add_steps import EmrAddStepsOperator
from airflow.providers.amazon.aws.operators.emr_create_job_flow import EmrCreateJobFlowOperator
from airflow.providers.amazon.aws.operators.emr_terminate_job_flow import EmrTerminateJobFlowOperator
Expand Down
3 changes: 2 additions & 1 deletion airflow/providers/amazon/aws/hooks/batch_client.py
Original file line number Diff line number Diff line change
Expand Up @@ -34,9 +34,10 @@
import botocore.exceptions
import botocore.waiter

from airflow import AirflowException, LoggingMixin
from airflow.exceptions import AirflowException
from airflow.providers.amazon.aws.hooks.base_aws import AwsBaseHook
from airflow.typing_compat import Protocol, runtime_checkable
from airflow.utils.log.logging_mixin import LoggingMixin

# Add exceptions to pylint for the boto3 protocol only; ideally the boto3 library could provide
# protocols for all their dynamically generated classes (try to migrate this to a PR on botocore).
Expand Down
2 changes: 1 addition & 1 deletion airflow/providers/amazon/aws/hooks/batch_waiters.py
Original file line number Diff line number Diff line change
Expand Up @@ -36,7 +36,7 @@
import botocore.exceptions
import botocore.waiter

from airflow import AirflowException
from airflow.exceptions import AirflowException
from airflow.providers.amazon.aws.hooks.batch_client import AwsBatchClient


Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -30,7 +30,7 @@
"""
from datetime import date, timedelta

from airflow import DAG
from airflow.models.dag import DAG
from airflow.operators.bash import BashOperator
from airflow.operators.python import PythonOperator
from airflow.providers.apache.hive.operators.hive import HiveOperator
Expand Down
2 changes: 1 addition & 1 deletion airflow/providers/apache/livy/example_dags/example_livy.py
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,7 @@
using the Java and Python executables provided in the example library.
"""

from airflow import DAG
from airflow.models.dag import DAG
from airflow.providers.apache.livy.operators.livy import LivyOperator
from airflow.utils.dates import days_ago

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -31,7 +31,7 @@
https://docs.databricks.com/api/latest/jobs.html#runstate
"""

from airflow import DAG
from airflow.models.dag import DAG
from airflow.providers.databricks.operators.databricks import DatabricksSubmitRunOperator
from airflow.utils.dates import days_ago

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,7 @@
"""
from datetime import timedelta

from airflow import DAG
from airflow.models.dag import DAG
from airflow.providers.dingding.operators.dingding import DingdingOperator
from airflow.utils.dates import days_ago

Expand Down
2 changes: 1 addition & 1 deletion airflow/providers/dingding/hooks/dingding.py
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,7 @@

import requests

from airflow import AirflowException
from airflow.exceptions import AirflowException
from airflow.providers.http.hooks.http import HttpHook


Expand Down
2 changes: 1 addition & 1 deletion airflow/providers/docker/example_dags/example_docker.py
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,7 @@
# under the License.
from datetime import timedelta

from airflow import DAG
from airflow.models.dag import DAG
from airflow.operators.bash import BashOperator
from airflow.providers.docker.operators.docker import DockerOperator
from airflow.utils.dates import days_ago
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -27,7 +27,7 @@

from datetime import timedelta

from airflow import DAG
from airflow.models.dag import DAG
from airflow.operators.bash import BashOperator
from airflow.operators.python import ShortCircuitOperator
from airflow.providers.docker.operators.docker import DockerOperator
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,7 @@
# under the License.
from datetime import timedelta

from airflow import DAG
from airflow.models.dag import DAG
from airflow.providers.docker.operators.docker_swarm import DockerSwarmOperator
from airflow.utils.dates import days_ago

Expand Down
2 changes: 1 addition & 1 deletion airflow/providers/google/cloud/hooks/bigquery.py
Original file line number Diff line number Diff line change
Expand Up @@ -35,7 +35,7 @@
_test_google_api_imports as gbq_test_google_api_imports,
)

from airflow import AirflowException
from airflow.exceptions import AirflowException
from airflow.hooks.dbapi_hook import DbApiHook
from airflow.providers.google.cloud.hooks.base import CloudBaseHook
from airflow.utils.log.logging_mixin import LoggingMixin
Expand Down
2 changes: 1 addition & 1 deletion airflow/providers/google/cloud/hooks/cloud_build.py
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,7 @@

from googleapiclient.discovery import build

from airflow import AirflowException
from airflow.exceptions import AirflowException
from airflow.providers.google.cloud.hooks.base import CloudBaseHook

# Time to sleep between active checks of the operation results
Expand Down
3 changes: 2 additions & 1 deletion airflow/providers/google/cloud/hooks/cloud_memorystore.py
Original file line number Diff line number Diff line change
Expand Up @@ -27,7 +27,8 @@
from google.cloud.redis_v1.types import FieldMask, InputConfig, Instance, OutputConfig
from google.protobuf.json_format import ParseDict

from airflow import AirflowException, version
from airflow import version
from airflow.exceptions import AirflowException
from airflow.providers.google.cloud.hooks.base import CloudBaseHook


Expand Down
3 changes: 2 additions & 1 deletion airflow/providers/google/cloud/hooks/cloud_sql.py
Original file line number Diff line number Diff line change
Expand Up @@ -42,14 +42,15 @@
from googleapiclient.errors import HttpError
from sqlalchemy.orm import Session

from airflow import AirflowException, LoggingMixin
from airflow.exceptions import AirflowException
# Number of retries - used by googleapiclient method calls to perform retries
# For requests that are "retriable"
from airflow.hooks.base_hook import BaseHook
from airflow.models import Connection
from airflow.providers.google.cloud.hooks.base import CloudBaseHook
from airflow.providers.mysql.hooks.mysql import MySqlHook
from airflow.providers.postgres.hooks.postgres import PostgresHook
from airflow.utils.log.logging_mixin import LoggingMixin
from airflow.utils.session import provide_session

UNIX_PATH_MAX = 108
Expand Down
2 changes: 1 addition & 1 deletion airflow/providers/google/cloud/hooks/compute.py
Original file line number Diff line number Diff line change
Expand Up @@ -24,7 +24,7 @@

from googleapiclient.discovery import build

from airflow import AirflowException
from airflow.exceptions import AirflowException
from airflow.providers.google.cloud.hooks.base import CloudBaseHook

# Time to sleep between active checks of the operation results
Expand Down
2 changes: 1 addition & 1 deletion airflow/providers/google/cloud/hooks/dataflow.py
Original file line number Diff line number Diff line change
Expand Up @@ -31,7 +31,7 @@

from googleapiclient.discovery import build

from airflow import AirflowException
from airflow.exceptions import AirflowException
from airflow.providers.google.cloud.hooks.base import CloudBaseHook
from airflow.utils.log.logging_mixin import LoggingMixin
from airflow.utils.python_virtualenv import prepare_virtualenv
Expand Down
Loading

0 comments on commit 4d03e33

Please sign in to comment.