Airflow 2.10.2 + ubuntu_jammy

Change-Id: I88d91ffc9fedb51a61cb34a77e6fd7b9ea187862
This commit is contained in:
Sergiy Markin 2024-09-04 23:19:27 +00:00
parent c8be88cfa2
commit e917c9dca7
23 changed files with 786 additions and 323 deletions

View File

@ -13,30 +13,34 @@
- project:
templates:
- docs-on-readthedocs
- openstack-python38-jobs
vars:
rtd_webhook_id: '38576'
rtd_project_name: 'airship-shipyard'
ensure_global_symlinks: true
check:
jobs:
- airship-shipyard-openstack-tox-pep8-focal
- airship-shipyard-openstack-tox-cover-focal
- openstack-tox-py310
- airship-shipyard-openstack-tox-pep8-jammy
- airship-shipyard-openstack-tox-cover-jammy
- airship-shipyard-chart-build-gate
- airship-shipyard-chart-build-latest-htk
- airship-airflow-dependency-vulnerability-check
- airship-shipyard-dependency-vulnerability-check
- airship-shipyard-whitespace-lint-gate
- airship-shipyard-airskiff-deployment-focal
- shipyard-airskiff-deployment-focal-kubeadm
- airship-shipyard-image-gate-ubuntu_jammy
- shipyard-airskiff-deployment-jammy-kubeadm
gate:
jobs:
- airship-shipyard-openstack-tox-pep8-focal
- airship-shipyard-openstack-tox-cover-focal
- openstack-tox-py310
- airship-shipyard-openstack-tox-pep8-jammy
- airship-shipyard-openstack-tox-cover-jammy
- airship-shipyard-chart-build-gate
- airship-shipyard-whitespace-lint-gate
- airship-shipyard-airskiff-deployment-focal
- airship-shipyard-image-gate-ubuntu_jammy
- shipyard-airskiff-deployment-jammy-kubeadm
post:
jobs:
- airship-shipyard-docker-build-publish-ubuntu_focal
- airship-shipyard-docker-build-publish-ubuntu_jammy
- shipyard-upload-git-mirror
- nodeset:
@ -46,32 +50,52 @@
label: ubuntu-bionic
- nodeset:
name: airship-shipyard-single-node-focal
name: airship-shipyard-single-node-jammy
nodes:
- name: primary
label: ubuntu-focal
label: ubuntu-jammy
- job:
name: airship-shipyard-openstack-tox-pep8-focal
name: airship-airflow-dependency-vulnerability-check
parent: tox-py310
voting: false
timeout: 600
nodeset: ubuntu-jammy
vars:
tox_envlist: airflow_safety
bindep_profile: test py310
- job:
name: airship-shipyard-dependency-vulnerability-check
parent: tox-py310
voting: false
timeout: 600
nodeset: ubuntu-jammy
vars:
tox_envlist: shipyard_safety
bindep_profile: test py310
- job:
name: airship-shipyard-openstack-tox-pep8-jammy
parent: openstack-tox-pep8
description: Runs pep8 job on focal
nodeset: airship-shipyard-single-node-focal
description: Runs pep8 job on jammy
nodeset: airship-shipyard-single-node-jammy
- job:
name: airship-shipyard-openstack-tox-cover-focal
name: airship-shipyard-openstack-tox-cover-jammy
parent: openstack-tox-cover
description: Runs cover job on focal
nodeset: airship-shipyard-single-node-focal
description: Runs cover job on jammy
nodeset: airship-shipyard-single-node-jammy
- job:
name: airship-shipyard-chart-build-gate
description: Build charts using pinned Helm toolkit.
timeout: 900
run: tools/gate/playbooks/build-charts.yaml
nodeset: airship-shipyard-single-node-focal
nodeset: airship-shipyard-single-node-jammy
vars:
HTK_COMMIT: cfff60ec10a6c386f38db79bb9f59a552c2b032f
HTK_COMMIT: 43fd7143481b6ddda0dbd2f26bf6ec39a417b15b
- job:
name: airship-shipyard-chart-build-latest-htk
@ -79,7 +103,7 @@
timeout: 900
voting: false
run: tools/gate/playbooks/build-charts.yaml
nodeset: airship-shipyard-single-node-focal
nodeset: airship-shipyard-single-node-jammy
vars:
HTK_COMMIT: master
@ -88,7 +112,7 @@
description: |
Lints all files by checking them for whitespace.
run: tools/gate/playbooks/zuul-linter.yaml
nodeset: airship-shipyard-single-node-focal
nodeset: airship-shipyard-single-node-jammy
- job:
name: airship-shipyard-image-base
@ -96,7 +120,7 @@
Base job for running airship-shipyard image related jobs.
timeout: 3600
run: tools/gate/playbooks/docker-image-build.yaml
nodeset: airship-shipyard-single-node-focal
nodeset: airship-shipyard-single-node-jammy
irrelevant-files: &irrelevant-files
- ^.*\.rst$
- ^doc/.*$
@ -104,39 +128,17 @@
- job:
name: airship-shipyard-image-gate-ubuntu_focal
name: airship-shipyard-image-gate-ubuntu_jammy
description: |
Run shipyard-image build for ubuntu_focal.
Run shipyard-image build for ubuntu_jammy.
parent: airship-shipyard-image-base
vars:
publish: false
distro: ubuntu_focal
distro: ubuntu_jammy
tags:
dynamic:
patch_set: true
# - job:
# name: airship-shipyard-airskiff-deployment-focal
# nodeset: airship-shipyard-single-node-focal
# description: |
# Deploy Memcached using Airskiff and submitted Armada changes.
# timeout: 9600
# voting: true
# pre-run:
# - tools/gate/playbooks/airskiff-reduce-site.yaml
# - tools/gate/playbooks/git-config.yaml
# run: tools/gate/playbooks/airskiff-deploy.yaml
# post-run: tools/gate/playbooks/debug-report.yaml
# required-projects:
# - airship/treasuremap
# vars:
# CLONE_SHIPYARD: false
# SHIPYARD_IMAGE_DISTRO: ubuntu_focal
# HELM_ARTIFACT_URL: https://get.helm.sh/helm-v3.13.2-linux-amd64.tar.gz
# HTK_COMMIT: cfff60ec10a6c386f38db79bb9f59a552c2b032f
# OSH_INFRA_COMMIT: cfff60ec10a6c386f38db79bb9f59a552c2b032f
# OSH_COMMIT: 2d9457e34ca4200ed631466bd87569b0214c92e7
# irrelevant-files: *irrelevant-files
- job:
name: shipyard-base
@ -153,6 +155,7 @@
irrelevant-files: *irrelevant-files
timeout: 10800
pre-run:
- tools/gate/playbooks/checkout-treasuremap-ref.yaml
- tools/gate/playbooks/prepare-hosts.yaml
- tools/gate/playbooks/mount-volumes.yaml
- tools/gate/playbooks/deploy-env.yaml
@ -161,6 +164,7 @@
post-run:
- tools/gate/playbooks/osh-infra-collect-logs.yaml
vars:
treasuremap_ref: refs/changes/43/927643/4
extra_volume:
size: 80G
type: Linux
@ -177,16 +181,16 @@
loopback_device: /dev/loop100
loopback_image: "/opt/ext_vol/openstack-helm/ceph-loop.img"
ceph_osd_data_device: /dev/loop100
kube_version_repo: "v1.29"
# the list of k8s package versions are available here
# https://pkgs.k8s.io/core:/stable:/{{ kube_version_repo }}/deb/Packages
kube_version: "1.29.5-1.1"
kube_version_repo: "v1.30"
kube_version: "1.30.3-1.1"
calico_setup: true
calico_version: "v3.27.0"
calico_version: "v3.27.4"
cilium_setup: false
helm_version: "v3.14.2"
yq_version: "v4.6.0"
crictl_version: "v1.26.1"
cilium_version: "1.16.0"
flannel_setup: false
flannel_version: v0.25.4
helm_version: "v3.15.4"
crictl_version: "v1.30.1"
zuul_osh_relative_path: ../../openstack/openstack-helm
zuul_osh_infra_relative_path: ../../openstack/openstack-helm-infra
zuul_treasuremap_relative_path: ../../airship/treasuremap
@ -194,19 +198,20 @@
run_helm_tests: "no"
- job:
name: shipyard-airskiff-deployment-focal-kubeadm
nodeset: treasuremap-airskiff-1node-ubuntu_focal
name: shipyard-airskiff-deployment-jammy-kubeadm
nodeset: treasuremap-airskiff-1node-ubuntu_jammy
description: |
Deploy Memcached using Airskiff and submitted Shipyard changes.
parent: shipyard-base
vars:
site: airskiff
HELM_ARTIFACT_URL: https://get.helm.sh/helm-v3.14.2-linux-amd64.tar.gz
HTK_COMMIT: 05f2f45971abcf483189358d663e2b46c3fc2fe8
OSH_INFRA_COMMIT: 05f2f45971abcf483189358d663e2b46c3fc2fe8
OSH_COMMIT: 049e679939fbd3b0c659dd0977911b8dc3b5a015
HELM_ARTIFACT_URL: https://get.helm.sh/helm-v3.15.4-linux-amd64.tar.gz
HTK_COMMIT: 43fd7143481b6ddda0dbd2f26bf6ec39a417b15b
OSH_INFRA_COMMIT: 43fd7143481b6ddda0dbd2f26bf6ec39a417b15b
OSH_COMMIT: 540df5cb0dbdaed63c202e2d6f2b7891062f8203
TREASUREMAP_COMMIT: refs/changes/43/927643/4
CLONE_SHIPYARD: false
DISTRO: ubuntu_focal
DISTRO: ubuntu_jammy
DOCKER_REGISTRY: localhost:5000
MAKE_SHIPYARD_IMAGES: true
gate_scripts_relative_path: ../../airship/treasuremap
@ -227,23 +232,23 @@
irrelevant-files: *irrelevant-files
- job:
name: airship-shipyard-docker-build-publish-ubuntu_focal
name: airship-shipyard-docker-build-publish-ubuntu_jammy
timeout: 3600
run: tools/gate/playbooks/run-image.yaml
nodeset: airship-shipyard-single-node-focal
nodeset: airship-shipyard-single-node-jammy
irrelevant-files: *irrelevant-files
secrets:
- airship_shipyard_quay_creds
vars:
publish: true
distro: ubuntu_focal
distro: ubuntu_jammy
tags:
dynamic:
branch: true
commit: true
static:
- latest
- airflow_2.8.2
- airflow_2.10.2

View File

@ -34,9 +34,11 @@ USE_PROXY ?= false
AIRFLOW_SRC ?=
AIRFLOW_HOME ?=
DISTRO_BASE_IMAGE ?=
DISTRO ?= ubuntu_focal
DISTRO ?= ubuntu_jammy
DISTRO_ALIAS ?= ubuntu_focal
IMAGE:=${DOCKER_REGISTRY}/${IMAGE_PREFIX}/$(IMAGE_NAME):${IMAGE_TAG}-${DISTRO}
IMAGE_ALIAS := ${DOCKER_REGISTRY}/${IMAGE_PREFIX}/${IMAGE_NAME}:${IMAGE_TAG}-${DISTRO_ALIAS}
IMAGE_DIR:=images/$(IMAGE_NAME)
.PHONY: images
@ -137,6 +139,13 @@ else
$(_AIRFLOW_HOME_ARG) \
--build-arg ctx_base=$(BUILD_CTX) .
endif
ifneq ($(DISTRO), $(DISTRO_ALIAS))
docker tag $(IMAGE) $(IMAGE_ALIAS)
endif
ifeq ($(DOCKER_REGISTRY), localhost:5000)
docker push $(IMAGE)
docker push $(IMAGE_ALIAS)
endif
ifeq ($(PUSH_IMAGE), true)
docker push $(IMAGE)
endif

View File

@ -16,8 +16,8 @@
apiVersion: v1
description: A Helm chart for Shipyard and Airflow
name: shipyard
version: 0.2.6
appVersion: 2.8.2
version: 0.2.7
appVersion: 2.10.2
keywords:
- shipyard
- airflow

View File

@ -180,4 +180,4 @@ USER airflow
WORKDIR ${AIRFLOW_HOME}
# Execute entrypoint
ENTRYPOINT ["./entrypoint.sh"]
ENTRYPOINT ["./entrypoint.sh"]

View File

@ -0,0 +1,186 @@
# Copyright 2018 AT&T Intellectual Property. All other rights reserved.
#
# Licensed 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.
# Docker image to run Airflow on Kubernetes
ARG FROM=ubuntu:jammy
FROM ${FROM}
LABEL org.opencontainers.image.authors='airship-discuss@lists.airshipit.org, irc://#airshipit@freenode' \
org.opencontainers.image.url='https://airshipit.org' \
org.opencontainers.image.documentation='https://airship-shipyard.readthedocs.org' \
org.opencontainers.image.source='https://opendev.org/airship/shipyard' \
org.opencontainers.image.vendor='The Airship Authors' \
org.opencontainers.image.licenses='Apache-2.0'
# Do not prompt user for choices on installation/configuration of packages
# Set port 8080 for Airflow Web
# Set port 5555 for Airflow Flower
# Set port 8793 for Airflow Worker
ENV container docker
ENV WEB_PORT 8080
ENV FLOWER_PORT 5555
ENV WORKER_PORT 8793
ENV SLUGIFY_USES_TEXT_UNIDECODE yes
ENV PYTHONWARNINGS=ignore::DeprecationWarning,ignore::FutureWarning
# Expose port for applications
EXPOSE $WEB_PORT
EXPOSE $FLOWER_PORT
EXPOSE $WORKER_PORT
# Set ARG for usage during build
ARG AIRFLOW_HOME=/usr/local/airflow
# Moved celery to images/airflow/requirements.txt as apache-airflow uses a
# version of celery incompatibile with the version of kombu needed by other
# Airship components
ARG AIRFLOW_SRC="apache-airflow[crypto,celery,hive,hdfs,jdbc,postgres]==2.10.2"
ARG DEBIAN_FRONTEND=noninteractive
ARG ctx_base=src/bin
# Kubectl version
ARG KUBECTL_VERSION=1.31.0
# Needed from apache-airflow 1.10.2, since core.airflow_home config is deprecated
ENV AIRFLOW_HOME=${AIRFLOW_HOME}
RUN set -ex \
&& apt-get update && apt-get upgrade -y \
&& apt-get install -y wget curl \
apt-transport-https ca-certificates gnupg \
&& echo "deb http://apt.postgresql.org/pub/repos/apt jammy-pgdg main" > /etc/apt/sources.list.d/pgdg.list \
&& curl -o /etc/apt/trusted.gpg.d/postgresql_release_signing_key.asc 'https://www.postgresql.org/media/keys/ACCC4CF8.asc' \
&& apt update \
&& apt -y install \
automake \
build-essential \
ca-certificates \
curl \
git \
g++ \
libkrb5-dev \
libffi-dev \
libssl-dev \
libpq-dev \
libpq5 \
libtool \
libxml2 \
libsasl2-dev \
locales \
netcat \
netbase \
postgresql-client \
postgresql-common \
python3 \
python3-setuptools \
python3-pip \
python3-dev \
python3-dateutil \
make \
--no-install-recommends \
&& python3 -m pip install -U pip \
&& apt-get clean \
&& rm -rf \
/var/lib/apt/lists/* \
/tmp/* \
/var/tmp/* \
/usr/share/man \
/usr/share/doc \
/usr/share/doc-base \
/etc/ssl/private/ssl-cert-snakeoil.key \
/etc/ssl/private/ssl-cert-snakeoil.pem
# Install LibYAML
ENV LD_LIBRARY_PATH=/usr/local/lib
ARG LIBYAML_VERSION=0.2.5
RUN set -ex \
&& git clone https://github.com/yaml/libyaml.git \
&& cd libyaml \
&& git checkout $LIBYAML_VERSION \
&& ./bootstrap \
&& ./configure \
&& make \
&& make install \
&& cd .. \
&& rm -fr libyaml
# Things that change mostly infrequently
RUN useradd -ms /bin/bash -d ${AIRFLOW_HOME} airflow \
&& curl -L -o /usr/local/bin/kubectl \
https://storage.googleapis.com/kubernetes-release/release/v${KUBECTL_VERSION}/bin/linux/amd64/kubectl \
&& chmod +x /usr/local/bin/kubectl
# Dependency requirements
# Note - removing snakebite (python 2 vs. 3). See:
# https://github.com/puckel/docker-airflow/issues/77
# Install Airflow directly to allow overriding source
# COPY images/airflow/requirements.txt /tmp/
COPY ${ctx_base}/shipyard_airflow/requirements-frozen.txt /tmp/requirements.txt
RUN pip3 install -r /tmp/requirements.txt --no-cache-dir \
&& pip3 install $AIRFLOW_SRC --no-cache-dir
# && (pip3 uninstall -y snakebite || true) \
# && (pip3 uninstall -y psycopg2 || true) \
# && (pip3 install --no-cache-dir --force-reinstall $(pip freeze | grep psycopg2-binary) || true)
# Copy scripts used in the container:
COPY images/airflow/script/*.sh ${AIRFLOW_HOME}/
# Copy configuration (e.g. logging config for Airflow):
COPY images/airflow/config/*.py ${AIRFLOW_HOME}/config/
COPY images/airflow/webserver_config.py ${AIRFLOW_HOME}/
# Change permissions
RUN chown -R airflow: ${AIRFLOW_HOME}
# Setting the version explicitly for PBR
ENV PBR_VERSION 0.1a1
# Shipyard
#
# Shipyard provides core functionality used by the Airflow plugins/operators
# Since Shipyard and Airflow are built together as images, this should prevent
# stale or out-of-date code between these parts.
# Shipyard requirements, source and installation
# COPY ${ctx_base}/shipyard_airflow/requirements-frozen.txt /tmp/api_requirements.txt
# RUN pip3 install -r /tmp/api_requirements.txt --no-cache-dir
COPY ${ctx_base}/shipyard_airflow /tmp/shipyard/
RUN cd /tmp/shipyard \
&& pip3 install $(pwd) --use-pep517
# Note: The value for the dags and plugins directories that are sourced
# from the values.yaml of the Shipyard Helm chart need to align with these
# directories. If they do not, airflow will not find the intended dags and
# plugins.
#
# Note: In the case of building images using the provided Makefile, a test is
# run against the built-in dags provided with Airflow. Since there is no Helm
# chart to reconfigure the airflow.cfg with these directories, these dags and
# plugins are not known to Airflow during the image test.
#
# Copy the plugins and dags that will be used by this Airflow image:
COPY ${ctx_base}/shipyard_airflow/shipyard_airflow/plugins ${AIRFLOW_HOME}/plugins/
COPY ${ctx_base}/shipyard_airflow/shipyard_airflow/plugins \
/usr/local/lib/python3.10/dist-packages/airflow/plugins/
COPY ${ctx_base}/shipyard_airflow/shipyard_airflow/dags ${AIRFLOW_HOME}/dags/
COPY ${ctx_base}/shipyard_airflow/shipyard_airflow/dags \
/usr/local/lib/python3.10/dist-packages/airflow/dags/
# Set work directory
USER airflow
WORKDIR ${AIRFLOW_HOME}
# Execute entrypoint
ENTRYPOINT ["./entrypoint.sh"]

View File

@ -40,13 +40,26 @@ elif [[ $cmd == *scheduler* ]]; then
${python3_path} ${airflow_path} scheduler $2 $3
done
elif [[ $cmd == 'quicktest' ]]; then
${python3_path} ${airflow_path} version
${python3_path} ${airflow_path} db init
${python3_path} ${airflow_path} db migrate
${python3_path} ${airflow_path} dags list
${python3_path} ${airflow_path} webserver -p 8080 &
${python3_path} ${airflow_path} scheduler &
while true; do
is_active=$(airflow dags details example_bash_operator -o plain | grep is_active | awk '{print $2}')
if [ "$is_active" == "True" ]; then
echo "DAG example_bash_operator is active."
break
fi
echo "Waiting for DAG example_bash_operator to become active..."
sleep 10
done
${python3_path} ${airflow_path} dags list
${python3_path} ${airflow_path} dags unpause example_bash_operator
${python3_path} ${airflow_path} tasks test example_bash_operator runme_0
${python3_path} ${airflow_path} dags backfill example_bash_operator -s 2018-01-01 -e 2018-01-02
${python3_path} ${airflow_path} tasks run example_bash_operator runme_0 2018-01-01
${python3_path} ${airflow_path} tasks states-for-dag-run example_bash_operator backfill__2018-01-02T00:00:00+00:00
${python3_path} ${airflow_path} dags state example_bash_operator 2018-01-01
else
echo "Invalid Command!"

View File

@ -0,0 +1,141 @@
# Copyright 2017 AT&T Intellectual Property. All other rights reserved.
#
# Licensed 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.
ARG FROM=ubuntu:jammy
FROM ${FROM}
LABEL org.opencontainers.image.authors='airship-discuss@lists.airshipit.org, irc://#airshipit@freenode' \
org.opencontainers.image.url='https://airshipit.org' \
org.opencontainers.image.documentation='https://airship-shipyard.readthedocs.org' \
org.opencontainers.image.source='https://opendev.org/airship/shipyard' \
org.opencontainers.image.vendor='The Airship Authors' \
org.opencontainers.image.licenses='Apache-2.0'
ENV container docker
ENV PORT 9000
ENV LC_ALL C.UTF-8
ENV LANG C.UTF-8
ENV PYTHONWARNINGS=ignore::DeprecationWarning,ignore::FutureWarning
# Setting the version explicitly for PBR
ENV PBR_VERSION 0.1a1
ARG DEBIAN_FRONTEND=noninteractive
ARG ctx_base=src/bin
# Expose port 9000 for application
EXPOSE $PORT
RUN set -ex && \
apt-get update && apt-get upgrade -y && \
apt-get -y install \
automake \
ca-certificates \
curl \
build-essential \
git \
libtool \
libxml2 \
make \
netbase \
python3-dev \
python3-setuptools \
--no-install-recommends \
&& apt-get autoremove -yqq --purge \
&& apt-get clean \
&& rm -rf \
/var/lib/apt/lists/* \
/tmp/* \
/var/tmp/* \
/usr/share/man \
/usr/share/doc \
/usr/share/doc-base
# Install LibYAML
ENV LD_LIBRARY_PATH=/usr/local/lib
ARG LIBYAML_VERSION=0.2.5
RUN set -ex \
&& git clone https://github.com/yaml/libyaml.git \
&& cd libyaml \
&& git checkout $LIBYAML_VERSION \
&& ./bootstrap \
&& ./configure \
&& make \
&& make install \
&& cd .. \
&& rm -fr libyaml
# Create shipyard user
RUN useradd -ms /bin/bash shipyard \
&& mkdir -p /home/shipyard/shipyard \
&& mkdir -p /home/shipyard/shipyard_client
# Copy entrypoint.sh to /home/shipyard
COPY ${ctx_base}/shipyard_airflow/entrypoint.sh /home/shipyard/entrypoint.sh
# Change permissions and set up directories
RUN chown -R shipyard: /home/shipyard \
&& chmod +x /home/shipyard/entrypoint.sh
# Requirements and Shipyard source
COPY ${ctx_base}/shipyard_airflow/requirements-frozen.txt /home/shipyard/api_requirements.txt
COPY ${ctx_base}/shipyard_client/requirements-frozen.txt /home/shipyard/client_requirements.txt
COPY ${ctx_base}/shipyard_client /home/shipyard/shipyard_client/
COPY ${ctx_base}/shipyard_airflow /home/shipyard/shipyard/
# Build
RUN set -ex \
&& buildDeps=' \
build-essential \
git \
libssl-dev \
libffi-dev \
libkrb5-dev \
libpq-dev \
libsasl2-dev \
libssl-dev \
libre2-dev \
libzmq3-dev \
make \
python3-pip \
' \
&& apt-get -qq update \
&& apt-get upgrade -y \
&& apt-get -y install -y $buildDeps --no-install-recommends \
&& python3 -m pip install -U pip \
&& pip3 install -r /home/shipyard/client_requirements.txt --no-cache-dir \
&& cd /home/shipyard/shipyard_client \
&& pip3 install . --use-pep517 --no-cache-dir \
&& pip3 install -r /home/shipyard/api_requirements.txt --no-cache-dir \
&& cd /home/shipyard/shipyard \
&& pip3 install . --use-pep517 --no-cache-dir \
&& apt-get purge -y --auto-remove $buildDeps \
&& apt-get autoremove -yqq --purge \
&& apt-get clean \
&& rm -rf \
/var/lib/apt/lists/* \
/tmp/* \
/var/tmp/* \
/usr/share/man \
/usr/share/doc \
/usr/share/doc-base \
&& python3 -m pip install -U pip
# Entrypoint
ENTRYPOINT ["/home/shipyard/entrypoint.sh"]
CMD ["server"]
# Set user to shipyard
USER shipyard

View File

@ -1,5 +1,5 @@
alembic
apache-airflow[crypto,celery,hive,hdfs,jdbc,postgres]==2.8.2
apache-airflow[crypto,celery,hive,hdfs,jdbc,postgres]==2.10.2
arrow
celery
Flask
@ -59,7 +59,7 @@ oslo.versionedobjects==3.1.0
# Airship dependencies
git+https://opendev.org/airship/deckhand.git@32e9950db405b5d1eb74da0c4e8df344a8638eff#egg=deckhand
git+https://opendev.org/airship/drydock.git@6b317dda0518e3366c9835ee99d9691ffba718eb#egg=drydock_provisioner&subdirectory=python
git+https://opendev.org/airship/armada.git@e85f0ccdeb93475aef2f2f4ce3da9f53a00309cd#egg=armada
git+https://opendev.org/airship/promenade.git@d21e3434f641e1f1e7400a44e77fccb5b87a2824#egg=promenade
git+https://opendev.org/airship/deckhand.git@be9f97b846b1edc6b74777e5e639aa9edce8cfa6#egg=deckhand
git+https://opendev.org/airship/drydock.git@146f1debbaf85f66e22cf8c546c3f343f0180ec9#egg=drydock_provisioner&subdirectory=python
git+https://opendev.org/airship/armada.git@edf8b5b88b726691f0dae23ec911e8d539c49211#egg=armada
git+https://opendev.org/airship/promenade.git@ac573b9fb53fd543172c50bbbcdfac3656fb8e66#egg=promenade

View File

@ -1,158 +1,164 @@
aiohttp==3.9.3
aiohappyeyeballs==2.4.0
aiohttp==3.10.5
aiosignal==1.3.1
alembic==1.13.1
alembic==1.13.2
amqp==5.2.0
anyio==4.3.0
apache-airflow==2.8.2
apache-airflow-providers-apache-hdfs==4.3.2
apache-airflow-providers-apache-hive==7.0.0
apache-airflow-providers-celery==3.6.0
apache-airflow-providers-common-io==1.3.0
apache-airflow-providers-common-sql==1.11.0
apache-airflow-providers-ftp==3.7.0
apache-airflow-providers-http==4.9.1
apache-airflow-providers-imap==3.5.0
apache-airflow-providers-jdbc==4.2.2
apache-airflow-providers-postgres==5.10.1
apache-airflow-providers-sqlite==3.7.1
apispec==6.4.0
argcomplete==3.2.2
Armada @ git+https://opendev.org/airship/armada.git@6f06dc09606e94bd6e7322a6d71c1ce5fdd33b0b
anyio==4.4.0
apache-airflow==2.10.2
apache-airflow-providers-apache-hdfs==4.5.0
apache-airflow-providers-apache-hive==8.2.0
apache-airflow-providers-celery==3.8.1
apache-airflow-providers-common-compat==1.2.0
apache-airflow-providers-common-io==1.4.0
apache-airflow-providers-common-sql==1.16.0
apache-airflow-providers-fab==1.3.0
apache-airflow-providers-ftp==3.11.0
apache-airflow-providers-http==4.13.0
apache-airflow-providers-imap==3.7.0
apache-airflow-providers-jdbc==4.5.0
apache-airflow-providers-postgres==5.12.0
apache-airflow-providers-smtp==1.8.0
apache-airflow-providers-sqlite==3.9.0
apispec==6.6.1
argcomplete==3.5.0
Armada @ git+https://opendev.org/airship/armada.git@edf8b5b88b726691f0dae23ec911e8d539c49211
arrow==1.3.0
asgiref==3.7.2
asgiref==3.8.1
async-timeout==4.0.3
attrs==23.2.0
attrs==24.2.0
autopage==0.5.2
Babel==2.14.0
backports.zoneinfo==0.2.1
babel==2.16.0
barbican==16.0.0
bcrypt==4.1.2
Beaker==1.12.1
bcrypt==4.2.0
Beaker==1.13.0
billiard==4.2.0
blinker==1.7.0
blinker==1.8.2
cachelib==0.9.0
cachetools==5.3.2
castellan==4.4.0
celery==5.3.6
certifi==2024.2.2
cffi==1.16.0
cachetools==5.5.0
castellan==5.1.1
celery==5.4.0
certifi==2024.8.30
cffi==1.17.1
charset-normalizer==3.3.2
click==8.1.7
click-didyoumean==0.3.0
click-didyoumean==0.3.1
click-plugins==1.1.1
click-repl==0.3.0
clickclick==20.10.2
cliff==4.6.0
cliff==4.7.0
cmd2==2.4.3
colorama==0.4.6
colorlog==4.8.0
colorlog==6.8.2
ConfigUpdater==3.2
connexion==2.14.2
cron-descriptor==1.4.3
croniter==2.0.1
cryptography==41.0.7
cron-descriptor==1.4.5
croniter==3.0.3
cryptography==42.0.8
debtcollector==3.0.0
Deckhand @ git+https://opendev.org/airship/deckhand.git@fd58230f6e31ede4925bab0325105eb5b05ad1a8
Deckhand @ git+https://opendev.org/airship/deckhand.git@be9f97b846b1edc6b74777e5e639aa9edce8cfa6
decorator==5.1.1
deepdiff==6.7.1
deepdiff==8.0.1
Deprecated==1.2.14
dill==0.3.1.1
dnspython==2.6.1
docopt==0.6.2
docutils==0.20.1
dogpile.cache==1.3.2
drydock-provisioner @ git+https://opendev.org/airship/drydock.git@816a4bbe366e2c1d58530986df05f99d7d9a7beb#subdirectory=python
email-validator==1.3.1
eventlet==0.35.2
exceptiongroup==1.2.0
docutils==0.16
dogpile.cache==1.3.3
drydock_provisioner @ git+https://opendev.org/airship/drydock.git@146f1debbaf85f66e22cf8c546c3f343f0180ec9#subdirectory=python
email_validator==2.2.0
eventlet==0.37.0
exceptiongroup==1.2.2
falcon==3.1.3
fastavro==1.9.4
fastavro==1.9.7
fasteners==0.19
fixtures==4.1.0
Flask==2.2.5
Flask-AppBuilder==4.3.11
Flask-AppBuilder==4.5.0
Flask-Babel==2.0.0
Flask-Caching==2.1.0
Flask-Caching==2.3.0
Flask-JWT-Extended==4.6.0
Flask-Limiter==3.5.1
Flask-Limiter==3.8.0
Flask-Login==0.6.3
Flask-Session==0.5.0
Flask-SQLAlchemy==2.5.1
Flask-WTF==1.2.1
flower==2.0.1
frozenlist==1.4.1
fsspec==2024.2.0
fsspec==2024.9.0
future==1.0.0
futurist==3.0.0
gitdb==4.0.11
GitPython==3.1.42
google-auth==2.28.1
google-re2==1.1
googleapis-common-protos==1.62.0
graphviz==0.20.1
greenlet==3.0.3
grpcio==1.62.0
GitPython==3.1.43
google-auth==2.34.0
google-re2==1.1.20240702
googleapis-common-protos==1.65.0
graphviz==0.20.3
greenlet==3.1.0
grpcio==1.66.1
gssapi==1.8.3
gunicorn==21.2.0
gunicorn==23.0.0
h11==0.14.0
hdfs==2.7.3
hmsclient==0.1.1
html5lib==0.9999999
httpcore==0.16.3
httpcore==1.0.5
httpexceptor==1.4.0
httpx==0.23.3
humanize==4.9.0
idna==3.6
httpx==0.27.0
humanize==4.10.0
idna==3.10
importlib-metadata==6.11.0
importlib-resources==5.13.0
importlib_resources==6.4.5
inflection==0.5.1
iso8601==2.1.0
itsdangerous==2.1.2
itsdangerous==2.2.0
JayDeBeApi==1.2.3
Jinja2==3.1.3
Jinja2==3.1.4
jmespath==0.10.0
JPype1==1.5.0
jsonpath-ng==1.6.1
jsonpickle==3.0.3
jsonschema==4.21.1
jsonpickle==3.3.0
jsonschema==4.23.0
jsonschema-specifications==2023.12.1
keystoneauth1==5.1.2
keystonemiddleware==10.2.0
kombu==5.3.5
krb5==0.5.1
kubernetes==29.0.0
kombu==5.4.1
krb5==0.6.0
kubernetes==30.1.0
lazy-object-proxy==1.10.0
ldap3==2.9.1
limits==3.9.0
limits==3.13.0
linkify-it-py==2.0.3
lockfile==0.12.2
logutils==0.3.5
Mako==1.3.2
Mako==1.3.5
markdown-it-py==3.0.0
MarkupSafe==2.1.5
marshmallow==3.20.2
marshmallow==3.22.0
marshmallow-oneofschema==3.1.1
marshmallow-sqlalchemy==0.26.1
mdit-py-plugins==0.4.0
marshmallow-sqlalchemy==0.28.2
mdit-py-plugins==0.4.2
mdurl==0.1.2
microversion-parse==1.0.1
methodtools==0.4.7
microversion-parse==2.0.0
mock==5.1.0
more-itertools==10.2.0
msgpack==1.0.7
multidict==6.0.5
netaddr==1.2.1
more-itertools==10.5.0
msgpack==1.1.0
multidict==6.1.0
netaddr==1.3.0
netifaces==0.11.0
networkx==3.1
numpy==1.24.4
networkx==3.3
numpy==1.26.4
oauthlib==3.2.2
opentelemetry-api==1.23.0
opentelemetry-exporter-otlp==1.23.0
opentelemetry-exporter-otlp-proto-common==1.23.0
opentelemetry-exporter-otlp-proto-grpc==1.23.0
opentelemetry-exporter-otlp-proto-http==1.23.0
opentelemetry-proto==1.23.0
opentelemetry-sdk==1.23.0
opentelemetry-semantic-conventions==0.44b0
opentelemetry-api==1.27.0
opentelemetry-exporter-otlp==1.27.0
opentelemetry-exporter-otlp-proto-common==1.27.0
opentelemetry-exporter-otlp-proto-grpc==1.27.0
opentelemetry-exporter-otlp-proto-http==1.27.0
opentelemetry-proto==1.27.0
opentelemetry-sdk==1.27.0
opentelemetry-semantic-conventions==0.48b0
ordered-set==4.1.0
orderly-set==5.2.2
os-service-types==1.7.0
oslo.cache==3.3.1
oslo.concurrency==5.1.1
@ -170,115 +176,116 @@ oslo.service==3.1.1
oslo.upgradecheck==2.1.1
oslo.utils==6.1.0
oslo.versionedobjects==3.1.0
packaging==23.2
pandas==2.0.3
Paste==3.7.1
packaging==24.1
pandas==2.1.4
Paste==3.10.1
PasteDeploy==3.1.0
PasteScript==3.4.0
PasteScript==3.6.0
pathspec==0.12.1
pbr==6.0.0
pbr==6.1.0
pecan==1.5.1
pendulum==3.0.0
pip==23.2.1
pkgutil_resolve_name==1.3.10
pluggy==1.4.0
pip==24.1
pluggy==1.5.0
ply==3.11
prettytable==3.10.0
prettytable==3.11.0
prison==0.2.1
promenade @ git+https://opendev.org/airship/promenade.git@14375e658bc06328042b1dc934eefcebf60210fd
promenade @ git+https://opendev.org/airship/promenade.git@ac573b9fb53fd543172c50bbbcdfac3656fb8e66
prometheus_client==0.20.0
prompt-toolkit==3.0.43
protobuf==4.25.3
psutil==5.9.8
prompt_toolkit==3.0.47
protobuf==4.25.4
psutil==6.0.0
psycopg2-binary==2.9.9
pure-sasl==0.6.2
py==1.11.0
pyarrow==14.0.2
pyasn1==0.5.1
pyasn1-modules==0.3.0
pyarrow==16.1.0
pyasn1==0.6.1
pyasn1_modules==0.4.0
pycadf==3.1.1
pycparser==2.21
Pygments==2.17.2
pycparser==2.22
Pygments==2.18.0
PyHive==0.7.0
PyJWT==2.8.0
PyJWT==2.9.0
pylibyaml==0.1.0
pyOpenSSL==24.0.0
pyparsing==3.1.1
pyperclip==1.8.2
pyspnego==0.10.2
pyOpenSSL==24.2.1
pyparsing==3.1.4
pyperclip==1.9.0
pyspnego==0.11.1
python-barbicanclient==5.5.0
python-daemon==3.0.1
python-dateutil==2.8.2
python-dateutil==2.9.0.post0
python-keystoneclient==5.1.0
python-memcached==1.62
python-mimeparse==1.6.0
python-nvd3==0.15.0
python-mimeparse==2.0.0
python-nvd3==0.16.0
python-slugify==8.0.4
python3-memcached==1.51
pytz==2024.1
PyYAML==6.0.1
referencing==0.33.0
regex==2023.12.25
pytz==2024.2
PyYAML==6.0.2
redis==5.0.8
referencing==0.35.1
regex==2024.9.11
repoze.lru==0.7
requests==2.31.0
requests-kerberos==0.14.0
requests==2.32.3
requests-kerberos==0.15.0
requests-oauthlib==1.3.1
requests-toolbelt==1.0.0
resolver==0.2.1
responses==0.25.0
responses==0.25.3
retry==0.9.2
rfc3339-validator==0.1.4
rfc3986==1.5.0
rich==13.7.0
rich-argparse==1.4.0
rfc3986==2.0.0
rich==13.8.1
rich-argparse==1.5.2
Routes==2.5.1
rpds-py==0.18.0
rpds-py==0.20.0
rsa==4.9
selector==0.10.1
setproctitle==1.3.3
setuptools==68.2.2
simplejson==3.19.2
setuptools==70.1.0
simplejson==3.19.3
six==1.16.0
smmap==5.0.1
sniffio==1.3.0
SQLAlchemy==1.4.51
sniffio==1.3.1
SQLAlchemy==1.4.54
SQLAlchemy-JSONField==1.0.2
sqlalchemy-migrate==0.13.0
SQLAlchemy-Utils==0.41.1
sqlparse==0.4.4
SQLAlchemy-Utils==0.41.2
sqlparse==0.5.1
statsd==4.0.1
stevedore==5.2.0
stevedore==5.3.0
tabulate==0.9.0
Tempita==0.5.2
tenacity==8.2.3
tenacity==8.5.0
termcolor==2.4.0
testresources==2.0.1
testscenarios==0.5.0
testtools==2.7.1
testtools==2.7.2
text-unidecode==1.3
thrift==0.16.0
thrift-sasl==0.4.3
tiddlyweb==2.4.3
time-machine==2.13.0
tornado==6.4
types-python-dateutil==2.8.19.20240106
typing_extensions==4.9.0
time-machine==2.15.0
tornado==6.4.1
types-python-dateutil==2.9.0.20240906
typing_extensions==4.12.2
tzdata==2024.1
uc-micro-py==1.0.3
ulid==1.1
unicodecsv==0.14.1
universal-pathlib==0.1.4
urllib3==1.26.18
uWSGI==2.0.24
universal_pathlib==0.2.5
urllib3==2.2.2
uWSGI==2.0.27
vine==5.1.0
wcwidth==0.2.13
WebOb==1.8.7
websocket-client==1.7.0
WebOb==1.8.8
websocket-client==1.8.0
Werkzeug==2.2.3
wheel==0.41.2
wheel==0.43.0
wirerope==0.4.7
wrapt==1.16.0
WTForms==3.1.2
xattr==0.10.1
yappi==1.6.0
yarl==1.9.4
zipp==3.17.0
yarl==1.11.1
zipp==3.20.2

View File

@ -19,20 +19,24 @@ import yaml
import kubernetes
import airflow
import pendulum
from shipyard_airflow.common.document_validators import \
document_validation_utils
from shipyard_airflow.common.document_validators import errors
from shipyard_airflow.plugins import deckhand_client_factory
from shipyard_airflow.plugins import deployment_status_operator
from shipyard_airflow.plugins import xcom_puller
from airflow import DAG
from airflow.models import TaskInstance, DagRun
from airflow.utils.dates import days_ago
from airflow.utils.state import State
from airflow.utils.types import DagRunType
@mock.patch.object(airflow.models.BaseOperator, '__init__')
# @mock.patch.object(airflow.models.BaseOperator, '__init__')
class TestDeploymentStatusOperator(TestCase):
def __init__(self, *args, **kwargs):
super(TestDeploymentStatusOperator, self).__init__(*args, **kwargs)
self.context = {'ti': None}
self.status = {'status': "doc"}
self.revision_id = "revision_id"
self.version = {'version': "doc"}
@ -42,33 +46,51 @@ class TestDeploymentStatusOperator(TestCase):
}
self.config_map_data = {'release': yaml.safe_dump(full_data)}
@mock.patch.object(xcom_puller.XcomPuller, 'get_concurrency_status',
return_value=True)
def setUp(self):
# Create a DAG for the test using pendulum
self.dag = DAG(dag_id="example_dag", start_date=pendulum.now('UTC').add(days=-1))
# Create a DagRun to associate with the TaskInstance
self.dag_run = DagRun(
dag_id=self.dag.dag_id,
execution_date=pendulum.now('UTC').add(days=-1), # Use pendulum for execution_date
run_id="manual__" + pendulum.now('UTC').to_iso8601_string(),
run_type=DagRunType.MANUAL,
state=State.RUNNING
)
# Create a TaskInstance with run_id
self.operator = deployment_status_operator.DeploymentStatusOperator(
shipyard_conf='conf', main_dag_name='name', dag=self.dag, task_id="task")
self.task_instance = TaskInstance(task=self.operator, run_id=self.dag_run.run_id)
self.task_instance.dag_run = self.dag_run # Associate TaskInstance with DagRun
self.task_instance.state = State.RUNNING
# Set the context to include TaskInstance
self.context = {'ti': self.task_instance}
@mock.patch.object(deployment_status_operator.XcomPuller, 'get_concurrency_status', return_value=True)
@mock.patch('shipyard_airflow.conf.config.parse_args')
@mock.patch.object(deployment_status_operator.DeploymentStatusOperator,
'_get_version_doc')
@mock.patch.object(deployment_status_operator.DeploymentStatusOperator,
'_get_status_and_revision')
@mock.patch.object(deployment_status_operator.DeploymentStatusOperator,
'_store_as_config_map')
@mock.patch.object(deployment_status_operator.DeploymentStatusOperator, '_get_version_doc')
@mock.patch.object(deployment_status_operator.DeploymentStatusOperator, '_get_status_and_revision')
@mock.patch.object(deployment_status_operator.DeploymentStatusOperator, '_store_as_config_map')
def test_execute(self,
store_as_config_map,
get_status_and_revision,
get_version_doc,
config_parse_args,
xcom_puller,
base_operator_init):
get_concurrency_status_mock):
# Mock return values for the methods
get_status_and_revision.return_value = (self.status, self.revision_id)
get_version_doc.return_value = self.version
operator = deployment_status_operator.DeploymentStatusOperator(
shipyard_conf='conf', main_dag_name='name')
operator.execute(self.context)
# Execute the operator
self.operator.execute(self.context)
assert config_parse_args.called
assert xcom_puller.called
assert get_concurrency_status_mock.called
assert get_status_and_revision.called
get_version_doc.assert_called_once_with(self.revision_id)
store_as_config_map.assert_called_once_with(self.config_map_data)
@ -78,12 +100,10 @@ class TestDeploymentStatusOperator(TestCase):
@mock.patch('shipyard_airflow.conf.config.parse_args')
def test_execute_concurrency_fail(self,
config_parse_args,
xcom_puller,
base_operator_init):
operator = deployment_status_operator.DeploymentStatusOperator(
shipyard_conf='conf', main_dag_name='name')
xcom_puller):
try:
operator.execute(self.context)
self.operator.execute(self.context)
except airflow.AirflowException as err:
assert str(err) == "Concurrency check did not pass, so the " \
"deployment status will not be updated"
@ -104,15 +124,13 @@ class TestDeploymentStatusOperator(TestCase):
create_cfg_map_object,
create_cfg_map,
patch_cfg_map,
load_k8s_config,
base_operator_init):
load_k8s_config):
data = 'data'
patch_cfg_map.side_effect = kubernetes.client.rest.ApiException(
status=404)
operator = deployment_status_operator.DeploymentStatusOperator(
shipyard_conf='conf', main_dag_name='name')
operator._store_as_config_map(data)
self.operator._store_as_config_map(data)
patch_cfg_map.assert_called_once_with(
config_parser.return_value,
config_parser.return_value,
@ -144,13 +162,11 @@ class TestDeploymentStatusOperator(TestCase):
create_cfg_map,
patch_cfg_map,
load_k8s_config,
get_deployment_status,
base_operator_init):
get_deployment_status):
data = 'data'
operator = deployment_status_operator.DeploymentStatusOperator(
shipyard_conf='conf', main_dag_name='name')
operator._store_as_config_map(data)
self.operator._store_as_config_map(data)
patch_cfg_map.assert_called_once_with(
config_parser.return_value,
config_parser.return_value,
@ -173,16 +189,14 @@ class TestDeploymentStatusOperator(TestCase):
config_parser,
create_cfg_map_object,
patch_cfg_map,
load_k8s_config,
base_operator_init):
load_k8s_config):
data = 'data'
patch_cfg_map.side_effect = kubernetes.client.rest.ApiException(
status=409)
operator = deployment_status_operator.DeploymentStatusOperator(
shipyard_conf='conf', main_dag_name='name')
try:
operator._store_as_config_map(data)
self.operator._store_as_config_map(data)
except kubernetes.client.rest.ApiException as err:
assert patch_cfg_map.side_effect == err
@ -206,11 +220,9 @@ class TestDeploymentStatusOperator(TestCase):
def test__get_version_doc(self,
config_parser,
get_unique_doc,
get_client,
base_operator_init):
operator = deployment_status_operator.DeploymentStatusOperator(
shipyard_conf='conf', main_dag_name='name')
result = operator._get_version_doc(self.revision_id)
get_client):
result = self.operator._get_version_doc(self.revision_id)
assert result == get_unique_doc.return_value
assert get_client.called
@ -229,13 +241,11 @@ class TestDeploymentStatusOperator(TestCase):
def test__get_version_doc_does_not_exist(self,
config_parser,
get_unique_doc,
get_client,
base_operator_init):
get_client):
get_unique_doc.side_effect = errors.DocumentNotFoundError()
operator = deployment_status_operator.DeploymentStatusOperator(
shipyard_conf='conf', main_dag_name='name')
result = operator._get_version_doc(self.revision_id)
result = self.operator._get_version_doc(self.revision_id)
assert result == {}
assert get_client.called
@ -247,21 +257,18 @@ class TestDeploymentStatusOperator(TestCase):
@mock.patch('shipyard_airflow.plugins.deployment_status_operator'
'.get_deployment_status')
def test__get_status_and_revision(self,
get_deployment_status,
base_operator_init):
operator = deployment_status_operator.DeploymentStatusOperator(
shipyard_conf='conf', main_dag_name='name')
get_deployment_status):
action = {'committed_rev_id': self.revision_id}
operator.xcom_puller = mock.MagicMock()
operator.xcom_puller.get_action_info = mock.MagicMock()
operator.xcom_puller.get_action_info.return_value = action
self.operator.xcom_puller = mock.MagicMock()
self.operator.xcom_puller.get_action_info = mock.MagicMock()
self.operator.xcom_puller.get_action_info.return_value = action
status_and_revision = operator._get_status_and_revision()
status_and_revision = self.operator._get_status_and_revision()
get_deployment_status.assert_called_once_with(
action,
force_completed=operator.force_completed)
force_completed=self.operator.force_completed)
assert status_and_revision == (get_deployment_status.return_value,
self.revision_id)

View File

@ -1,6 +1,6 @@
[tox]
skipsdist=True
envlist = py38, pep8, bandit
envlist = py310, pep8, bandit
[testenv]
setenv=
@ -17,20 +17,30 @@ allowlist_externals=
sh
deps=
-r{toxinidir}/requirements-direct.txt
-c https://raw.githubusercontent.com/apache/airflow/constraints-2.8.2/constraints-3.8.txt
-c https://raw.githubusercontent.com/apache/airflow/constraints-2.10.2/constraints-3.10.txt
commands=
rm -f {toxinidir}/requirements-frozen.txt
sh -c "pip freeze --all | grep -vE 'shipyard_airflow|pyinotify|pkg-resources' > requirements-frozen.txt"
[testenv:py38]
[testenv:safety]
basepython = python3
deps =
safety
allowlist_externals=
safety
commands =
safety check -r {toxinidir}/requirements-frozen.txt --full-report
[testenv:py310]
skipsdist=True
setenv=
SLUGIFY_USES_TEXT_UNIDECODE=yes
PYTHONWARNINGS=ignore::DeprecationWarning,ignore::FutureWarning
basepython=python3.8
basepython=python3.10
allowlist_externals=
bash
airflow
../../../tools/wait_for_dag.sh
commands =
bash -c "rm -rf $HOME/airflow"
airflow version
@ -39,9 +49,14 @@ commands =
airflow info
airflow dags list
airflow dags list-import-errors
bash -c "nohup airflow scheduler >/dev/null 2>&1 &"
../../../tools/wait_for_dag.sh
airflow dags list
airflow dags unpause example_bash_operator
airflow tasks test example_bash_operator runme_0
airflow dags backfill example_bash_operator -s 2018-01-01 -e 2018-01-02
airflow tasks run example_bash_operator runme_0 2018-01-01
airflow tasks states-for-dag-run example_bash_operator backfill__2018-01-01T00:00:00+00:00
airflow dags state example_bash_operator 2018-01-01
pytest {posargs} -vv
@ -53,6 +68,7 @@ setenv=
allowlist_externals=
bash
airflow
../../../tools/wait_for_dag.sh
commands =
bash -c "rm -rf $HOME/airflow"
airflow version
@ -61,9 +77,15 @@ commands =
airflow info
airflow dags list
airflow dags list-import-errors
bash -c "nohup airflow scheduler >/dev/null 2>&1 &"
../../../tools/wait_for_dag.sh
airflow dags list
airflow dags unpause example_bash_operator
airflow tasks test example_bash_operator runme_0
airflow dags backfill example_bash_operator -s 2018-01-01 -e 2018-01-02
airflow tasks run example_bash_operator runme_0 2018-01-01
airflow tasks states-for-dag-run example_bash_operator backfill__2018-01-02T00:00:00+00:00
airflow dags state example_bash_operator 2018-01-01
pytest \
{posargs} \
--cov-branch \

View File

@ -1,43 +1,41 @@
arrow==1.3.0
certifi==2024.2.2
certifi==2024.8.30
charset-normalizer==3.3.2
click==8.1.7
click-default-group==1.2.4
debtcollector==3.0.0
Flask==2.2.5
idna==3.6
importlib-metadata==6.11.0
idna==3.10
iso8601==2.1.0
itsdangerous==2.1.2
Jinja2==3.1.3
itsdangerous==2.2.0
Jinja2==3.1.4
keystoneauth1==5.1.2
MarkupSafe==2.1.5
msgpack==1.0.7
netaddr==1.2.1
msgpack==1.1.0
netaddr==1.3.0
netifaces==0.11.0
os-service-types==1.7.0
oslo.config==9.1.1
oslo.i18n==6.0.0
oslo.serialization==5.1.1
oslo.utils==6.1.0
packaging==23.2
pbr==6.0.0
pip==23.2.1
packaging==24.1
pbr==6.1.0
pip==24.1
PTable==0.9.2
pylibyaml==0.1.0
pyparsing==3.1.1
python-dateutil==2.8.2
pyparsing==3.1.4
python-dateutil==2.9.0.post0
python-keystoneclient==5.1.0
pytz==2024.1
PyYAML==6.0.1
requests==2.31.0
rfc3986==1.5.0
setuptools==68.2.2
pytz==2024.2
PyYAML==6.0.2
requests==2.32.3
rfc3986==2.0.0
setuptools==70.1.0
six==1.16.0
stevedore==5.2.0
types-python-dateutil==2.8.19.20240106
urllib3==1.26.18
stevedore==5.3.0
types-python-dateutil==2.9.0.20240906
urllib3==2.2.2
Werkzeug==2.2.3
wheel==0.41.2
wheel==0.43.0
wrapt==1.16.0
zipp==3.17.0

View File

@ -1,6 +1,6 @@
[tox]
skipsdist=True
envlist = py38, pep8, bandit
envlist = py310, pep8, bandit
[testenv]
setenv=
@ -18,12 +18,22 @@ allowlist_externals=
sh
deps=
-r{toxinidir}/requirements-direct.txt
-c https://raw.githubusercontent.com/apache/airflow/constraints-2.8.2/constraints-3.8.txt
-c https://raw.githubusercontent.com/apache/airflow/constraints-2.10.2/constraints-3.10.txt
commands=
rm -f {toxinidir}/requirements-frozen.txt
sh -c "pip freeze --all | grep -vE 'shipyard_airflow|pyinotify|pkg-resources' > requirements-frozen.txt"
[testenv:py38]
[testenv:safety]
basepython = python3
deps =
safety
allowlist_externals=
safety
commands =
safety check -r {toxinidir}/requirements-frozen.txt --full-report
[testenv:py310]
skipsdist=True
commands =
pytest \

View File

@ -32,6 +32,7 @@ fi
if [ "${USE_PROXY}" == "true" ]; then
TEST_RESP="$(docker run \
-p 8080:8080 \
--rm \
--env HTTP_PROXY="${PROXY}" \
--env HTTPS_PROXY="${PROXY}" \
--env NO_PROXY="${NO_PROXY}" \
@ -40,12 +41,11 @@ if [ "${USE_PROXY}" == "true" ]; then
else
TEST_RESP="$(docker run \
-p 8080:8080 \
--rm \
--name airflow_test ${IMAGE} \
quicktest)"
fi
docker stop airflow_test
docker rm airflow_test
if [ ${TEST_RESP:(-7)} == "success" ]; then

View File

@ -0,0 +1,31 @@
# Licensed 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.
---
- hosts: all
tasks:
- name: Checkout treasuremap ref
shell: |
set -xe;
: "${TREASUREMAP_REF:=v1.9}"
cd ../treasuremap
git fetch https://review.opendev.org/airship/treasuremap ${TREASUREMAP_REF} && git checkout FETCH_HEAD
args:
chdir: "{{ zuul.project.src_dir }}"
environment:
TREASUREMAP_REF: "{{ treasuremap_ref }}"
...

View File

@ -15,4 +15,7 @@
roles:
- bindep
- start-zuul-console
- role: add-authorized-keys
public_keys:
- public_key: ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABgQDA7eM8WFJrqQmki8rR0O3QBHyl8xq42jb1RduwuRwjWoGYJI5cX7Fx+7VR4A9ITCoiqxKS8DMfgKbt5jKC6SmvMALULZsnYlthB34KywurgxsW6fgp68DHWQ7J4CCBhoIpl0W3JW7s6b0vHLhab59r0E+AYemBVuWUqbFEy8nDAHcQv1S/2o1udhmljIN7c2ogO4KAJ7Lge0BoIP9ps4u6AVwyQZixp4anU9DHGNA/UQj4M5UyuALj5buEAuATBe9Vqj4sOvZjObPJAGPUrNRrGEWAFk+lSZHRzKXo0eeWtPqoh5UN9UDb5Pocg1krncMIZwjHKovlD1z/O1y91aY5LM1wxm/7aaIiX8eCihyVZaOuDCLF7WDT2SMs7ABcotX2MDtVQTrNNV3MmMAScFNDflzPKszd7cdjLl6PBq8bvPxmCkLmnitPTGOoh9d8i+JlbINvgx1pguYrpeciIyreCO1rjTW3MgB0tyoMEa31V+7HrauBMeNnE68YTqLTIB0= smarkin@mirantis.com
...

View File

@ -19,7 +19,7 @@ osh_params:
container_distro_version: focal
# feature_gates:
site: airskiff
HELM_ARTIFACT_URL: https://get.helm.sh/helm-v3.13.2-linux-amd64.tar.gz
HELM_ARTIFACT_URL: https://get.helm.sh/helm-v3.15.4-linux-amd64.tar.gz
HTK_COMMIT: cfff60ec10a6c386f38db79bb9f59a552c2b032f
OSH_INFRA_COMMIT: cfff60ec10a6c386f38db79bb9f59a552c2b032f
OSH_COMMIT: 2d9457e34ca4200ed631466bd87569b0214c92e7

View File

@ -35,7 +35,7 @@
FEATURE_GATES: "{{ osh_params.feature_gates | default('') }}"
RUN_HELM_TESTS: "{{ run_helm_tests | default('yes') }}"
PL_SITE: "{{ site | default('airskiff') }}"
HELM_ARTIFACT_URL: "{{ HELM_ARTIFACT_URL | default('https://get.helm.sh/helm-v3.13.2-linux-amd64.tar.gz') }}"
HELM_ARTIFACT_URL: "{{ HELM_ARTIFACT_URL | default('https://get.helm.sh/helm-v3.15.4-linux-amd64.tar.gz') }}"
HTK_COMMIT: "{{ HTK_COMMIT | default('cfff60ec10a6c386f38db79bb9f59a552c2b032f') }}"
OSH_INFRA_COMMIT: "{{ OSH_INFRA_COMMIT | default('cfff60ec10a6c386f38db79bb9f59a552c2b032f') }}"
OSH_COMMIT: "{{ OSH_COMMIT | default('2d9457e34ca4200ed631466bd87569b0214c92e7') }}"

View File

@ -19,7 +19,7 @@ osh_params:
container_distro_version: focal
# feature_gates:
site: airskiff
HELM_ARTIFACT_URL: https://get.helm.sh/helm-v3.13.2-linux-amd64.tar.gz
HELM_ARTIFACT_URL: https://get.helm.sh/helm-v3.15.4-linux-amd64.tar.gz
HTK_COMMIT: cfff60ec10a6c386f38db79bb9f59a552c2b032f
OSH_INFRA_COMMIT: cfff60ec10a6c386f38db79bb9f59a552c2b032f
OSH_COMMIT: 2d9457e34ca4200ed631466bd87569b0214c92e7

View File

@ -32,7 +32,7 @@
FEATURE_GATES: "{{ osh_params.feature_gates | default('') }}"
RUN_HELM_TESTS: "{{ run_helm_tests | default('yes') }}"
PL_SITE: "{{ site | default('airskiff') }}"
HELM_ARTIFACT_URL: "{{ HELM_ARTIFACT_URL | default('https://get.helm.sh/helm-v3.13.2-linux-amd64.tar.gz') }}"
HELM_ARTIFACT_URL: "{{ HELM_ARTIFACT_URL | default('https://get.helm.sh/helm-v3.15.4-linux-amd64.tar.gz') }}"
HTK_COMMIT: "{{ HTK_COMMIT | default('cfff60ec10a6c386f38db79bb9f59a552c2b032f') }}"
OSH_INFRA_COMMIT: "{{ OSH_INFRA_COMMIT | default('cfff60ec10a6c386f38db79bb9f59a552c2b032f') }}"
OSH_COMMIT: "{{ OSH_COMMIT | default('2d9457e34ca4200ed631466bd87569b0214c92e7') }}"

View File

@ -17,7 +17,7 @@
set -x
HELM=$1
HELM_ARTIFACT_URL=${HELM_ARTIFACT_URL:-"https://get.helm.sh/helm-v3.12.2-linux-amd64.tar.gz"}
HELM_ARTIFACT_URL=${HELM_ARTIFACT_URL:-"https://get.helm.sh/helm-v3.15.4-linux-amd64.tar.gz"}
function install_helm_binary {

10
tools/wait_for_dag.sh Executable file
View File

@ -0,0 +1,10 @@
#!/bin/bash
while true; do
is_active=$(airflow dags details example_bash_operator -o plain | grep is_active | awk '{print $2}')
if [ "$is_active" == "True" ]; then
echo "DAG example_bash_operator is active."
break
fi
echo "Waiting for DAG example_bash_operator to become active..."
sleep 10
done

35
tox.ini
View File

@ -16,6 +16,27 @@ passenv=
[testenv:venv]
commands = {posargs}
[testenv:airflow_safety]
basepython = python3
deps =
safety
allowlist_externals=
safety
tox
commands =
tox -c {toxinidir}/src/bin/shipyard_airflow/tox.ini -e safety
[testenv:shipyard_safety]
basepython = python3
deps =
safety
allowlist_externals=
safety
tox
commands =
tox -c {toxinidir}/src/bin/shipyard_client/tox.ini -e safety
# Please use `make docs` instead
[testenv:docs]
allowlist_externals=
@ -36,22 +57,22 @@ commands=
tox -c {toxinidir}/src/bin/shipyard_airflow/tox.ini
tox -c {toxinidir}/src/bin/shipyard_client/tox.ini
[testenv:py38]
deps =
tox<=4.0.0
[testenv:py310]
; deps =
; tox
allowlist_externals=
tox
bash
commands=
tox -c {toxinidir}/src/bin/shipyard_airflow/tox.ini -e py38
tox -c {toxinidir}/src/bin/shipyard_client/tox.ini -e py38
tox -c {toxinidir}/src/bin/shipyard_airflow/tox.ini -e py310
tox -c {toxinidir}/src/bin/shipyard_client/tox.ini -e py310
tox -c {toxinidir}/src/bin/shipyard_airflow/tox.ini -e gen_all
bash -c "cp {toxinidir}/src/bin/shipyard_airflow/etc/shipyard/policy.yaml.sample {toxinidir}/doc/source/_static/shipyard.policy.yaml.sample"
bash -c "cp {toxinidir}/src/bin/shipyard_airflow/etc/shipyard/shipyard.conf.sample {toxinidir}/doc/source/_static/shipyard.conf.sample"
[testenv:cover]
deps =
tox<=4.0.0
; deps =
; tox
allowlist_externals=
tox
sh