Files
mostovik-backend/.gitea/workflows/ci-cd.yml
Aleksandr Meshchriakov 5f8ffb6854
Some checks failed
CI/CD Pipeline / Run Tests (push) Successful in 1m54s
CI/CD Pipeline / Code Quality Checks (push) Successful in 1m57s
CI/CD Pipeline / Build Docker Images (push) Successful in 2s
CI/CD Pipeline / Push to Gitea Registry (push) Failing after 2m19s
fix(ci): create docker config.json manually for buildx auth
2026-02-02 13:36:37 +01:00

185 lines
6.4 KiB
YAML

name: CI/CD Pipeline
on:
push:
branches: [ main, develop, dev ]
pull_request:
branches: [ main, develop, dev ]
env:
PYTHON_VERSION: "3.11"
jobs:
lint:
name: Code Quality Checks
runs-on: ubuntu-latest
steps:
- name: Checkout code
run: |
REPO_URL=$(echo ${GITHUB_SERVER_URL} | sed "s|://|://oauth2:${{ gitea.token }}@|")
git clone --depth=1 --branch=${GITHUB_REF_NAME} ${REPO_URL}/${GITHUB_REPOSITORY}.git .
git checkout ${GITHUB_SHA}
- name: Install Python and uv
run: |
apt-get update && apt-get install -y software-properties-common
add-apt-repository -y ppa:deadsnakes/ppa
apt-get update && apt-get install -y python3.11 python3.11-venv
curl -LsSf https://astral.sh/uv/install.sh | sh
export PATH="$HOME/.local/bin:$PATH"
- name: Create virtual environment and install dependencies
run: |
export PATH="$HOME/.local/bin:$PATH"
uv venv --python python3.11
source .venv/bin/activate
uv sync --dev
- name: Run Ruff linting
run: |
export PATH="$HOME/.local/bin:$PATH"
source .venv/bin/activate
ruff check src/
- name: Run Ruff formatting check
run: |
export PATH="$HOME/.local/bin:$PATH"
source .venv/bin/activate
ruff format src/ --check
test:
name: Run Tests
runs-on: ubuntu-latest
steps:
- name: Checkout code
run: |
REPO_URL=$(echo ${GITHUB_SERVER_URL} | sed "s|://|://oauth2:${{ gitea.token }}@|")
git clone --depth=1 --branch=${GITHUB_REF_NAME} ${REPO_URL}/${GITHUB_REPOSITORY}.git .
git checkout ${GITHUB_SHA}
- name: Install Python and uv
run: |
apt-get update && apt-get install -y software-properties-common
add-apt-repository -y ppa:deadsnakes/ppa
apt-get update && apt-get install -y python3.11 python3.11-venv
curl -LsSf https://astral.sh/uv/install.sh | sh
export PATH="$HOME/.local/bin:$PATH"
- name: Create virtual environment and install dependencies
run: |
export PATH="$HOME/.local/bin:$PATH"
uv venv --python python3.11
source .venv/bin/activate
uv sync --dev
- name: Run Django tests
run: |
export PATH="$HOME/.local/bin:$PATH"
source .venv/bin/activate
export PYTHONPATH="${PWD}/src:${PYTHONPATH}"
python src/manage.py test tests --verbosity=2
env:
DJANGO_SETTINGS_MODULE: config.settings.test
SECRET_KEY: test-secret-key-for-ci
build:
name: Build Docker Images
runs-on: ubuntu-latest
needs: [lint, test]
steps:
- name: Checkout code
run: |
REPO_URL=$(echo ${GITHUB_SERVER_URL} | sed "s|://|://oauth2:${{ gitea.token }}@|")
git clone --depth=1 --branch=${GITHUB_REF_NAME} ${REPO_URL}/${GITHUB_REPOSITORY}.git .
git checkout ${GITHUB_SHA}
- name: Build web image
run: |
BRANCH_TAG=$(echo ${GITHUB_REF_NAME} | sed 's/\//-/g')
SHA_SHORT=$(echo ${GITHUB_SHA} | cut -c1-7)
docker build -f ./docker/Dockerfile.web -t mostovik-web:${BRANCH_TAG} -t mostovik-web:${BRANCH_TAG}-${SHA_SHORT} .
- name: Build celery image
run: |
BRANCH_TAG=$(echo ${GITHUB_REF_NAME} | sed 's/\//-/g')
SHA_SHORT=$(echo ${GITHUB_SHA} | cut -c1-7)
docker build -f ./docker/Dockerfile.celery -t mostovik-celery:${BRANCH_TAG} -t mostovik-celery:${BRANCH_TAG}-${SHA_SHORT} .
push:
name: Push to Gitea Registry
runs-on: ubuntu-latest
needs: [build]
if: github.ref == 'refs/heads/main' || github.ref == 'refs/heads/develop' || github.ref == 'refs/heads/dev'
steps:
- name: Checkout code
run: |
REPO_URL=$(echo ${GITHUB_SERVER_URL} | sed "s|://|://oauth2:${{ gitea.token }}@|")
git clone --depth=1 --branch=${GITHUB_REF_NAME} ${REPO_URL}/${GITHUB_REPOSITORY}.git .
git checkout ${GITHUB_SHA}
- name: Setup Docker Buildx for insecure registry
run: |
REGISTRY_URL=$(echo ${GITHUB_SERVER_URL} | sed 's|.*://||')
# Create buildkitd config for HTTP registry
cat > /tmp/buildkitd.toml << EOF
[registry."${REGISTRY_URL}"]
http = true
insecure = true
EOF
# Create docker config.json with credentials (for buildx)
mkdir -p ~/.docker
AUTH=$(echo -n "${{ gitea.actor }}:${{ gitea.token }}" | base64 -w 0)
cat > ~/.docker/config.json << EOF
{
"auths": {
"${REGISTRY_URL}": {
"auth": "${AUTH}"
}
}
}
EOF
# Create buildx builder with insecure registry and mount docker config
docker buildx create --name insecure-builder \
--driver docker-container \
--config /tmp/buildkitd.toml \
--driver-opt network=host \
--use
docker buildx inspect --bootstrap
- name: Build and push images
run: |
BRANCH_TAG=$(echo ${GITHUB_REF_NAME} | sed 's/\//-/g')
SHA_SHORT=$(echo ${GITHUB_SHA} | cut -c1-7)
REGISTRY_URL=$(echo ${GITHUB_SERVER_URL} | sed 's|.*://||')
REGISTRY="${REGISTRY_URL}/${{ github.repository_owner }}"
# Build and push web image
docker buildx build --push \
-f ./docker/Dockerfile.web \
-t ${REGISTRY}/mostovik-web:${BRANCH_TAG} \
-t ${REGISTRY}/mostovik-web:${BRANCH_TAG}-${SHA_SHORT} \
$([ "${GITHUB_REF_NAME}" = "main" ] && echo "-t ${REGISTRY}/mostovik-web:latest") \
.
# Build and push celery image
docker buildx build --push \
-f ./docker/Dockerfile.celery \
-t ${REGISTRY}/mostovik-celery:${BRANCH_TAG} \
-t ${REGISTRY}/mostovik-celery:${BRANCH_TAG}-${SHA_SHORT} \
$([ "${GITHUB_REF_NAME}" = "main" ] && echo "-t ${REGISTRY}/mostovik-celery:latest") \
.
env:
DOCKER_BUILDKIT: 1
- name: Image summary
run: |
REGISTRY_URL=$(echo ${GITHUB_SERVER_URL} | sed 's|.*://||')
echo "Images pushed to ${REGISTRY_URL}/${{ github.repository_owner }}/"