Skip to content

Commit

Permalink
[AIRFLOW-5161] Static checks are run automatically in pre-commit hooks (
Browse files Browse the repository at this point in the history
  • Loading branch information
potiuk authored Aug 15, 2019
1 parent 84b65d8 commit 70e937a
Show file tree
Hide file tree
Showing 36 changed files with 894 additions and 555 deletions.
54 changes: 54 additions & 0 deletions .pre-commit-config.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,54 @@
# 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.
---
default_stages: [commit, push]
repos:
- repo: meta
hooks:
- id: check-hooks-apply
- repo: local
hooks:
- id: lint-dockerfile
name: Lint dockerfile
language: system
entry: ./scripts/ci/ci_lint_dockerfile.sh
files: ^Dockerfile.*$
- id: mypy
name: Run mypy
language: system
entry: ./scripts/ci/ci_mypy.sh
files: \.py$
require_serial: true
- id: pylint
name: Run pylint for main sources
language: system
entry: ./scripts/ci/ci_pylint_main.sh
files: \.py$
exclude: ^tests/.*\.py$
require_serial: true
- id: pylint
name: Run pylint for tests
language: system
entry: ./scripts/ci/ci_pylint_tests.sh
files: ^tests/.*\.py$
require_serial: true
- id: flake8
name: Run flake8
language: system
entry: ./scripts/ci/ci_flake8.sh
files: \.py$
require_serial: true
24 changes: 10 additions & 14 deletions .travis.yml
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,8 @@ language: python
env:
global:
- BUILD_ID=${TRAVIS_BUILD_ID}
- AIRFLOW_CONTAINER_MOUNT_HOST_VOLUMES="false"
- AIRFLOW_CI_SILENT="false"
- CI="true"
python: "3.6"
stages:
Expand Down Expand Up @@ -48,24 +50,18 @@ jobs:
env: BACKEND=postgres ENV=kubernetes KUBERNETES_VERSION=v1.13.0 KUBERNETES_MODE=git_mode
python: "3.6"
stage: test
- name: Flake8
- name: "Static checks except pylint and docs"
stage: pre-test
script: ./scripts/ci/ci_flake8.sh
- name: mypy
stage: pre-test
script: ./scripts/ci/ci_mypy.sh
- name: Check license header
stage: pre-test
script: ./scripts/ci/ci_check_license.sh
- name: Lint Dockerfile
stage: pre-test
script: ./scripts/ci/ci_lint_dockerfile.sh
script: ./scripts/ci/ci_run_all_static_tests.sh
- name: Check docs
stage: test
stage: pre-test
script: ./scripts/ci/ci_docs.sh
- name: Pylint
- name: Pylint main
stage: pre-test
script: ./scripts/ci/ci_pylint_main.sh
- name: Pylint tests
stage: pre-test
script: ./scripts/ci/ci_pylint.sh
script: ./scripts/ci/ci_pylint_tests.sh
services:
- docker
before_install:
Expand Down
264 changes: 180 additions & 84 deletions CONTRIBUTING.md

Large diffs are not rendered by default.

4 changes: 1 addition & 3 deletions airflow/contrib/hooks/bigquery_hook.py
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
# -*- coding: utf-8 -*-
# -*- coding: utf-8 -*- # pylint: disable=too-many-lines
#
# Licensed to the Apache Software Foundation (ASF) under one
# or more contributor license agreements. See the NOTICE file
Expand All @@ -22,8 +22,6 @@
implementation for BigQuery.
"""

# pylint: disable=too-many-lines

import time
from copy import deepcopy

Expand Down
16 changes: 14 additions & 2 deletions confirm
Original file line number Diff line number Diff line change
Expand Up @@ -17,15 +17,27 @@
# under the License.
set -euo pipefail

if [[ "${ASSUME_YES:=false}" == "true" ]]; then
if [[ "${ASSUME_YES_TO_ALL_QUESTIONS:=false}" == "true" ]]; then
exit 0
fi

read -r -p "${1}. Are you sure? [y/N] " response
if [[ "${ASSUME_NO_TO_ALL_QUESTIONS:=false}" == "true" ]]; then
exit 1
fi

if [[ "${ASSUME_QUIT_TO_ALL_QUESTIONS:=false}" == "true" ]]; then
exit 2
fi


read -r -p "${1}. Are you sure? [y/N/q] " response
case "$response" in
[yY][eE][sS]|[yY])
exit 0
;;
[qQ][uU][iI|[tT]|[qQ])
exit 2
;;
*)
exit 1
;;
Expand Down
6 changes: 4 additions & 2 deletions docs/conf.py
Original file line number Diff line number Diff line change
Expand Up @@ -31,8 +31,10 @@
#
# All configuration values have a default; values that are commented out
# serve to show the default.
"""Configuration of Airflow Docs"""
import os
import sys
from typing import Dict

import airflow

Expand Down Expand Up @@ -256,7 +258,7 @@

# Add any paths that contain custom themes here, relative to this directory.
# html_theme_path = []
import sphinx_rtd_theme
import sphinx_rtd_theme # pylint: disable=wrong-import-position,wrong-import-order

html_theme_path = [sphinx_rtd_theme.get_html_theme_path()]

Expand Down Expand Up @@ -341,7 +343,7 @@

# Additional stuff for the LaTeX preamble.
# 'preamble': '',
}
} # type: Dict[str,str]

# Grouping the document tree into LaTeX files. List of tuples
# (source start file, target name, title,
Expand Down
102 changes: 60 additions & 42 deletions hooks/build
Original file line number Diff line number Diff line change
Expand Up @@ -147,15 +147,19 @@ export DOCKERHUB_USER=${DOCKERHUB_USER:="apache"}
# own docker images. In this case you can build images locally and push them
export DOCKERHUB_REPO=${DOCKERHUB_REPO:="airflow"}

# You can override python binary with specific version
export PYTHON_BINARY=${PYTHON_BINARY:=python}

# Determine python version from the local python on the path.
# You can override it with PYTHON_VERSION because all python version dependencies
# Are determined in Docker images. If you pass IMAGE_NAME, python version will be extracted from the name
# This default Python version is later overridden in case IMAGE_NAME is passed
export PYTHON_VERSION=\
${PYTHON_VERSION:=$(python -c 'import sys;print("%s.%s" % (sys.version_info.major, sys.version_info.minor))')}
${PYTHON_VERSION:=$(${PYTHON_BINARY} -c \
'import sys;print("%s.%s" % (sys.version_info.major, sys.version_info.minor))')}

# shellcheck source=./_default_branch.sh
. ${MY_DIR}/_default_branch.sh
. "${MY_DIR}/_default_branch.sh"

# Source brnnch will be set in DockerHub
SOURCE_BRANCH=${SOURCE_BRANCH:=${DEFAULT_BRANCH}}
Expand Down Expand Up @@ -259,7 +263,7 @@ AIRFLOW_CONTAINER_USE_PULLED_IMAGES_CACHE=${AIRFLOW_CONTAINER_USE_PULLED_IMAGES_

pwd
# Determine version of the Airflow from version.py
AIRFLOW_VERSION=$(cat airflow/version.py - << EOF | python
AIRFLOW_VERSION=$(cat airflow/version.py - << EOF | ${PYTHON_BINARY}
print(version.replace("+",""))
EOF
)
Expand All @@ -268,7 +272,7 @@ export AIRFLOW_VERSION
# Check if we are running in the CI environment
CI=${CI:="false"}

if [[ ${CI} == "true" ]]; then
if [[ "${CI}" == "true" ]]; then
NON_CI="false"
else
NON_CI="true"
Expand Down Expand Up @@ -425,57 +429,65 @@ if [[ "${AIRFLOW_CONTAINER_USE_PULLED_IMAGES_CACHE}" == "true" ]]; then
IMAGES_TO_PULL="${IMAGES_TO_PULL} ${AIRFLOW_CHECKLICENCE_IMAGE}"
fi

for IMAGE in ${IMAGES_TO_PULL}
do
DOCKER_CACHE_DIRECTIVE_CI=()
DOCKER_CACHE_DIRECTIVE_CI_SLIM=()
if [[ ${IMAGES_TO_PULL} == "" ]]; then
echo
echo "Checking whether image ${IMAGE} needs to be pulled."
echo "Skipping building of all images."
echo
PULL_IMAGE="false"
if [[ "${AIRFLOW_CONTAINER_FORCE_PULL_IMAGES}" == "true" ]]; then
else
for IMAGE in ${IMAGES_TO_PULL}
do
echo
echo "Pulling images is forced. Pulling ${IMAGE}"
echo "Checking whether image ${IMAGE} needs to be pulled."
echo
PULL_IMAGE="true"
else
IMAGE_HASH=$(docker images -q "${IMAGE}" 2> /dev/null)
if [[ "${IMAGE_HASH}" == "" ]]; then
PULL_IMAGE="false"
if [[ "${AIRFLOW_CONTAINER_FORCE_PULL_IMAGES}" == "true" ]]; then
echo
echo "No image ${IMAGE} locally available. Pulling for the first time."
echo "Pulling images is forced. Pulling ${IMAGE}"
echo
PULL_IMAGE="true"
else
echo
echo "Image ${IMAGE} is in local registry (${IMAGE_HASH}). Not pulling it!"
echo
PULL_IMAGE="false"
IMAGE_HASH=$(docker images -q "${IMAGE}" 2> /dev/null)
if [[ "${IMAGE_HASH}" == "" ]]; then
echo
echo "No image ${IMAGE} locally available. Pulling for the first time."
echo
PULL_IMAGE="true"
else
echo
echo "Image ${IMAGE} is in local registry (${IMAGE_HASH}). Not pulling it!"
echo
PULL_IMAGE="false"
fi
fi
fi
if [[ "${PULL_IMAGE}" == "true" ]]; then
if [[ "${AIRFLOW_CONTAINER_SKIP_PULLING_AIRFLOW_IMAGES}" == "true" ]]; then
echo
echo "Skipping pulling image ${IMAGE}"
echo
if [[ "${PULL_IMAGE}" == "true" ]]; then
if [[ "${AIRFLOW_CONTAINER_SKIP_PULLING_AIRFLOW_IMAGES}" == "true" ]]; then
echo
echo "Skipping pulling image ${IMAGE}"
echo
else
echo
set -x
docker pull "${IMAGE}" || true
set +x
echo
fi
fi
if [[ "${IMAGE}" == "${AIRFLOW_CI_IMAGE}" ]]; then
DOCKER_CACHE_DIRECTIVE_CI+=("--cache-from" "${IMAGE}")
elif [[ "${IMAGE}" == "${AIRFLOW_SLIM_CI_IMAGE}" ]]; then
DOCKER_CACHE_DIRECTIVE_CI_SLIM+=("--cache-from" "${IMAGE}")
elif [[ "${IMAGE}" == "${AIRFLOW_CHECKLICENCE_IMAGE}" ]]; then
DOCKER_CACHE_DIRECTIVE_CHECKLICENCE+=("--cache-from" "${IMAGE}")
else
echo
set -x
docker pull "${IMAGE}" || true
set +x
echo "Don't know how to set cache directive for ${IMAGE}. Exiting"
echo
exit 1
fi
fi
if [[ "${IMAGE}" == "${AIRFLOW_CI_IMAGE}" ]]; then
DOCKER_CACHE_DIRECTIVE_CI+=("--cache-from" "${IMAGE}")
elif [[ "${IMAGE}" == "${AIRFLOW_SLIM_CI_IMAGE}" ]]; then
DOCKER_CACHE_DIRECTIVE_CI_SLIM+=("--cache-from" "${IMAGE}")
elif [[ "${IMAGE}" == "${AIRFLOW_CHECKLICENCE_IMAGE}" ]]; then
DOCKER_CACHE_DIRECTIVE_CHECKLICENCE+=("--cache-from" "${IMAGE}")
else
echo
echo "Don't know how to set cache directive for ${IMAGE}. Exiting"
echo
exit 1
fi
done
done
fi
fi

start_step "Setting cache options"
Expand Down Expand Up @@ -600,13 +612,16 @@ else
if [[ "${PYTHON_VERSION_FOR_DEFAULT_IMAGE}" == "${PYTHON_VERSION}" ]]; then
docker tag "${AIRFLOW_SLIM_CI_IMAGE}" "${AIRFLOW_SLIM_CI_IMAGE_DEFAULT}"
add_image_to_push "${AIRFLOW_SLIM_CI_IMAGE_DEFAULT}"
save_to_file AIRFLOW_SLIM_CI_IMAGE_DEFAULT
fi
if [[ "${AIRFLOW_RELEASE_BUILD}" == "true" ]]; then
docker tag "${AIRFLOW_SLIM_CI_IMAGE}" "${AIRFLOW_SLIM_CI_IMAGE_LATEST}"
add_image_to_push "${AIRFLOW_SLIM_CI_IMAGE_LATEST}"
save_to_file AIRFLOW_SLIM_CI_IMAGE_LATEST
if [[ "${PYTHON_VERSION_FOR_DEFAULT_IMAGE}" == "${PYTHON_VERSION}" ]]; then
docker tag "${AIRFLOW_SLIM_CI_IMAGE}" "${AIRFLOW_SLIM_CI_IMAGE_LATEST_DEFAULT}"
add_image_to_push "${AIRFLOW_SLIM_CI_IMAGE_LATEST_DEFAULT}"
save_to_file AIRFLOW_SLIM_CI_IMAGE_LATEST_DEFAULT
fi
fi
fi
Expand All @@ -627,13 +642,16 @@ else
if [[ "${PYTHON_VERSION_FOR_DEFAULT_IMAGE}" == "${PYTHON_VERSION}" ]]; then
docker tag "${AIRFLOW_CI_IMAGE}" "${AIRFLOW_CI_IMAGE_DEFAULT}"
add_image_to_push "${AIRFLOW_CI_IMAGE_DEFAULT}"
save_to_file AIRFLOW_CI_IMAGE_DEFAULT
fi
if [[ "${AIRFLOW_RELEASE_BUILD}" == "true" ]]; then
docker tag "${AIRFLOW_CI_IMAGE}" "${AIRFLOW_CI_IMAGE_LATEST}"
add_image_to_push "${AIRFLOW_CI_IMAGE_LATEST}"
save_to_file AIRFLOW_CI_IMAGE_LATEST
if [[ "${PYTHON_VERSION_FOR_DEFAULT_IMAGE}" == "${PYTHON_VERSION}" ]]; then
docker tag "${AIRFLOW_CI_IMAGE}" "${AIRFLOW_CI_IMAGE_LATEST_DEFAULT}"
add_image_to_push "${AIRFLOW_CI_IMAGE_LATEST_DEFAULT}"
save_to_file AIRFLOW_CI_IMAGE_LATEST_DEFAULT
fi
fi
fi
Expand Down
33 changes: 14 additions & 19 deletions hooks/push
Original file line number Diff line number Diff line change
@@ -1,25 +1,20 @@
#!/usr/bin/env bash
# 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
#
# 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
#
# 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.

# This is hook build used by DockerHub. We are also using it
# on Travis CI to potentially rebuild (and refresh layers that
# are not cached) Docker images that are used to run CI jobs
# 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.

# We do not push in the push step because we are building multiple images in the build step
# and it is difficult to pass list of the built images from the build to push phase
Expand Down
Loading

0 comments on commit 70e937a

Please sign in to comment.