Jenkinsfile 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145
  1. node{
  2. stage('Prepare Node and NPM') { // confirm nodejs plugin and setting
  3. env.NODEJS_HOME = "${tool 'NodeJS'}"
  4. //on linux / mac
  5. env.PATH="${env.NODEJS_HOME}/bin:${env.PATH}"
  6. // on windows
  7. // env.PATH="${env.NODEJS_HOME};${env.PATH}"
  8. sh 'npm --version'
  9. }
  10. stage('checkout'){
  11. deleteDir()
  12. checkout scm
  13. echo 'Pulling..................' + env.BRANCH_NAME
  14. }
  15. stage('Stop Container'){
  16. sh 'docker ps | grep "workflow_" -v | awk -F " " \'{if(NR>1)print $1}\' | xargs docker kill | xargs docker rm || true'
  17. sh 'docker system prune -f'
  18. }
  19. //stage('Build Container')
  20. // {
  21. // imageApache=docker.build('server-apache-dev', '--no-cache -f build/docker/apache/Dockerfile .')
  22. // imageSql=docker.build('server-mysql-dev', '--no-cache -f build/docker/mysql/Dockerfile .')
  23. // containerMysql=imageSql.run('--name server-mysql-dev')
  24. // containerApache=imageApache.run('-p 8080:80 --link server-mysql-dev:mysql')
  25. // }
  26. // stage('Waiting Container'){
  27. // waitUntil{
  28. // try{
  29. // sh "docker exec ${containerApache.id} php -v"
  30. // return true
  31. // } catch(Exception $e){
  32. // return false
  33. // }
  34. // }
  35. // }
  36. stage('stage 1bis'){
  37. sh 'docker -v'
  38. sh 'docker ps'
  39. }
  40. stage('stage 2bis'){
  41. sh 'ls -ls'
  42. }
  43. stage('Test') {
  44. steps {
  45. dir("${env.WORKSPACE}/angular-client") {
  46. def karma = docker.image('trion/ng-cli-karma')
  47. karma.pull()
  48. try {
  49. karma.run('-u $(id -u) -v ${WORKSPACE}:/app trion/ng-cli-karma') {
  50. sh 'npm install --force'
  51. // Ajouter la configuration spécifique pour le fournisseur d'OpenSSL
  52. sh 'export NODE_OPTIONS=--openssl-legacy-provider'
  53. try {
  54. sh 'ng test'
  55. } catch (err) {
  56. sh 'echo TEST FAILED'
  57. step([$class: 'JUnitResultArchiver', testResults: 'target/surefire-reports/TESTS-TestSuite.xml/*.xml', healthScaleFactor: 1.0])
  58. throw err
  59. }
  60. sh 'echo DO SOMETHING ELSE AFTER TEST'
  61. }
  62. sh 'ls -al '
  63. } catch (err) {
  64. sh 'echo RUN DOCKER FAILED'
  65. throw err
  66. }
  67. }
  68. }
  69. }
  70. // def imageApache = stage("Build apache preprod")
  71. // {
  72. // docker.build("server-apache-preprod", "--no-cache --label traefik.enable=true --label traefik.http.routers.server-apache-preprod.rule='Host(`angular-preprod.foodgame.fr`)' --label traefik.http.routers.server-apache-preprod.entrypoints=websecure --label traefik.http.routers.server-apache-preprod.tls.certresolver=myresolver -f build/docker/httpd/Dockerfile .")
  73. // }
  74. // def imageExpress = stage("Build express preprod")
  75. // {
  76. // docker.build("server-express-preprod", "--no-cache -f express-server/Dockerfile express-server")
  77. // }
  78. /*stage("Run Container express preprod")
  79. {
  80. containerSql=imageExpress.run("--name server-express-preprod -v /var/log:/var/www/app/log/root --link database_preprod:mongo --network=web")
  81. }
  82. stage("Run Container apache preprod")
  83. {
  84. containerApache=imageApache.run("--name server-apache-preprod --link server-mysql-preprod:mysql --network=web")
  85. }*/
  86. /*stage("Run Container express preprod")
  87. {
  88. containerSql=imageExpress.run("--name server-express-preprod -v /home/projet/fatboar/${e}/mysql:/var/lib/mysql --network=web")
  89. }
  90. stage("Run Container apache preprod")
  91. {
  92. containerApache=imageApache.run("--name server-apache-preprod --link server-mysql-preprod:mysql --network=web")
  93. }*/
  94. // stage("Push preprod images to nexus")
  95. // {
  96. // /*docker.withRegistry('http://localhost:8083','885ef60c-9352-489a-bd1c-e4b695747c21')
  97. // {
  98. // imageApache.push('latest')
  99. // imageExpress.push('latest')
  100. // }*/
  101. // }
  102. // stage('SonarQube analysis')
  103. // {
  104. // def scannerHome = tool name: 'SonarQube Scanner', type: 'hudson.plugins.sonar.SonarRunnerInstallation';
  105. // withSonarQubeEnv('SonarQube')
  106. // {
  107. // // If you have configured more than one global server connection, you can specify its name
  108. // sh "${scannerHome}/bin/sonar-scanner \
  109. // -Dsonar.projectKey=FatboarProject \
  110. // -Dsonar.sources=. \
  111. // -Dsonar.host.url=https://sonarqube.foodgame.fr \
  112. // -Dsonar.login=sqp_09ee9072c917af8212864baf0f75c950afc14c64"
  113. // }
  114. // }
  115. // stage('Build Docker MEAN Stack(Test Deployment)')
  116. // {
  117. // sh 'docker-compose -v'
  118. // sh 'docker-compose build'
  119. // sh 'docker-compose up -d'
  120. // }
  121. stage('Fin du Pipeline')
  122. {
  123. sh 'echo "Félicitation tout c\'est bien déroulé!"'
  124. }
  125. }