fix. Jenkinsfile
This commit is contained in:
54
Jenkinsfile
vendored
54
Jenkinsfile
vendored
@@ -1,13 +1,7 @@
|
||||
pipeline {
|
||||
//test 1
|
||||
// Nutze das gleiche Playwright-Image wie Woodpecker für Parität
|
||||
agent {
|
||||
docker {
|
||||
image 'mcr.microsoft.com/playwright:v1.54.2-jammy'
|
||||
// root erlaubt playwright install (falls nötig)
|
||||
args '-u 0:0'
|
||||
}
|
||||
}
|
||||
// Fallback Variante ohne Docker-Plugin (agent any)
|
||||
agent any
|
||||
tools { nodejs 'node20' }
|
||||
|
||||
options { timestamps() }
|
||||
|
||||
@@ -24,30 +18,32 @@ pipeline {
|
||||
stages {
|
||||
stage('Self-check Jenkinsfile version') {
|
||||
steps {
|
||||
sh '''#!/bin/bash
|
||||
set -euo pipefail
|
||||
sh '''
|
||||
set -eu
|
||||
echo '==== Showing first lines of Jenkinsfile (debug) ===='
|
||||
head -n 40 Jenkinsfile || true
|
||||
echo 'Git commit:'
|
||||
git rev-parse --short HEAD || true
|
||||
'''
|
||||
uname -a || true
|
||||
which node || true
|
||||
'''
|
||||
}
|
||||
}
|
||||
|
||||
stage('Versions') {
|
||||
steps {
|
||||
sh '''#!/bin/bash
|
||||
set -euo pipefail
|
||||
sh '''
|
||||
set -eu
|
||||
node -v && npm -v
|
||||
npx playwright --version || true
|
||||
'''
|
||||
'''
|
||||
}
|
||||
}
|
||||
|
||||
stage('Verify mocks') {
|
||||
steps {
|
||||
sh '''#!/bin/bash
|
||||
set -euo pipefail
|
||||
sh '''
|
||||
set -eu
|
||||
echo "[Verify mocks] working dir: $(pwd)"
|
||||
node -v && npm -v
|
||||
echo "HUSKY=$HUSKY"
|
||||
@@ -57,7 +53,7 @@ git ls-files | grep -i '^mocks/device-cgi-simulator/SERVICE/systemMockData.js' |
|
||||
echo "=== ls -la ==="
|
||||
ls -la mocks/device-cgi-simulator/SERVICE || true
|
||||
echo "=== file exists? ==="
|
||||
if [[ -f mocks/device-cgi-simulator/SERVICE/systemMockData.js ]]; then
|
||||
if [ -f mocks/device-cgi-simulator/SERVICE/systemMockData.js ]; then
|
||||
echo 'FOUND'
|
||||
else
|
||||
echo 'MISSING'; exit 1
|
||||
@@ -68,37 +64,33 @@ fi
|
||||
|
||||
stage('Build') {
|
||||
steps {
|
||||
sh '''#!/bin/bash
|
||||
set -euo pipefail
|
||||
sh '''
|
||||
set -eu
|
||||
env npm_config_production=false npm ci
|
||||
npm run build
|
||||
'''
|
||||
'''
|
||||
}
|
||||
}
|
||||
|
||||
stage('E2E chromium') {
|
||||
steps {
|
||||
sh '''#!/bin/bash
|
||||
set -euo pipefail
|
||||
sh '''
|
||||
set -eu
|
||||
echo 'Start simulator'
|
||||
npm run server:sim &
|
||||
SIM_PID=$!
|
||||
|
||||
cleanup() {
|
||||
echo 'Stopping simulator'
|
||||
kill $SIM_PID 2>/dev/null || true
|
||||
}
|
||||
trap cleanup EXIT
|
||||
trap 'echo Stopping simulator; kill $SIM_PID 2>/dev/null || true' EXIT
|
||||
|
||||
echo 'Waiting for http://localhost:3000'
|
||||
node -e "const http=require('http');let n=120;function ping(){http.get('http://localhost:3000',res=>{console.log('Server is up');process.exit(0)}).on('error',()=>{if(n--<=0){console.error('Server did not start');process.exit(1)}setTimeout(ping,1000)});}ping();"
|
||||
|
||||
# Browser (Image hat sie normalerweise schon)
|
||||
npx playwright install --with-deps chromium || true
|
||||
# Playwright Browser installieren (best-effort)
|
||||
npx playwright install chromium || true
|
||||
|
||||
echo 'Run tests (chromium)'
|
||||
npx playwright test --project=chromium
|
||||
'''
|
||||
'''
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user