EXAMPLE-LIKE PIPELINE

This commit is contained in:
2025-09-11 11:50:16 +09:00
parent a188cd5d8f
commit 132af4af18
3 changed files with 98 additions and 32 deletions

View File

@@ -1,33 +1,20 @@
kind: pipeline
type: docker
name: quiz-bot-ci-cd
trigger:
branch:
- main
- develop
- "feature/*"
event:
- push
- pull_request
services:
- name: docker
image: docker:27-dind
privileged: true
command:
- --host=tcp://0.0.0.0:2375
environment:
DOCKER_TLS_CERTDIR: ""
name: quiz-bot-ci
steps:
- name: install-deps
image: python:3.12-slim
commands:
- echo "🔧 Installing dependencies..."
- pip install --upgrade pip
- pip install -r requirements.txt
- echo "✅ Dependencies installed"
- name: prepare
image: alpine/git:latest
environment:
DOCKER_HOST: tcp://docker:2375
commands:
- echo "🚀 Pipeline started for branch ${DRONE_BRANCH}"
# BusyBox ash может не поддерживать ${VAR:0:8}; безопаснее так:
- echo "📝 Commit: $(echo ${DRONE_COMMIT_SHA} | cut -c1-8)"
- echo "👤 Author: ${DRONE_COMMIT_AUTHOR}"
- echo "📅 Build: ${DRONE_BUILD_NUMBER}"
@@ -37,7 +24,7 @@ steps:
image: python:3.12-slim
commands:
- echo "🔍 Installing linting tools..."
- pip install --no-cache-dir flake8 black isort mypy
- pip install flake8 black isort
- echo "🎨 Running Black formatter check..."
- black --check --diff src/ config/ tools/ tests/ || true
- echo "📦 Running isort import sorting check..."
@@ -49,22 +36,24 @@ steps:
- name: test
image: python:3.12-slim
commands:
- pip install --no-cache-dir -r requirements.txt
- echo "🧪 Installing test dependencies..."
- pip install -r requirements.txt
- pip install pytest
- echo "🚀 Running tests..."
- python -m pytest tests/ -v --tb=short || true
- python tests/test_bot.py || true
- echo "✅ Tests completed"
- name: security
image: python:3.12-slim
commands:
- pip install --no-cache-dir safety bandit
- echo "🔒 Installing security tools..."
- pip install safety bandit
- echo "🛡️ Running safety check..."
- safety check --json || true
- echo "🔍 Running bandit security check..."
- bandit -r src/ -f json || true
- name: typecheck
image: python:3.12-slim
commands:
- pip install --no-cache-dir mypy types-requests
- mypy src/ --ignore-missing-imports || true
- echo "✅ Security checks completed"
- name: docker_build
image: docker:27-cli
@@ -75,3 +64,78 @@ steps:
- echo "🐳 Docker version info:"
- docker version
- echo "🔨 Building Docker image..."
- docker build -t quiz-bot:${DRONE_COMMIT_SHA} .
- docker tag quiz-bot:${DRONE_COMMIT_SHA} quiz-bot:latest
- echo "<22><> Docker build completed"
- docker images | grep quiz-bot || true
when:
branch:
- main
- develop
event:
- push
- pull_request
- name: docker_test
image: docker:27-cli
environment:
DOCKER_HOST: tcp://docker:2375
DOCKER_TLS_CERTDIR: ""
commands:
- echo "🧪 Testing Docker image..."
- docker run --rm quiz-bot:${DRONE_COMMIT_SHA} python -c "import src.bot; print('✅ Bot import successful')"
- docker run --rm quiz-bot:${DRONE_COMMIT_SHA} python -c "import config.config; print('✅ Config import successful')"
- echo "✅ Docker tests completed"
depends_on:
- docker_build
when:
branch:
- main
- develop
event:
- push
- pull_request
- name: quality
image: python:3.12-slim
commands:
- pip install --no-cache-dir flake8 radon
- echo "📊 Calculating code metrics..."
- radon cc src/ -s || true
- radon mi src/ -s || true
- echo "✅ Quality check completed"
- name: deploy
image: docker:27-cli
environment:
DOCKER_HOST: tcp://docker:2375
DOCKER_TLS_CERTDIR: ""
commands:
- echo "🚀 Deployment preparation..."
- docker tag quiz-bot:${DRONE_COMMIT_SHA} quiz-bot:production
- echo "Tagged image for production"
- echo "✅ Deployment completed (simulation)"
depends_on:
- docker_test
- quality
when:
branch:
- main
event:
- push
- name: notify
image: alpine:latest
commands:
- echo "📋 Pipeline Summary:"
- echo "🌿 Branch: ${DRONE_BRANCH}"
- echo "📝 Commit: $(echo ${DRONE_COMMIT_SHA} | cut -c1-8)"
- echo "🏗️ Build: #${DRONE_BUILD_NUMBER}"
- echo "👤 Author: ${DRONE_COMMIT_AUTHOR}"
- echo "✅ Status: ${DRONE_BUILD_STATUS}"
- echo "🕒 Started: ${DRONE_BUILD_STARTED}"
- echo "🎉 All checks passed!"
when:
status:
- success
- failure