282 lines
9.7 KiB
Groovy
282 lines
9.7 KiB
Groovy
#!/usr/bin/env groovy
|
|
|
|
def PROTECTED_BRANCH
|
|
def FROM_GIT
|
|
def RUN_TESTS
|
|
def RUN_BUILD
|
|
|
|
def BRANCH_ENV = [
|
|
test: 'test',
|
|
master: 'production'
|
|
]
|
|
|
|
node {
|
|
stage('Setup') {
|
|
env.BACK_REPLICAS = 1
|
|
env.NODE_ENV = BRANCH_ENV[env.BRANCH_NAME] ?: 'dev'
|
|
|
|
PROTECTED_BRANCH = [
|
|
'dev',
|
|
'test',
|
|
'master'
|
|
].contains(env.BRANCH_NAME)
|
|
|
|
FROM_GIT = env.JOB_NAME.startsWith('gitea/')
|
|
RUN_TESTS = !PROTECTED_BRANCH && FROM_GIT
|
|
RUN_BUILD = PROTECTED_BRANCH && FROM_GIT
|
|
|
|
// 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.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.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-v20'
|
|
}
|
|
environment {
|
|
PROJECT_NAME = 'salix'
|
|
}
|
|
stages {
|
|
stage('Install') {
|
|
environment {
|
|
NODE_ENV = ''
|
|
}
|
|
parallel {
|
|
stage('Back') {
|
|
steps {
|
|
sh 'pnpm install --prefer-offline'
|
|
sh 'node node_modules/puppeteer/install.mjs'
|
|
}
|
|
}
|
|
stage('Print') {
|
|
when {
|
|
expression { FROM_GIT }
|
|
}
|
|
steps {
|
|
sh 'pnpm install --prefer-offline --prefix=print'
|
|
}
|
|
}
|
|
stage('Front') {
|
|
when {
|
|
expression { FROM_GIT }
|
|
}
|
|
steps {
|
|
sh 'pnpm install --prefer-offline --prefix=front'
|
|
}
|
|
}
|
|
|
|
}
|
|
}
|
|
// stage('Push image') {
|
|
// environment {
|
|
// CREDENTIALS = credentials('docker-registry')
|
|
// IMAGE = "$REGISTRY/salix-back"
|
|
// }
|
|
// steps {
|
|
// script {
|
|
// def packageJson = readJSON file: 'package.json'
|
|
// env.VERSION = "e2e-try"
|
|
// }
|
|
// sh 'docker-compose build back'
|
|
// sh 'docker login --username $CREDENTIALS_USR --password $CREDENTIALS_PSW $REGISTRY'
|
|
// sh 'docker tag $IMAGE:$VERSION $IMAGE:$GIT_BRANCH'
|
|
// sh 'docker push $IMAGE:$GIT_BRANCH'
|
|
// }
|
|
// }
|
|
stage('Stack') {
|
|
parallel {
|
|
stage('Back') {
|
|
stages {
|
|
stage('Test') {
|
|
when {
|
|
expression { RUN_TESTS }
|
|
}
|
|
environment {
|
|
NODE_ENV = ''
|
|
}
|
|
steps {
|
|
sh 'node back/tests.js --junit'
|
|
}
|
|
post {
|
|
always {
|
|
junit(
|
|
testResults: 'junitresults.xml',
|
|
allowEmptyResults: true
|
|
)
|
|
}
|
|
}
|
|
}
|
|
stage('Build') {
|
|
when {
|
|
expression { RUN_BUILD }
|
|
}
|
|
steps {
|
|
script {
|
|
def packageJson = readJSON file: 'package.json'
|
|
env.VERSION = "${packageJson.version}-build${env.BUILD_ID}"
|
|
}
|
|
sh 'docker-compose build back'
|
|
}
|
|
}
|
|
}
|
|
}
|
|
stage('Front') {
|
|
when {
|
|
expression { FROM_GIT }
|
|
}
|
|
stages {
|
|
stage('Test') {
|
|
when {
|
|
expression { RUN_TESTS }
|
|
}
|
|
environment {
|
|
NODE_ENV = ''
|
|
}
|
|
steps {
|
|
sh 'jest --ci --reporters=default --reporters=jest-junit --maxWorkers=10'
|
|
}
|
|
post {
|
|
always {
|
|
junit(
|
|
testResults: 'junit.xml',
|
|
allowEmptyResults: true
|
|
)
|
|
}
|
|
}
|
|
}
|
|
stage('Build') {
|
|
when {
|
|
expression { RUN_BUILD }
|
|
}
|
|
steps {
|
|
script {
|
|
def packageJson = readJSON file: 'package.json'
|
|
env.VERSION = "${packageJson.version}-build${env.BUILD_ID}"
|
|
}
|
|
sh 'gulp build'
|
|
sh 'docker-compose build front'
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
stage('Push') {
|
|
when {
|
|
expression { RUN_BUILD }
|
|
}
|
|
environment {
|
|
CREDENTIALS = credentials('docker-registry')
|
|
}
|
|
steps {
|
|
script {
|
|
def packageJson = readJSON file: 'package.json'
|
|
env.VERSION = "${packageJson.version}-build${env.BUILD_ID}"
|
|
}
|
|
sh 'docker login --username $CREDENTIALS_USR --password $CREDENTIALS_PSW $REGISTRY'
|
|
sh 'docker-compose push'
|
|
script {
|
|
if (env.BRANCH_NAME == 'master') {
|
|
sh 'docker tag $IMAGE:$TAG $IMAGE:latest'
|
|
sh 'docker push $IMAGE:latest'
|
|
}
|
|
}
|
|
}
|
|
}
|
|
stage('Deploy') {
|
|
when {
|
|
expression { PROTECTED_BRANCH }
|
|
}
|
|
parallel {
|
|
stage('Database') {
|
|
steps {
|
|
configFileProvider([
|
|
configFile(fileId: "config.${env.NODE_ENV}.ini",
|
|
variable: 'MYSQL_CONFIG')
|
|
]) {
|
|
sh 'mkdir -p db/remotes'
|
|
sh 'cp "$MYSQL_CONFIG" db/remotes/$NODE_ENV.ini'
|
|
}
|
|
|
|
sh 'npx myt push $NODE_ENV --force --commit'
|
|
}
|
|
}
|
|
stage('Kubernetes') {
|
|
when {
|
|
expression { FROM_GIT }
|
|
}
|
|
steps {
|
|
script {
|
|
def packageJson = readJSON file: 'package.json'
|
|
env.VERSION = "${packageJson.version}-build${env.BUILD_ID}"
|
|
}
|
|
withKubeConfig([
|
|
serverUrl: "$KUBERNETES_API",
|
|
credentialsId: 'kubernetes',
|
|
namespace: 'salix'
|
|
]) {
|
|
sh 'kubectl set image deployment/salix-back-$BRANCH_NAME salix-back-$BRANCH_NAME=$REGISTRY/salix-back:$VERSION'
|
|
sh 'kubectl set image deployment/salix-front-$BRANCH_NAME salix-front-$BRANCH_NAME=$REGISTRY/salix-front:$VERSION'
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
post {
|
|
success {
|
|
script {
|
|
if (env.BRANCH_NAME == 'master' && FROM_GIT) {
|
|
env.GIT_COMMIT_MSG = sh(
|
|
script: 'git log -1 --pretty=%B ${GIT_COMMIT}',
|
|
returnStdout: true
|
|
).trim()
|
|
|
|
String message = env.GIT_COMMIT_MSG
|
|
int index = message.indexOf('\n')
|
|
if (index != -1)
|
|
message = message.substring(0, index)
|
|
|
|
setEnv()
|
|
rocketSend(
|
|
channel: 'vn-database',
|
|
message: "*DB version uploaded:* ${message}"
|
|
+"\n$COMMITTER_EMAIL ($BRANCH_NAME)"
|
|
+"\n$RUN_DISPLAY_URL",
|
|
rawMessage: true
|
|
)
|
|
}
|
|
}
|
|
}
|
|
unsuccessful {
|
|
setEnv()
|
|
sendEmail()
|
|
}
|
|
}
|
|
}
|