DM-47333: Logger.exception() missing 1 required positional argument #1221
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: "Build and test service" | |
on: | |
push: | |
branches: | |
- main | |
- 'releases/**' | |
paths: | |
- '.github/workflows/build-service.yml' | |
- 'config/**' | |
- 'pipelines/**' | |
- 'python/activator/**' | |
- 'tests/**' | |
- 'Dockerfile' | |
pull_request: | |
paths: | |
- '.github/workflows/build-service.yml' | |
- 'config/**' | |
- 'pipelines/**' | |
- 'python/activator/**' | |
- 'tests/**' | |
- 'Dockerfile' | |
workflow_dispatch: | |
permissions: | |
packages: write | |
env: | |
IMAGE_NAME: prompt-service | |
BASE_IMAGE: ghcr.io/${{ github.repository_owner }}/prompt-base | |
# This is a bracketed, comma-separated list of double-quoted base container | |
# tags that will be used to build service containers on each branch | |
# (including "main"). Typically, any tags listed beyond "latest" would be | |
# relatively stable Pipelines containers that are needed to avoid issues with | |
# the "latest" version; they would remain in this list until "latest" becomes | |
# usable for all building and testing. | |
BASE_TAG_LIST: '["latest"]' | |
jobs: | |
matrix-gen: | |
# This job exists solely because fromJSON() cannot directly accept | |
# env.BASE_TAG_LIST for some reason. | |
runs-on: ubuntu-latest | |
outputs: | |
matrix: ${{ steps.set-matrix.outputs.matrix }} | |
steps: | |
- id: set-matrix | |
run: echo "matrix=${BASE_TAG_LIST}" >> $GITHUB_OUTPUT | |
# Do testing and building in separate jobs to keep total disk usage down | |
test-service: | |
needs: matrix-gen | |
strategy: | |
matrix: | |
baseTag: ${{ fromJSON(needs.matrix-gen.outputs.matrix) }} | |
name: Test service | |
runs-on: ubuntu-latest | |
env: | |
BASE_TAG: ${{ matrix.baseTag }} | |
steps: | |
- name: Checkout code | |
uses: actions/checkout@v4 | |
- name: Fix permissions | |
run: chmod -R a+rwX $GITHUB_WORKSPACE | |
- name: Login to GitHub Container Registry | |
uses: docker/login-action@v3 | |
with: | |
registry: ghcr.io | |
username: ${{ github.actor }} | |
password: ${{ secrets.GITHUB_TOKEN }} | |
- name: Run tests | |
run: | | |
docker run \ | |
-v $GITHUB_WORKSPACE:/home/lsst/prompt_processing \ | |
"$BASE_IMAGE":"$BASE_TAG" \ | |
bash -c ' | |
cd /home/lsst/prompt_processing | |
source /opt/lsst/software/stack/loadLSST.bash | |
setup -r . | |
# Fix permissions; arg must be absolute path. | |
git config --global --add safe.directory /home/lsst/prompt_processing | |
scons' | |
update-service-image: | |
name: Update service image | |
needs: | |
- matrix-gen | |
- test-service | |
runs-on: ubuntu-latest | |
strategy: | |
matrix: | |
baseTag: ${{ fromJSON(needs.matrix-gen.outputs.matrix) }} | |
env: | |
BASE_TAG: ${{ matrix.baseTag }} | |
steps: | |
- name: Checkout code | |
uses: actions/checkout@v4 | |
- name: Login to GitHub Container Registry | |
uses: docker/login-action@v3 | |
with: | |
registry: ghcr.io | |
username: ${{ github.actor }} | |
password: ${{ secrets.GITHUB_TOKEN }} | |
- name: Determine eups tag | |
run: | | |
docker run "$BASE_IMAGE":"$BASE_TAG" bash -c "cat conda/envs/lsst-scipipe-*/share/eups/ups_db/global.tags" > eups.tag || docker run "$BASE_IMAGE":"$BASE_TAG" bash -c "cat stack/miniconda*/ups_db/global.tags" > eups.tag || echo "Unknown" > eups.tag | |
echo "Eups tag = $(< eups.tag)" | |
- name: Build image | |
run: | | |
docker build . -f Dockerfile \ | |
--build-arg "BASE_TAG=$BASE_TAG" \ | |
--tag $IMAGE_NAME \ | |
--label "runnumber=${GITHUB_RUN_ID}" \ | |
--label "basetag=${BASE_TAG}" \ | |
--label "eupstag=$(< eups.tag)" | |
- name: Push image to container registries | |
run: | | |
BRANCH=$(echo "${{ github.ref }}" | sed -e 's,.*/\(.*\),\1,') | |
[ "$BRANCH" == "merge" ] && BRANCH=$(echo "${{ github.head_ref }}" | sed -e 's,.*/\(.*\),\1,') | |
for IMAGE_ID in "ghcr.io/${{ github.repository_owner }}/$IMAGE_NAME"; do | |
if [ "$BRANCH" == "main" ]; then | |
VERSION="$BASE_TAG" | |
else | |
VERSION="${BRANCH}-$BASE_TAG" | |
fi | |
echo IMAGE_ID=$IMAGE_ID | |
echo VERSION=$VERSION | |
docker tag $IMAGE_NAME $IMAGE_ID:$VERSION | |
docker push $IMAGE_ID:$VERSION | |
EUPS_TAG=$(< eups.tag) | |
if [ "$EUPS_TAG" != "Unknown" ] && [ "$BASE_TAG" != "$EUPS_TAG" ]; then | |
if [ "$BRANCH" == "main" ]; then | |
VERSION="$EUPS_TAG" | |
else | |
VERSION="${BRANCH}-$EUPS_TAG" | |
fi | |
echo VERSION=$VERSION | |
docker tag $IMAGE_NAME $IMAGE_ID:$VERSION | |
docker push $IMAGE_ID:$VERSION | |
fi | |
done |