pyserveX/.gitea/workflows/release.yaml
Илья Глазунов 537b783726
Some checks failed
Lint Code / lint (push) Failing after 2m2s
CI/CD Pipeline / lint (push) Successful in 0s
Run Tests / test (3.12) (push) Successful in 54s
CI/CD Pipeline / build-and-release (push) Has been cancelled
CI/CD Pipeline / test (push) Has been cancelled
CI/CD Pipeline / notify (push) Has been cancelled
Run Tests / test (3.13) (push) Has been cancelled
Add CI/CD pipeline, logging enhancements, and release management
- Create a GitHub Actions workflow for testing with Python 3.12 and 3.13.
- Update Makefile to include release management commands and pipeline checks.
- Document the CI/CD pipeline structure and usage in PIPELINE.md.
- Add structlog for structured logging and enhance logging utilities.
- Implement release management script for automated versioning and tagging.
- Modify logging configuration to support structured logging and improved formatting.
- Update dependencies in pyproject.toml and poetry.lock to include structlog.
- Enhance access logging in server and middleware to include structured data.
2025-09-03 00:13:21 +03:00

156 lines
4.8 KiB
YAML

name: Build and Release
run-name: ${{ gitea.actor }} preparing release
on:
push:
tags:
- 'v*'
workflow_dispatch:
inputs:
version:
description: 'Release version (e.g., v0.6.1)'
required: true
default: 'v0.6.1'
jobs:
build:
runs-on: ubuntu-latest
needs: []
steps:
- name: Checkout repository
uses: actions/checkout@v4
with:
fetch-depth: 0
- name: Setup Python
uses: actions/setup-python@v4
with:
python-version: '3.12'
- name: Install Poetry
uses: snok/install-poetry@v1
with:
version: latest
virtualenvs-create: true
virtualenvs-in-project: true
- name: Load cached venv
id: cached-poetry-dependencies
uses: actions/cache@v3
with:
path: .venv
key: venv-${{ runner.os }}-${{ hashFiles('**/poetry.lock') }}
- name: Install dependencies
if: steps.cached-poetry-dependencies.outputs.cache-hit != 'true'
run: poetry install --with dev
- name: Build package
run: |
poetry build
echo "Package built successfully!"
ls -la dist/
- name: Generate changelog
id: changelog
run: |
echo "## What's new in this version" > CHANGELOG.md
echo "" >> CHANGELOG.md
echo "### New Features" >> CHANGELOG.md
echo "- Add description of new features" >> CHANGELOG.md
echo "" >> CHANGELOG.md
echo "### Bug Fixes" >> CHANGELOG.md
echo "- Add description of bug fixes" >> CHANGELOG.md
echo "" >> CHANGELOG.md
echo "### Technical Changes" >> CHANGELOG.md
echo "- Add description of technical improvements" >> CHANGELOG.md
echo "" >> CHANGELOG.md
echo "### Dependencies" >> CHANGELOG.md
echo "- Updated dependencies to latest versions" >> CHANGELOG.md
echo "" >> CHANGELOG.md
echo "---" >> CHANGELOG.md
echo "**Full Changelog:** https://gitea.example.com/${{ gitea.repository }}/compare/v0.5.0...${{ github.ref_name }}" >> CHANGELOG.md
- name: Upload build artifacts
uses: actions/upload-artifact@v3
with:
name: dist-${{ github.ref_name }}
path: |
dist/
CHANGELOG.md
- name: Build completed
run: echo "Build completed! Artifacts ready for release."
release:
runs-on: ubuntu-latest
needs: build
if: startsWith(github.ref, 'refs/tags/v') || github.event_name == 'workflow_dispatch'
steps:
- name: Checkout repository
uses: actions/checkout@v4
- name: Download build artifacts
uses: actions/download-artifact@v3
with:
name: dist-${{ github.ref_name || github.event.inputs.version }}
- name: Read changelog
id: changelog
run: |
if [ -f CHANGELOG.md ]; then
echo "CHANGELOG<<EOF" >> $GITHUB_OUTPUT
cat CHANGELOG.md >> $GITHUB_OUTPUT
echo "EOF" >> $GITHUB_OUTPUT
else
echo "CHANGELOG=Automatically generated release" >> $GITHUB_OUTPUT
fi
- name: Create Release
uses: actions/create-release@v1
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
with:
tag_name: ${{ github.ref_name || github.event.inputs.version }}
release_name: PyServeX ${{ github.ref_name || github.event.inputs.version }}
body: |
${{ steps.changelog.outputs.CHANGELOG }}
## Installation
```bash
pip install pyserve==${{ github.ref_name || github.event.inputs.version }}
```
## Usage
```bash
pyserve --help
```
draft: true
prerelease: false
- name: Upload Release Asset (wheel)
uses: actions/upload-release-asset@v1
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
with:
upload_url: ${{ steps.create_release.outputs.upload_url }}
asset_path: ./dist/pyserve-*.whl
asset_name: pyserve-${{ github.ref_name || github.event.inputs.version }}.whl
asset_content_type: application/octet-stream
- name: Upload Release Asset (tarball)
uses: actions/upload-release-asset@v1
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
with:
upload_url: ${{ steps.create_release.outputs.upload_url }}
asset_path: ./dist/pyserve-*.tar.gz
asset_name: pyserve-${{ github.ref_name || github.event.inputs.version }}.tar.gz
asset_content_type: application/gzip
- name: Release created
run: echo "Draft release created! Check and publish in Gitea interface."