baktainer/.forgejo/workflows/simple.yml

119 lines
3.1 KiB
YAML
Raw Normal View History

Fix Node.js executable error in Forgejo Actions ## Problem Forgejo Actions failed with error: ``` OCI runtime exec failed: exec failed: unable to start container process: exec: "node": executable file not found in $PATH: unknown ``` ## Root Cause GitHub Actions like checkout@v4, cache@v4, and upload-artifact@v4 require Node.js runtime, but Ruby Alpine containers don't include Node.js by default. ## Solutions Implemented ### 1. Updated Existing Workflows - **ci.yml**: Added Node.js installation (`apk add nodejs npm`) - **test.yml**: Added Node.js installation for GitHub Actions compatibility ### 2. New Alternative Workflows - **node-ruby.yml**: Uses Node.js 18 Alpine base with Ruby installed - **simple.yml**: Shell-based workflow avoiding Node.js actions - **minimal.yml**: Minimal test-only workflow with basic shell commands ### 3. Updated Documentation - Added troubleshooting section for Node.js issues - Documented all workflow options with their trade-offs - Provided clear solutions for different use cases ## Workflow Options ### For Full GitHub Actions Support - Use `node-ruby.yml` (Node.js base + Ruby) - Use `ci.yml` or `test.yml` (Ruby base + Node.js installed) ### For Minimal Dependencies - Use `simple.yml` (shell-based, manual git/docker) - Use `minimal.yml` (basic test execution only) ### For Production - Use `node-ruby.yml` for maximum compatibility - Use `simple.yml` for minimal resource usage ## Benefits - **Multiple Options**: Choose workflow based on needs - **Backward Compatibility**: Existing workflows still work - **Minimal Alternatives**: Avoid Node.js dependency if not needed - **Clear Documentation**: Troubleshooting guide for common issues This provides flexibility to use Forgejo Actions with or without Node.js dependencies based on specific requirements. 🤖 Generated with [Claude Code](https://claude.ai/code) Co-Authored-By: Claude <noreply@anthropic.com>
2025-07-15 11:18:12 -04:00
name: Simple CI Pipeline
on:
push:
branches:
- main
tags:
- 'v*.*.*'
pull_request:
branches:
- main
jobs:
test:
runs-on: docker
container:
image: ruby:3.3-alpine
defaults:
run:
working-directory: ./app
steps:
- name: Checkout repository
run: |
apk add --no-cache git
git clone ${{ github.server_url }}/${{ github.repository }}.git .
git checkout ${{ github.sha }}
- name: Install system dependencies
run: |
apk add --no-cache build-base libffi-dev linux-headers postgresql-dev curl tzdata
- name: Install bundler
run: gem install bundler -v 2.6.7
- name: Install Ruby dependencies
run: |
bundle config path vendor/bundle
bundle install --jobs 4 --retry 3
- name: Run RSpec tests
run: |
mkdir -p tmp
bundle exec rspec --format progress
- name: Test status
run: |
if [ $? -eq 0 ]; then
echo "✅ All tests passed!"
else
echo "❌ Tests failed"
exit 1
fi
build:
needs: test
runs-on: docker
if: github.event_name == 'push' && (github.ref == 'refs/heads/main' || startsWith(github.ref, 'refs/tags/'))
steps:
- name: Checkout repository
run: |
apk add --no-cache git
git clone ${{ github.server_url }}/${{ github.repository }}.git .
git checkout ${{ github.sha }}
- name: Install Docker
run: |
apk add --no-cache docker
- name: Build Docker image
run: |
docker build -t baktainer-test .
- name: Test Docker image
run: |
docker run --rm baktainer-test ruby --version
- name: Login to Docker Hub
run: |
echo "${{ secrets.DOCKER_PASSWORD }}" | docker login -u "${{ secrets.DOCKER_USERNAME }}" --password-stdin
- name: Tag and push image
run: |
IMAGE_NAME="${{ secrets.DOCKER_IMAGE_NAME }}"
# Tag as latest
docker tag baktainer-test "${IMAGE_NAME}:latest"
docker push "${IMAGE_NAME}:latest"
# Tag with version if it's a tag
if [[ "${GITHUB_REF}" == refs/tags/v* ]]; then
VERSION_TAG="${GITHUB_REF#refs/tags/}"
docker tag baktainer-test "${IMAGE_NAME}:${VERSION_TAG}"
docker push "${IMAGE_NAME}:${VERSION_TAG}"
echo "✅ Pushed ${IMAGE_NAME}:${VERSION_TAG}"
fi
echo "✅ Docker image pushed successfully"
notify:
needs: [test, build]
runs-on: docker
if: always()
steps:
- name: Notify pipeline status
run: |
echo "📊 Pipeline Status Report:"
echo "🧪 Tests: ${{ needs.test.result }}"
if [ "${{ needs.build.result }}" != "skipped" ]; then
echo "🐳 Build: ${{ needs.build.result }}"
fi
if [ "${{ needs.test.result }}" == "success" ]; then
echo "✅ All tests passed!"
else
echo "❌ Tests failed"
fi