Add configurable AMQP port to endpoint #6195
Workflow file for this run
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: CI/CD | |
on: | |
push: | |
branches: | |
- "*" | |
tags: | |
- "*" | |
pull_request: | |
jobs: | |
lint: | |
runs-on: ubuntu-latest | |
steps: | |
- uses: actions/checkout@v4 | |
- uses: actions/setup-python@v4 | |
- name: install requirements | |
run: | | |
python -m pip install -U pip setuptools wheel | |
python -m pip install pre-commit tox | |
- name: run pre-commit | |
run: pre-commit run -a | |
- name: mypy (sdk) | |
run: | | |
cd compute_sdk | |
tox -e mypy | |
- name: mypy (endpoint) | |
run: | | |
cd compute_endpoint | |
tox -e mypy | |
# ensure docs can build, imitating the RTD build as best we can | |
check-docs: | |
runs-on: ubuntu-latest | |
steps: | |
- uses: actions/checkout@v4 | |
- uses: actions/setup-python@v4 | |
with: | |
python-version: "3.11" | |
- name: build docs | |
run: make docs | |
safety-check-endpoint: | |
runs-on: ubuntu-latest | |
steps: | |
- uses: actions/checkout@v4 | |
- uses: actions/setup-python@v4 | |
with: | |
python-version: "3.11" | |
- name: install requirements | |
run: | | |
python -m pip install --upgrade setuptools | |
python -m pip install './compute_sdk' | |
python -m pip install './compute_endpoint' | |
python -m pip install safety | |
- name: run safety check | |
run: safety check | |
test-sdk: | |
strategy: | |
matrix: | |
os: [ubuntu-latest] | |
python-version: ["3.7", "3.8", "3.9", "3.10", "3.11"] | |
name: "Test SDK on py${{ matrix.python-version }} x ${{ matrix.os }} " | |
runs-on: ${{ matrix.os }} | |
steps: | |
- uses: actions/checkout@v4 | |
- uses: actions/setup-python@v4 | |
with: | |
python-version: ${{ matrix.python-version }} | |
- run: python -m pip install -U pip setuptools | |
- run: python -m pip install tox | |
- name: run tests | |
run: | | |
cd compute_sdk | |
tox -e py | |
test-endpoint: | |
runs-on: ubuntu-latest | |
services: | |
rabbitmq: | |
image: rabbitmq | |
ports: | |
- 5672:5672 | |
# needed because the rabbitmq container does not provide a healthcheck | |
options: --health-cmd "rabbitmq-diagnostics -q check_running && rabbitmq-diagnostics -q check_virtual_hosts && rabbitmq-diagnostics -q check_port_connectivity" --health-interval 10s --health-timeout 5s --health-retries 5 | |
strategy: | |
matrix: | |
python-version: ["3.8", "3.9", "3.10", "3.11"] | |
name: "Test Endpoint on py${{ matrix.python-version }} x ${{ matrix.os }} " | |
steps: | |
- uses: actions/checkout@v4 | |
- uses: actions/setup-python@v4 | |
with: | |
python-version: ${{ matrix.python-version }} | |
- run: python -m pip install -U pip setuptools | |
- run: python -m pip install tox | |
- name: run tests | |
run: | | |
cd compute_endpoint | |
tox -e py -- --log-cli-level=ERROR | |
- name: Collect Docker Logs | |
if: failure() | |
uses: jwalton/gh-docker-logs@v2.2.1 | |
publish: | |
# only trigger on pushes to the main repo (not forks, and not PRs) | |
if: ${{ github.repository == 'funcx-faas/funcX' && github.event_name == 'push' }} | |
needs: | |
- lint | |
- test-sdk | |
- test-endpoint | |
runs-on: ubuntu-latest | |
strategy: | |
matrix: | |
python: ["3.8", "3.9", "3.10", "3.11"] | |
steps: | |
- uses: actions/checkout@master | |
- name: Extract tag name | |
shell: bash | |
run: echo "##[set-output name=imagetag;]$(echo ${GITHUB_REF##*/})" | |
id: extract_tag_name | |
- name: Build globus-compute-endpoint Image for selected python version | |
uses: elgohr/Publish-Docker-Github-Action@master | |
env: | |
PYTHON_VERSION: ${{ matrix.python }} | |
with: | |
dockerfile: Dockerfile-endpoint | |
name: funcx/kube-endpoint:${{ steps.extract_tag_name.outputs.imagetag }}-${{ matrix.python }} | |
username: ${{ secrets.DOCKER_USERNAME }} | |
password: ${{ secrets.DOCKER_PASSWORD }} | |
buildargs: PYTHON_VERSION |