Files
mostovik-backend/.gitea/workflows/ci-cd.yml
Aleksandr Meshchriakov 97a7764155 fix(ci): replace GitHub Actions with native bash commands
- Remove dependency on GitHub (network blocks access)
- Replace actions/checkout@v4 with git clone
- Replace actions/setup-python@v4 with apt-get install
- Replace docker/build-push-action with native docker commands
- Use config.settings.test (SQLite in-memory) for tests

Closes: network connectivity issue in CI
2026-02-02 12:39:06 +01:00

157 lines
5.3 KiB
YAML

name: CI/CD Pipeline
on:
push:
branches: [ main, develop ]
pull_request:
branches: [ main, develop ]
env:
PYTHON_VERSION: "3.11"
jobs:
lint:
name: Code Quality Checks
runs-on: ubuntu-latest
steps:
- name: Checkout code
run: |
git clone --depth=1 --branch=${GITHUB_REF_NAME} ${GITHUB_SERVER_URL}/${GITHUB_REPOSITORY}.git .
git checkout ${GITHUB_SHA}
- name: Install Python and uv
run: |
apt-get update && apt-get install -y python${PYTHON_VERSION} python${PYTHON_VERSION}-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 python${PYTHON_VERSION}
source .venv/bin/activate
uv sync --dev
- name: Run Ruff linting
run: |
export PATH="$HOME/.local/bin:$PATH"
source .venv/bin/activate
ruff check .
- name: Run Ruff formatting check
run: |
export PATH="$HOME/.local/bin:$PATH"
source .venv/bin/activate
ruff format . --check
test:
name: Run Tests
runs-on: ubuntu-latest
steps:
- name: Checkout code
run: |
git clone --depth=1 --branch=${GITHUB_REF_NAME} ${GITHUB_SERVER_URL}/${GITHUB_REPOSITORY}.git .
git checkout ${GITHUB_SHA}
- name: Install Python and uv
run: |
apt-get update && apt-get install -y python${PYTHON_VERSION} python${PYTHON_VERSION}-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 python${PYTHON_VERSION}
source .venv/bin/activate
uv sync --dev
- name: Run Django tests
run: |
export PATH="$HOME/.local/bin:$PATH"
source .venv/bin/activate
cd src
python manage.py test --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: |
git clone --depth=1 --branch=${GITHUB_REF_NAME} ${GITHUB_SERVER_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'
steps:
- name: Checkout code
run: |
git clone --depth=1 --branch=${GITHUB_REF_NAME} ${GITHUB_SERVER_URL}/${GITHUB_REPOSITORY}.git .
git checkout ${GITHUB_SHA}
- name: Login to Gitea Container Registry
run: |
echo "${{ secrets.GITEA_TOKEN }}" | docker login ${{ vars.GITEA_REGISTRY_URL }} -u ${{ secrets.GITEA_USERNAME }} --password-stdin
- name: Build and push images
run: |
BRANCH_TAG=$(echo ${GITHUB_REF_NAME} | sed 's/\//-/g')
SHA_SHORT=$(echo ${GITHUB_SHA} | cut -c1-7)
REGISTRY="${{ vars.GITEA_REGISTRY_URL }}/${{ github.repository_owner }}"
# Build and push web image
docker build -f ./docker/Dockerfile.web \
-t ${REGISTRY}/mostovik-web:${BRANCH_TAG} \
-t ${REGISTRY}/mostovik-web:${BRANCH_TAG}-${SHA_SHORT} \
.
docker push ${REGISTRY}/mostovik-web:${BRANCH_TAG}
docker push ${REGISTRY}/mostovik-web:${BRANCH_TAG}-${SHA_SHORT}
# Tag as latest if main branch
if [ "${GITHUB_REF_NAME}" = "main" ]; then
docker tag ${REGISTRY}/mostovik-web:${BRANCH_TAG} ${REGISTRY}/mostovik-web:latest
docker push ${REGISTRY}/mostovik-web:latest
fi
# Build and push celery image
docker build -f ./docker/Dockerfile.celery \
-t ${REGISTRY}/mostovik-celery:${BRANCH_TAG} \
-t ${REGISTRY}/mostovik-celery:${BRANCH_TAG}-${SHA_SHORT} \
.
docker push ${REGISTRY}/mostovik-celery:${BRANCH_TAG}
docker push ${REGISTRY}/mostovik-celery:${BRANCH_TAG}-${SHA_SHORT}
# Tag as latest if main branch
if [ "${GITHUB_REF_NAME}" = "main" ]; then
docker tag ${REGISTRY}/mostovik-celery:${BRANCH_TAG} ${REGISTRY}/mostovik-celery:latest
docker push ${REGISTRY}/mostovik-celery:latest
fi
- name: Image summary
run: |
echo "Images pushed to ${{ vars.GITEA_REGISTRY_URL }}/${{ github.repository_owner }}/"