225 lines
7.7 KiB
Groovy
225 lines
7.7 KiB
Groovy
#!/usr/bin/env groovy
|
|
|
|
def PROTECTED_BRANCH
|
|
|
|
def BRANCH_ENV = [
|
|
test: 'test',
|
|
master: 'production',
|
|
beta: 'production'
|
|
]
|
|
|
|
node {
|
|
stage('Setup') {
|
|
env.FRONT_REPLICAS = 1
|
|
env.NODE_ENV = BRANCH_ENV[env.BRANCH_NAME] ?: 'dev'
|
|
|
|
PROTECTED_BRANCH = [
|
|
'dev',
|
|
'test',
|
|
'master',
|
|
'beta'
|
|
].contains(env.BRANCH_NAME)
|
|
|
|
// https://www.jenkins.io/doc/book/pipeline/jenkinsfile/#using-environment-variables
|
|
echo "NODE_NAME: ${env.NODE_NAME}"
|
|
echo "WORKSPACE: ${env.WORKSPACE}"
|
|
|
|
configFileProvider([
|
|
configFile(fileId: 'salix-front.properties',
|
|
variable: 'PROPS_FILE')
|
|
]) {
|
|
def props = readProperties file: PROPS_FILE
|
|
props.each {key, value -> env."${key}" = value }
|
|
props.each {key, value -> echo "${key}: ${value}" }
|
|
}
|
|
|
|
if (PROTECTED_BRANCH) {
|
|
configFileProvider([
|
|
configFile(fileId: "salix-front.branch.${env.BRANCH_NAME}",
|
|
variable: 'BRANCH_PROPS_FILE')
|
|
]) {
|
|
def props = readProperties file: BRANCH_PROPS_FILE
|
|
props.each {key, value -> env."${key}" = value }
|
|
props.each {key, value -> echo "${key}: ${value}" }
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
pipeline {
|
|
agent any
|
|
options {
|
|
disableConcurrentBuilds()
|
|
}
|
|
tools {
|
|
nodejs 'node-v18'
|
|
}
|
|
environment {
|
|
PROJECT_NAME = 'lilium'
|
|
}
|
|
stages {
|
|
stage('Install') {
|
|
environment {
|
|
NODE_ENV = ""
|
|
}
|
|
steps {
|
|
sh 'pnpm install --prefer-offline'
|
|
}
|
|
}
|
|
// stage('Test: Unit') {
|
|
// when {
|
|
// expression { !PROTECTED_BRANCH }
|
|
// }
|
|
// environment {
|
|
// NODE_ENV = ""
|
|
// }
|
|
// steps {
|
|
// sh 'pnpm run test:unit:ci'
|
|
// }
|
|
// post {
|
|
// always {
|
|
// junit(
|
|
// testResults: 'junitresults.xml',
|
|
// allowEmptyResults: true
|
|
// )
|
|
// }
|
|
// }
|
|
// }
|
|
stage('Test: E2E') {
|
|
when {
|
|
expression { !PROTECTED_BRANCH }
|
|
}
|
|
environment {
|
|
NODE_ENV = ""
|
|
CREDENTIALS = credentials('docker-registry')
|
|
}
|
|
stages {
|
|
stage('Setup') {
|
|
steps {
|
|
script {
|
|
def packageJson = readJSON file: 'package.json'
|
|
env.VERSION = "${packageJson.version}-build${env.BUILD_ID}"
|
|
env.NETWORK = "${PROJECT_NAME}-${env.BRANCH_NAME}-${env.BUILD_ID}"
|
|
cleanDockerE2E()
|
|
sh "pnpm exec cypress install"
|
|
// sh "docker network create ${env.NETWORK} || true"
|
|
}
|
|
|
|
}
|
|
}
|
|
stage('Run E2E') {
|
|
steps {
|
|
script {
|
|
runTestsInParallel()
|
|
def containerId = sh(script: "docker-compose -p ${env.NETWORK} -f docker-compose.e2e.yml ps -q e2e", returnStdout: true).trim()
|
|
if (containerId) {
|
|
def exitCode = sh(script: "docker inspect -f '{{.State.ExitCode}}' ${containerId}", returnStdout: true).trim()
|
|
sh "docker cp ${containerId}:/app/test/cypress/reports ./test/cypress/"
|
|
if (exitCode != '0') {
|
|
def logs = sh(script: "docker logs ${containerId}", returnStdout: true).trim()
|
|
error("Cypress E2E tests failed with exit code: ${exitCode}\nLogs:\n${logs}")
|
|
}
|
|
} else {
|
|
error("The Docker container for E2E tests could not be created")
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
post {
|
|
always {
|
|
cleanDockerE2E()
|
|
}
|
|
}
|
|
}
|
|
stage('Build') {
|
|
when {
|
|
expression { PROTECTED_BRANCH }
|
|
}
|
|
environment {
|
|
CREDENTIALS = credentials('docker-registry')
|
|
}
|
|
steps {
|
|
sh 'quasar build'
|
|
script {
|
|
def packageJson = readJSON file: 'package.json'
|
|
env.VERSION = "${packageJson.version}-build${env.BUILD_ID}"
|
|
}
|
|
dockerBuild()
|
|
}
|
|
}
|
|
stage('Deploy') {
|
|
when {
|
|
expression { PROTECTED_BRANCH }
|
|
}
|
|
steps {
|
|
script {
|
|
def packageJson = readJSON file: 'package.json'
|
|
env.VERSION = "${packageJson.version}-build${env.BUILD_ID}"
|
|
}
|
|
withKubeConfig([
|
|
serverUrl: "$KUBERNETES_API",
|
|
credentialsId: 'kubernetes',
|
|
namespace: 'lilium'
|
|
]) {
|
|
sh 'kubectl set image deployment/lilium-$BRANCH_NAME lilium-$BRANCH_NAME=$REGISTRY/salix-frontend:$VERSION'
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
def cleanDockerE2E() {
|
|
script {
|
|
// sh 'docker rm -f vn-database || true'
|
|
// sh 'docker rm -f salix_e2e || true'
|
|
// sh "docker-compose -p ${env.NETWORK} -f docker-compose.e2e.yml down --volumes || true"
|
|
// sh """
|
|
// docker ps -a --format '{{.Names}}' | grep '${env.NETWORK}' | xargs -r docker-compose -p ${env.NETWORK} -f docker-compose.e2e.yml down --volumes
|
|
// """
|
|
|
|
def services = sh(script: "docker-compose -f docker-compose.e2e.yml config --services | grep ${env.NETWORK}", returnStdout: true).trim()
|
|
if (services) {
|
|
echo "${services}"
|
|
sh "docker-compose -f ${env.COMPOSE_FILE} down ${services}"
|
|
} else {
|
|
echo "No se encontraron servicios para detener."
|
|
}
|
|
|
|
|
|
def networks = sh(script: "docker network ls --filter name=${env.NETWORK} -q", returnStdout: true).trim()
|
|
if (networks) {
|
|
sh "docker network rm ${networks}"
|
|
echo "${networks}"
|
|
} else {
|
|
echo "No se encontraron redes para eliminar."
|
|
}
|
|
|
|
|
|
}
|
|
}
|
|
|
|
def runTestsInParallel() {
|
|
// def integrationTests = sh(script: "ls -d test/cypress/integration/*/ || echo ''", returnStdout: true).trim().split('\n')
|
|
def integrationTests = ['test/cypress/integration/claim/', 'test/cypress/integration/client/']
|
|
def tasks = [:]
|
|
|
|
integrationTests.each { testFolder ->
|
|
if (testFolder.trim()) {
|
|
def folderName = testFolder.replaceAll('test/cypress/integration/', '').replaceAll('/', '')
|
|
folderName = folderName.replaceAll('[^a-zA-Z0-9_-]', '') // Seguridad en nombres de red
|
|
env.CYPRESS_SPEC="test/cypress/integration/${folderName}/**/*.spec.js"
|
|
|
|
tasks["e2e_${folderName}"] = {
|
|
script {
|
|
sh "docker-compose -p ${env.NETWORK}_${folderName} -f docker-compose.e2e.yml up -d back vn-database"
|
|
sh "docker-compose -p ${env.NETWORK}_${folderName} -f docker-compose.e2e.yml up -d front"
|
|
sh "docker-compose -p ${env.NETWORK}_${folderName} -f docker-compose.e2e.yml up e2e"
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
parallel tasks
|
|
}
|