Skip to content

Direct registration of files to database #54

Direct registration of files to database

Direct registration of files to database #54

Workflow file for this run

# On push: build latest images
name: CI
on:
push:
branches: [ master ]
tags:
- "v?[0-9]+.[0-9]+.[0-9]+*"
paths:
- '.github/**'
- '**.rs'
- 'Cargo.*'
- 'justfile'
- 'Dockerfile'
- 'docker-compose.yml'
- 'run.sh'
pull_request:
branches: [ master ]
jobs:
test:
name: Test
runs-on: ubuntu-22.04
steps:
- uses: actions/checkout@v4
- uses: FNNDSC/miniChRIS-docker@master
- uses: taiki-e/install-action@v2
with:
tool: just
- name: Start Orthanc
run: docker compose up -d orthanc
- name: Download example data
run: docker compose up get-data
- name: Compile test binary
run: just test -- --no-run
- name: Integration test
run: just test
build:
name: Build
runs-on: ubuntu-22.04
steps:
- name: Decide image tags
id: info
shell: python
run: |
import os
import itertools
def join_tag(t):
registry, repo, tag = t
return f'{registry}/{repo}:{tag}'.lower()
registries = ['docker.io', 'ghcr.io']
repos = ['${{ github.repository }}'.lower()]
if '${{ github.ref_type }}' == 'branch':
tags = ['latest']
elif '${{ github.ref_type }}' == 'tag':
tag = '${{ github.ref_name }}'
version = tag[1:] if tag.startswith('v') else tag
tags = ['latest', version]
else:
tags = []
product = itertools.product(registries, repos, tags)
tags_csv = ','.join(map(join_tag, product))
outputs = {
'tags_csv' : tags_csv,
}
with open(os.environ['GITHUB_OUTPUT'], 'a') as out:
for k, v in outputs.items():
out.write(f'{k}={v}\n')
- uses: FNNDSC/miniChRIS-docker@master # need to run CUBE for sqlx to do compile-time validation of SQL queries
- uses: docker/setup-buildx-action@v3
with:
# builder needs to be able to see the Postgres database running in the minichris-local network,
# so that the sqlx crate can do compile-time verification of SQL commands.
driver-opts: network=minichris-local
- name: Login to DockerHub
if: github.event_name == 'push' || github.event_name == 'release'
id: dockerhub_login
uses: docker/login-action@v3
with:
username: ${{ secrets.DOCKERHUB_USERNAME }}
password: ${{ secrets.DOCKERHUB_PASSWORD }}
- name: Login to GitHub Container Registry
if: github.event_name == 'push' || github.event_name == 'release'
uses: docker/login-action@v3
with:
registry: ghcr.io
username: ${{ github.repository_owner }}
password: ${{ secrets.GITHUB_TOKEN }}
- name: Get database IP
id: read-network
# sqlx crate needs the environment variable DATABASE_URL to be set for compile-time validation of SQL commands.
# For unknown reasons, docker container service name DNS doesn't work inside the build, so we need to get the
# database container's IP address.
run: |
ip_address_with_subnet=$(docker network inspect minichris-local --format '{{ range .Containers }}{{ if (eq .Name "minichris-docker-db-1") }}{{ .IPv4Address }}{{ end }}{{ end }}')
ip_address="${ip_address%/*}"
echo "DATABASE_URL=postgresql://chris:chris1234@$ip_address:5432/chris" >> "$GITHUB_OUTPUT"
- name: Build image
uses: docker/build-push-action@v5
id: docker_build
with:
tags: ${{ steps.info.outputs.tags_csv }}
push: true
cache-from: type=gha
cache-to: type=gha,mode=max
build-args: DATABASE_URL=${{ steps.read-network.outputs.DATABASE_URL }}