Files
labFusion/.gitea/workflows/frontend.yml
GSRN 651e1fe5eb
Some checks failed
API Docs (Node.js Express) / test (20) (push) Failing after 43s
API Docs (Node.js Express) / build (push) Has been skipped
Integration Tests / integration-tests (push) Failing after 24s
Integration Tests / performance-tests (push) Has been skipped
Frontend (React) / test (20) (push) Failing after 1m25s
Frontend (React) / build (push) Has been skipped
Service Adapters (Python FastAPI) / test (3.11) (push) Failing after 23s
Service Adapters (Python FastAPI) / test (3.12) (push) Failing after 23s
Frontend (React) / lighthouse (push) Has been skipped
Service Adapters (Python FastAPI) / test (3.13) (push) Failing after 22s
Service Adapters (Python FastAPI) / build (push) Has been skipped
API Gateway (Java Spring Boot) / test (17) (push) Successful in 2m1s
API Gateway (Java Spring Boot) / test (21) (push) Successful in 2m7s
API Gateway (Java Spring Boot) / build (push) Successful in 2m2s
chore: Clean up CI workflow by removing redundant Docker build steps
### Summary of Changes
- Removed unnecessary Docker build steps from the CI workflows for API Docs, API Gateway, and Frontend.
- Streamlined the build process by eliminating duplicate commands, enhancing clarity and maintainability.

### Expected Results
- Improved readability of CI configuration and reduced complexity in the build process, making it easier to manage and update in the future.
2025-09-18 11:14:06 +02:00

199 lines
5.1 KiB
YAML

name: Frontend (React)
on:
push:
paths:
- 'frontend/**'
- '.gitea/workflows/frontend.yml'
pull_request:
paths:
- 'frontend/**'
workflow_dispatch:
inputs:
run_tests:
description: 'Run tests'
required: false
default: true
type: boolean
run_lint:
description: 'Run linting'
required: false
default: true
type: boolean
run_build:
description: 'Run build'
required: false
default: true
type: boolean
run_sonar:
description: 'Run SonarQube analysis'
required: false
default: true
type: boolean
env:
REGISTRY: gitea.example.com
IMAGE_PREFIX: labfusion
SERVICE_NAME: frontend
jobs:
test:
runs-on: [self-hosted]
env:
RUNNER_TOOL_CACHE: /toolcache
defaults:
run:
working-directory: ./frontend
strategy:
matrix:
node-version: [20]
steps:
- name: Checkout code
uses: actions/checkout@v4
- name: Set up Node.js ${{ matrix.node-version }}
uses: actions/setup-node@v4
with:
node-version: ${{ matrix.node-version }}
- name: Cache npm dependencies
uses: actions/cache@v4
with:
path: |
~/.npm
node_modules
~/.cache/node-gyp
key: npm-${{ runner.os }}-${{ matrix.node-version }}-${{ hashFiles('frontend/package-lock.json') }}
restore-keys: |
npm-${{ runner.os }}-${{ matrix.node-version }}-
npm-${{ runner.os }}-
npm-
fail-on-cache-miss: false
- name: Install dependencies
run: |
if [ -f package-lock.json ]; then
npm ci
else
npm install
fi
- name: Run linting
run: |
npm run lint
npm run lint:fix --dry-run
- name: Run security audit
run: |
npm audit --audit-level=moderate
npm audit fix --dry-run
- name: Run tests
run: |
npx vitest run --coverage --reporter=verbose
- name: Verify coverage files
run: |
echo "Checking coverage files..."
ls -la coverage/
echo "Required coverage files:"
if [ -f "coverage/lcov.info" ]; then
echo "✓ lcov.info found"
else
echo "✗ lcov.info missing"
fi
- name: Send results to SonarQube
run: |
echo "Sending Frontend results to SonarQube..."
# Install SonarQube Scanner for Node.js
npm install -g @sonar/scan
# Run SonarQube analysis
sonar-scanner \
-Dsonar.host.url=${{ secrets.SONAR_HOST_URL }} \
-Dsonar.login=${{ secrets.SONAR_TOKEN }} \
-Dsonar.projectKey=labfusion-frontend \
-Dsonar.projectName=LabFusion Frontend \
-Dsonar.sources=src \
-Dsonar.tests=src \
-Dsonar.sources.inclusions=**/*.js,**/*.jsx \
-Dsonar.sources.exclusions=**/*.test.js,**/*.test.jsx,**/*.spec.js,**/*.spec.jsx,src/index.js,src/setupTests.js \
-Dsonar.tests.inclusions=**/*.test.js,**/*.test.jsx,**/*.spec.js,**/*.spec.jsx \
-Dsonar.coverage.exclusions=**/*.test.js,**/*.test.jsx,**/*.spec.js,**/*.spec.jsx,src/index.js,src/setupTests.js \
-Dsonar.javascript.lcov.reportPaths=coverage/lcov.info
- name: Test results summary
if: always()
run: |
echo "Test results available in pipeline logs"
echo "Coverage report: frontend/coverage/"
echo "Vitest test results: frontend/test-results/"
build:
runs-on: [self-hosted]
needs: test
defaults:
run:
working-directory: ./frontend
steps:
- name: Checkout code
uses: actions/checkout@v4
- name: Set up Node.js 20
uses: actions/setup-node@v4
with:
node-version: '20'
- name: Cache npm dependencies
uses: actions/cache@v4
with:
path: ~/.npm
key: ${{ runner.os }}-node-20-${{ hashFiles('frontend/package-lock.json') }}
restore-keys: |
${{ runner.os }}-node-20-
${{ runner.os }}-node-
- name: Install dependencies
run: |
if [ -f package-lock.json ]; then
npm ci
else
npm install
fi
- name: Build application
run: |
npm run build
npm run build:analyze
- name: Build artifacts summary
run: |
echo "Build artifacts created in frontend/build/"
echo "Build analysis available in pipeline logs"
lighthouse:
runs-on: [self-hosted]
needs: build
if: github.event_name == 'pull_request'
steps:
- name: Checkout code
uses: actions/checkout@v4
- name: Build application for Lighthouse
run: |
cd frontend
npm ci
npm run build
- name: Run Lighthouse CI
uses: treosh/lighthouse-ci-action@v10
with:
configPath: './frontend/.lighthouserc.json'
uploadArtifacts: true
temporaryPublicStorage: true