Compare commits

..

7 Commits

7 changed files with 47 additions and 40 deletions

View File

@@ -16,14 +16,8 @@ jobs:
- db: postgres - db: postgres
variant: base variant: base
env:
POSTGRES_USER: postgres
POSTGRES_PASSWORD: postgres
POSTGRES_DB: postgres
POSTGRES_PORT: 5432
steps: steps:
- uses: actions/checkout@v4 - uses: actions/checkout@v6
- uses: jdx/mise-action@v3 - uses: jdx/mise-action@v3
- name: Test - name: Test
@@ -46,7 +40,7 @@ jobs:
variant: base variant: base
steps: steps:
- uses: actions/checkout@v4 - uses: actions/checkout@v6
- uses: jdx/mise-action@v3 - uses: jdx/mise-action@v3
- name: Login to registry - name: Login to registry

View File

@@ -1,53 +1,64 @@
set shell := ["bash", "-euo", "pipefail", "-c"] set shell := ["bash", "-euo", "pipefail", "-c"]
set dotenv-load := true set dotenv-load := true
DATABASE := env("DATABASE", "postgres") SERVICE := env("SERVICE", "postgres")
VARIANT := env("VARIANT", "base") VARIANT := env("VARIANT", "base")
_default: _default:
@echo "Default env variables:" #!/usr/bin/env bash
@echo " DATABASE: {{DATABASE}}" echo "Default env variables:"
@echo " VARIANT: {{VARIANT}}" echo " SERVICE: {{SERVICE}}"
@just --list echo " VARIANT: {{VARIANT}}"
just --list
### Container Management ### ### Container Management ###
# Start the database and wait until it's healthy # Start the service and wait until it's healthy
up db=DATABASE variant=VARIANT: up service=SERVICE variant=VARIANT:
just build {{db}} {{variant}} just build {{service}} {{variant}}
docker compose -f {{db}}-{{variant}}/compose.yml up -d --wait docker compose -f {{service}}/{{variant}}/compose.yml up -d --wait
# Stop the database container but preserve data volumes # Stop the service container but preserve data volumes
down db=DATABASE variant=VARIANT: down service=SERVICE variant=VARIANT:
docker compose -f {{db}}-{{variant}}/compose.yml down docker compose -f {{service}}/{{variant}}/compose.yml down
# Remove containers and data volumes but preserve images # Remove containers and data volumes but preserve images
down-volumes db=DATABASE variant=VARIANT: down-volumes service=SERVICE variant=VARIANT:
docker compose -f {{db}}-{{variant}}/compose.yml down -v docker compose -f {{service}}/{{variant}}/compose.yml down -v
# Remove containers, volumes, and images # Remove containers, volumes, and images
down-all db=DATABASE variant=VARIANT: down-all service=SERVICE variant=VARIANT:
docker compose -f {{db}}-{{variant}}/compose.yml down -v --rmi local docker compose -f {{service}}/{{variant}}/compose.yml down -v --rmi all
### Shell Access ###
# Access a bash shell inside the running container
bash service=SERVICE variant=VARIANT:
docker compose -f {{service}}/{{variant}}/compose.yml exec {{service}} bash
# Access a sh shell inside the running container
sh service=SERVICE variant=VARIANT:
docker compose -f {{service}}/{{variant}}/compose.yml exec {{service}} sh
### Build & Publish ### ### Build & Publish ###
# Build image locally # Build image locally
build db=DATABASE variant=VARIANT: build service=SERVICE variant=VARIANT:
#!/usr/bin/env bash #!/usr/bin/env bash
IMAGE="db-{{db}}" IMAGE="db-{{service}}"
VERSION="{{variant}}" VERSION="{{variant}}"
echo "docker build -f {{db}}-{{variant}}/Dockerfile -t ${IMAGE}:${VERSION} {{db}}-{{variant}}" echo "docker build -f {{service}}/{{variant}}/Dockerfile -t ${IMAGE}:${VERSION} {{service}}/{{variant}}"
docker build -f {{db}}-{{variant}}/Dockerfile -t ${IMAGE}:${VERSION} {{db}}-{{variant}} docker build -f {{service}}/{{variant}}/Dockerfile -t ${IMAGE}:${VERSION} {{service}}/{{variant}}
# Build and push image to registry # Build and push image to registry
push db=DATABASE variant=VARIANT: push service=SERVICE variant=VARIANT:
#!/usr/bin/env bash #!/usr/bin/env bash
PREFIX=${REGISTRY_URL:+${REGISTRY_URL}/} PREFIX=${REGISTRY_URL:+${REGISTRY_URL}/}
IMAGE="db-{{db}}" IMAGE="db-{{service}}"
VERSION="{{variant}}" VERSION="{{variant}}"
just build {{db}} {{variant}} just build {{service}} {{variant}}
echo "docker tag ${IMAGE}:${VERSION} ${PREFIX}${IMAGE}:${VERSION}" echo "docker tag ${IMAGE}:${VERSION} ${PREFIX}${IMAGE}:${VERSION}"
docker tag ${IMAGE}:${VERSION} ${PREFIX}${IMAGE}:${VERSION} docker tag ${IMAGE}:${VERSION} ${PREFIX}${IMAGE}:${VERSION}
@@ -57,16 +68,18 @@ push db=DATABASE variant=VARIANT:
### Tests ### ### Tests ###
# Run tests against a database variant # Run tests against a service
test db=DATABASE variant=VARIANT: test service=SERVICE variant=VARIANT:
#!/usr/bin/env bash #!/usr/bin/env bash
just up {{db}} {{variant}} just up {{service}} {{variant}}
case "{{db}}:{{variant}}" in trap "just down {{service}} {{variant}}" EXIT
case "{{service}}:{{variant}}" in
postgres:base) just _test-postgres base ;; postgres:base) just _test-postgres base ;;
*) echo "Unknown database: {{db}}" >&2; exit 1 ;; *) echo "Unknown service: {{service}} {{variant}}" >&2; exit 1 ;;
esac esac
just down {{db}} {{variant}}
# Run tests against a Postgres database
_test-postgres variant=VARIANT: _test-postgres variant=VARIANT:
docker compose -f postgres-{{variant}}/compose.yml exec postgres pg_isready -U ${POSTGRES_USER:-postgres} #!/usr/bin/env bash
docker compose -f postgres/{{variant}}/compose.yml exec postgres bash -c "
psql -U ${POSTGRES_USER:-postgres} -c 'SELECT 1;'
"

View File

@@ -1,6 +1,6 @@
services: services:
postgres: postgres:
# run `just build postgres` first # run `just build postgres base` first
image: db-postgres:base image: db-postgres:base
restart: unless-stopped restart: unless-stopped
environment: environment: