Skip to content

chore: Set some injected services to readonly #31

chore: Set some injected services to readonly

chore: Set some injected services to readonly #31

name: Release - Visualization
on:
workflow_dispatch:
inputs:
version:
description: 'Version to release (e.g., 1.131.3)'
required: true
type: string
pull_request:
types:
- closed
branches:
- main
paths:
- 'visualization/**'
- 'gh-pages/_posts/release/*vis_*.md'
env:
VERSION: "0.0.0"
jobs:
# Build artifacts
build:
if: |
(github.event_name == 'workflow_dispatch') ||
(github.event_name == 'pull_request' &&
github.event.pull_request.merged == true &&
contains(github.event.pull_request.labels.*.name, 'release') &&
startsWith(github.event.pull_request.head.ref, 'release/vis-'))
name: Build
runs-on: ubuntu-latest
outputs:
version: ${{ env.VERSION }}
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Set version
run: |
if [[ "${{ github.event_name }}" == "workflow_dispatch" ]]; then
echo "VERSION=${{ inputs.version }}" >> $GITHUB_ENV
else
BRANCH_NAME="${{ github.event.pull_request.head.ref }}"
echo "VERSION=${BRANCH_NAME#release/vis-}" >> $GITHUB_ENV
fi
- name: Create tag
run: |
git config --local user.email "41898282+github-actions[bot]@users.noreply.github.com"
git config --local user.name "github-actions[bot]"
git tag "vis-${{ env.VERSION }}"
git push origin "vis-${{ env.VERSION }}"
- name: Setup Node.js
uses: actions/setup-node@v4
with:
node-version: '20'
registry-url: 'https://registry.npmjs.org'
- name: Install dependencies
run: |
sudo apt-get update
sudo apt-get install -y wine-stable zip
- name: Enable analysis execution rights
working-directory: ./analysis
run: |
chmod +x ./gradlew
- name: Build visualization
env:
NODE_OPTIONS: "--max_old_space_size=4096"
working-directory: ./visualization
run: |
npm ci
npm run build
npm run package
# Debug step to verify files
- name: List build artifacts
run: |
echo "Contents of visualization/dist/packages:"
ls -la visualization/dist/packages/
echo "Found zip files:"
find visualization/dist/packages -name "*.zip"
# Upload build artifacts for other jobs
- name: Upload build artifacts
uses: actions/upload-artifact@v4
with:
name: build-artifacts
path: |
visualization/dist/packages
- name: Upload webpack
uses: actions/upload-artifact@v4
with:
name: webpack-build
path: |
visualization/dist/webpack
# Create GitHub Release
create_release:
needs: build
name: Create GitHub Release
runs-on: ubuntu-latest
permissions:
contents: write
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Download build artifacts
uses: actions/download-artifact@v4
with:
name: build-artifacts
path: visualization/dist/packages
- name: Setup Bun
uses: oven-sh/setup-bun@v1
with:
bun-version: latest
- name: Create Release
run: |
# Debug: List files
echo "Contents of packages directory:"
ls -la visualization/dist/packages/
CHANGELOG_CONTENT=$(bun script/version-manager.ts extract-changelog visualization ${{ needs.build.outputs.version }})
gh release create "vis-${{ needs.build.outputs.version }}" \
--title "Visualization release ${{ needs.build.outputs.version }}" \
--notes "$CHANGELOG_CONTENT" \
visualization/dist/packages/*.zip
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
# Publish to npm
publish_npm:
needs: build
name: Publish to npm
runs-on: ubuntu-latest
steps:
- name: Setup Node.js
uses: actions/setup-node@v4
with:
node-version: '20'
registry-url: 'https://registry.npmjs.org'
- name: Download build artifacts
uses: actions/download-artifact@v4
with:
name: webpack-build
path: visualization/dist/webpack
- name: Publish package
working-directory: visualization
run: |
npm version ${{ needs.build.outputs.version }} --no-git-tag-version --allow-same-version
npm publish --tag latest
env:
NODE_AUTH_TOKEN: ${{ secrets.NPM_TOKEN }}
# Publish to Docker Hub
publish_docker:
needs: build
name: Publish to Docker Hub
runs-on: ubuntu-latest
steps:
- name: Login to Docker Hub
uses: docker/login-action@v3
with:
username: ${{ secrets.DOCKER_USERNAME }}
password: ${{ secrets.DOCKER_PASSWORD }}
- name: Pull and retag Docker image
run: |
docker pull codecharta/codecharta-visualization:staging
docker tag codecharta/codecharta-visualization:staging codecharta/codecharta-visualization:latest
docker tag codecharta/codecharta-visualization:staging codecharta/codecharta-visualization:${{ needs.build.outputs.version }}
docker push codecharta/codecharta-visualization:latest
docker push codecharta/codecharta-visualization:${{ needs.build.outputs.version }}
# Deploy to GitHub Pages
deploy_website:
needs: build
name: Deploy Website
runs-on: ubuntu-latest
permissions:
contents: write
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Download build artifacts
uses: actions/download-artifact@v4
with:
name: webpack-build
path: visualization/dist/webpack
- name: Create Sample File for Web Demo
run: sh ./script/build_demo_file_visualization.sh
- name: Deploy to GitHub Pages
uses: JamesIves/[email protected]
with:
token: ${{ secrets.DEPLOY_TOKEN }}
branch: gh-pages
folder: visualization/dist/webpack
target-folder: visualization/app
clean: true