devops #1

Merged
trevor merged 11 commits from devops into main 2025-09-10 23:41:22 +00:00
40 changed files with 2297 additions and 409 deletions
Showing only changes of commit a188cd5d8f - Show all commits

View File

@@ -1,23 +1,39 @@
kind: pipeline
type: docker
name: quiz-bot-ci-cd
trigger:
branch:
- main
- develop
- "feature/*"
event:
- push
- pull_request
services:
docker:
- name: docker
image: docker:27-dind
privileged: true
command: [ "--host=tcp://0.0.0.0:2375" ]
command:
- --host=tcp://0.0.0.0:2375
environment:
DOCKER_TLS_CERTDIR: ""
pipeline:
prepare:
steps:
- name: prepare
image: alpine/git:latest
environment:
DOCKER_HOST: tcp://docker:2375
commands:
- echo "🚀 Pipeline started for branch ${DRONE_BRANCH}"
- echo "📝 Commit: ${DRONE_COMMIT_SHA:0:8}"
# BusyBox ash может не поддерживать ${VAR:0:8}; безопаснее так:
- echo "📝 Commit: $(echo ${DRONE_COMMIT_SHA} | cut -c1-8)"
- echo "👤 Author: ${DRONE_COMMIT_AUTHOR}"
- echo "📅 Build: ${DRONE_BUILD_NUMBER}"
- git --version
lint:
- name: lint
image: python:3.12-slim
commands:
- echo "🔍 Installing linting tools..."
@@ -30,28 +46,28 @@ pipeline:
- flake8 src/ config/ tools/ tests/ --max-line-length=88 --extend-ignore=E203,W503 || true
- echo "✅ Linting completed"
test:
- name: test
image: python:3.12-slim
commands:
- pip install --no-cache-dir -r requirements.txt
- python -m pytest tests/ -v --tb=short || true
- python tests/test_bot.py || true
security:
- name: security
image: python:3.12-slim
commands:
- pip install --no-cache-dir safety bandit
- safety check --json || true
- bandit -r src/ -f json || true
typecheck:
- name: typecheck
image: python:3.12-slim
commands:
- pip install --no-cache-dir mypy types-requests
- mypy src/ --ignore-missing-imports || true
docker_build:
image: docker:27
- name: docker_build
image: docker:27-cli
environment:
DOCKER_HOST: tcp://docker:2375
DOCKER_TLS_CERTDIR: ""
@@ -59,68 +75,3 @@ pipeline:
- 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 "📦 Docker build completed"
- docker images | grep quiz-bot
when:
branch: [ main, develop ]
event: [ push, pull_request ]
docker_test:
image: docker:27
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"
when:
branch: [ main, develop ]
event: [ push, pull_request ]
quality:
image: python:3.12-slim
commands:
- pip install --no-cache-dir flake8 radon
- radon cc src/ -s || true
- radon mi src/ -s || true
deploy:
image: docker:27
environment:
DOCKER_HOST: tcp://docker:2375
DOCKER_TLS_CERTDIR: ""
commands:
- docker tag quiz-bot:${DRONE_COMMIT_SHA} quiz-bot:production
- echo "Deployment completed (simulation)"
when:
branch: [ main ]
event: [ push ]
notify_success:
image: alpine:latest
commands:
- echo "🎉 Pipeline completed successfully!"
- echo "🌿 Branch: ${DRONE_BRANCH}"
- echo "📝 Commit: ${DRONE_COMMIT_SHA:0:8}"
- echo "🏗️ Build: #${DRONE_BUILD_NUMBER}"
- echo "✅ Status: SUCCESS"
- echo "🕒 Started: ${DRONE_BUILD_STARTED}"
when:
status: success
notify_failure:
image: alpine:latest
commands:
- echo "❌ Pipeline failed!"
- echo "🌿 Branch: ${DRONE_BRANCH}"
- echo "📝 Commit: ${DRONE_COMMIT_SHA:0:8}"
- echo "🏗️ Build: #${DRONE_BUILD_NUMBER}"
- echo "💥 Status: FAILURE"
- echo "🕒 Started: ${DRONE_BUILD_STARTED}"
- echo "🔍 Check logs above for details"
when:
status: failure