Better errors handling #1991
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: 'Test Docker Compose' | |
on: | |
pull_request: | |
concurrency: | |
group: ${{ github.workflow }}-${{ github.ref }} | |
cancel-in-progress: true | |
jobs: | |
test: | |
timeout-minutes: 30 | |
runs-on: ubuntu-latest | |
steps: | |
- name: Checkout | |
uses: actions/checkout@v2 | |
- name: Check for changed files | |
id: changed-files | |
uses: tj-actions/changed-files@v11 | |
with: | |
files: | | |
packages/twenty-docker/** | |
docker-compose.yml | |
- name: Skip if no relevant changes | |
if: steps.changed-files.outputs.any_changed != 'true' | |
run: echo "No relevant changes detected. Marking as valid." | |
- name: Run compose | |
if: steps.changed-files.outputs.any_changed == 'true' | |
run: | | |
echo "Patching docker-compose.yml..." | |
# change image to localbuild using yq | |
yq eval 'del(.services.server.image)' -i docker-compose.yml | |
yq eval '.services.server.build.context = "../../"' -i docker-compose.yml | |
yq eval '.services.server.build.dockerfile = "./packages/twenty-docker/twenty/Dockerfile"' -i docker-compose.yml | |
yq eval '.services.server.restart = "no"' -i docker-compose.yml | |
yq eval 'del(.services.db.image)' -i docker-compose.yml | |
yq eval '.services.db.build.context = "../../"' -i docker-compose.yml | |
yq eval '.services.db.build.dockerfile = "./packages/twenty-docker/twenty-postgres-spilo/Dockerfile"' -i docker-compose.yml | |
echo "Setting up .env file..." | |
cp .env.example .env | |
echo "Generating secrets..." | |
echo "# === Randomly generated secrets ===" >>.env | |
echo "APP_SECRET=$(openssl rand -base64 32)" >>.env | |
echo "PGPASSWORD_SUPERUSER=$(openssl rand -base64 32)" >>.env | |
echo "Docker compose up..." | |
docker compose up -d || { | |
echo "Docker compose failed to start" | |
docker compose logs | |
exit 1 | |
} | |
docker compose logs db server -f & | |
pid=$! | |
echo "Waiting for database to start..." | |
count=0 | |
while [ ! $(docker inspect --format='{{.State.Health.Status}}' twenty-db-1) = "healthy" ]; do | |
sleep 1; | |
count=$((count+1)); | |
if [ $(docker inspect --format='{{.State.Status}}' twenty-db-1) = "exited" ]; then | |
echo "Database exited" | |
docker compose logs db | |
exit 1 | |
fi | |
if [ $count -gt 300 ]; then | |
echo "Failed to start database after 5 minutes" | |
docker compose logs db | |
exit 1 | |
fi | |
echo "Still waiting for database... (${count}/60)" | |
done | |
echo "Waiting for server to start..." | |
count=0 | |
while [ ! $(docker inspect --format='{{.State.Health.Status}}' twenty-server-1) = "healthy" ]; do | |
sleep 1; | |
count=$((count+1)); | |
if [ $(docker inspect --format='{{.State.Status}}' twenty-server-1) = "exited" ]; then | |
echo "Server exited" | |
docker compose logs server | |
exit 1 | |
fi | |
if [ $count -gt 300 ]; then | |
echo "Failed to start server after 5 minutes" | |
docker compose logs server | |
exit 1 | |
fi | |
echo "Still waiting for server... (${count}/300s)" | |
done | |
working-directory: ./packages/twenty-docker/ |