feat: enhance release workflow with artifact collection and job output handling

This commit is contained in:
David Soria Parra
2025-01-13 20:01:18 +00:00
parent 111806d6ae
commit 3d8c33cd9a

View File

@@ -21,14 +21,17 @@ jobs:
- name: Find package directories - name: Find package directories
id: set-matrix id: set-matrix
run: | run: |
# Find all package.json and pyproject.toml files, excluding root
DIRS=$(git ls-tree -r HEAD --name-only | grep -E "package.json|pyproject.toml" | xargs dirname | grep -v "^.$" | jq -R -s -c 'split("\n")[:-1]') DIRS=$(git ls-tree -r HEAD --name-only | grep -E "package.json|pyproject.toml" | xargs dirname | grep -v "^.$" | jq -R -s -c 'split("\n")[:-1]')
echo "matrix=${DIRS}" >> $GITHUB_OUTPUT echo "matrix=${DIRS}" >> $GITHUB_OUTPUT
echo "Found directories: ${DIRS}"
- name: Get last release hash - name: Get last release hash
id: last-release id: last-release
run: | run: |
HASH=$(git rev-list --tags --max-count=1 || echo "HEAD~1") HASH=$(git rev-list --tags --max-count=1 || echo "HEAD~1")
echo "hash=${HASH}" >> $GITHUB_OUTPUT echo "hash=${HASH}" >> $GITHUB_OUTPUT
echo "Using last release hash: ${HASH}"
release: release:
needs: prepare needs: prepare
@@ -50,23 +53,76 @@ jobs:
- uses: astral-sh/setup-uv@v5 - uses: astral-sh/setup-uv@v5
- name: Setup Node.js - name: Setup Node.js
if: endsWith(matrix.directory, 'package.json') if: endsWith(matrix.directory, '/package.json')
uses: actions/setup-node@v4 uses: actions/setup-node@v4
with: with:
node-version: '18' node-version: '18'
registry-url: 'https://registry.npmjs.org' registry-url: 'https://registry.npmjs.org'
- name: Setup Python - name: Setup Python
if: endsWith(matrix.directory, 'pyproject.toml') if: endsWith(matrix.directory, '/pyproject.toml')
run: uv python install run: uv python install
- name: Release package - name: Release package
id: release
env: env:
NODE_AUTH_TOKEN: ${{ secrets.NPM_TOKEN }} NODE_AUTH_TOKEN: ${{ secrets.NPM_TOKEN }}
UV_PUBLISH_TOKEN: ${{ secrets.PYPI_TOKEN }} UV_PUBLISH_TOKEN: ${{ secrets.PYPI_TOKEN }}
run: uv run --script scripts/release.py "${{ matrix.directory }}" "${{ needs.prepare.outputs.last_release }}" >> "$GITHUB_OUTPUT" run: |
# Create unique hash for this directory
dir_hash=$(echo "${{ matrix.directory }}" | sha256sum | awk '{print $1}')
create-release: # Run git diff first to show changes
echo "Changes since last release:"
git diff --name-only "${{ needs.prepare.outputs.last_release }}" -- "${{ matrix.directory }}" || true
# Run the release
output=$(uv run --script scripts/release.py "${{ matrix.directory }}" "${{ needs.prepare.outputs.last_release }}" 2>&1)
exit_code=$?
echo "Release output (exit code: $exit_code):"
echo "$output"
# Extract package info if successful
if [ $exit_code -eq 0 ]; then
pkg_info=$(echo "$output" | grep -o -E "[a-zA-Z0-9\-]+@[0-9]+\.[0-9]+\.[0-9]+" || true)
else
echo "Release failed"
exit 1
fi
if [ ! -z "$pkg_info" ]; then
echo "Released package: $pkg_info"
# Create outputs directory
mkdir -p ./outputs
# Save both package info and full changes
echo "$pkg_info" > "./outputs/${dir_hash}_info"
echo "dir_hash=${dir_hash}" >> $GITHUB_OUTPUT
# Log what we're saving
echo "Saved package info to ./outputs/${dir_hash}_info:"
cat "./outputs/${dir_hash}_info"
else
echo "No release needed for this package"
fi
- name: Set artifact name
if: steps.release.outputs.dir_hash
id: artifact
run: |
# Replace forward slashes with dashes
SAFE_DIR=$(echo "${{ matrix.directory }}" | tr '/' '-')
echo "name=release-outputs-${SAFE_DIR}" >> $GITHUB_OUTPUT
- uses: actions/upload-artifact@v4
if: steps.release.outputs.dir_hash
with:
name: ${{ steps.artifact.outputs.name }}
path: ./outputs/${{ steps.release.outputs.dir_hash }}*
create-tag:
needs: [prepare, release] needs: [prepare, release]
runs-on: ubuntu-latest runs-on: ubuntu-latest
permissions: permissions:
@@ -74,30 +130,45 @@ jobs:
steps: steps:
- uses: actions/checkout@v4 - uses: actions/checkout@v4
- name: Create Release - uses: actions/download-artifact@v4
with:
pattern: release-outputs-src-*
merge-multiple: true
path: outputs
- name: Create tag and release
env: env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
run: | run: |
# Check if there's output from release step if [ -d outputs ]; then
if [ -s "$GITHUB_OUTPUT" ]; then # Collect package info
DATE=$(date +%Y.%m.%d) find outputs -name "*_info" -exec cat {} \; > packages.txt
# Create git tag if [ -s packages.txt ]; then
git tag -s -a -m"automated release v${DATE}" "v${DATE}" DATE=$(date +%Y.%m.%d)
git push origin "v${DATE}" echo "Creating tag v${DATE}"
# Create release notes # Generate comprehensive release notes
echo "# Release ${DATE}" > notes.md {
echo "" >> notes.md echo "# Release ${DATE}"
echo "## Updated Packages" >> notes.md echo ""
echo "## Updated Packages"
while IFS= read -r line; do
echo "- $line"
done < packages.txt
} > notes.md
# Read updated packages from github output # Create and push tag
while IFS= read -r line; do git tag -a "v${DATE}" -m "Release ${DATE}"
echo "- ${line}" >> notes.md git push origin "v${DATE}"
done < "$GITHUB_OUTPUT"
# Create GitHub release # Create GitHub release
gh release create "v${DATE}" \ gh release create "v${DATE}" \
--title "Release ${DATE}" \ --title "Release ${DATE}" \
--notes-file notes.md --notes-file notes.md
fi else
echo "No packages need release"
fi
else
echo "No release artifacts found"
fi