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. dir("${env.WORKSPACE}/angular-client") {
  45. def karma = docker.image('trion/ng-cli-karma')
  46. karma.pull()
  47. try {
  48. karma.run('-u $(id -u) -v ${WORKSPACE}:/app trion/ng-cli-karma') {
  49. sh 'npm install --force'
  50. // Ajouter la configuration spécifique pour le fournisseur d'OpenSSL
  51. sh 'export NODE_OPTIONS=--openssl-legacy-provider'
  52. try {
  53. sh 'ng test'
  54. } catch (err) {
  55. sh 'echo TEST FAILED'
  56. step([$class: 'JUnitResultArchiver', testResults: 'target/surefire-reports/TESTS-TestSuite.xml/*.xml', healthScaleFactor: 1.0])
  57. throw err
  58. }
  59. sh 'echo DO SOMETHING ELSE AFTER TEST'
  60. }
  61. sh 'ls -al '
  62. } catch (err) {
  63. sh 'echo RUN DOCKER FAILED'
  64. throw err
  65. }
  66. }
  67. }
  68. // def imageApache = stage("Build apache preprod")
  69. // {
  70. // 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 .")
  71. // }
  72. // def imageExpress = stage("Build express preprod")
  73. // {
  74. // docker.build("server-express-preprod", "--no-cache -f express-server/Dockerfile express-server")
  75. // }
  76. /*stage("Run Container express preprod")
  77. {
  78. containerSql=imageExpress.run("--name server-express-preprod -v /var/log:/var/www/app/log/root --link database_preprod:mongo --network=web")
  79. }
  80. stage("Run Container apache preprod")
  81. {
  82. containerApache=imageApache.run("--name server-apache-preprod --link server-mysql-preprod:mysql --network=web")
  83. }*/
  84. /*stage("Run Container express preprod")
  85. {
  86. containerSql=imageExpress.run("--name server-express-preprod -v /home/projet/fatboar/${e}/mysql:/var/lib/mysql --network=web")
  87. }
  88. stage("Run Container apache preprod")
  89. {
  90. containerApache=imageApache.run("--name server-apache-preprod --link server-mysql-preprod:mysql --network=web")
  91. }*/
  92. // stage("Push preprod images to nexus")
  93. // {
  94. // /*docker.withRegistry('http://localhost:8083','885ef60c-9352-489a-bd1c-e4b695747c21')
  95. // {
  96. // imageApache.push('latest')
  97. // imageExpress.push('latest')
  98. // }*/
  99. // }
  100. // stage('SonarQube analysis')
  101. // {
  102. // def scannerHome = tool name: 'SonarQube Scanner', type: 'hudson.plugins.sonar.SonarRunnerInstallation';
  103. // withSonarQubeEnv('SonarQube')
  104. // {
  105. // // If you have configured more than one global server connection, you can specify its name
  106. // sh "${scannerHome}/bin/sonar-scanner \
  107. // -Dsonar.projectKey=FatboarProject \
  108. // -Dsonar.sources=. \
  109. // -Dsonar.host.url=https://sonarqube.foodgame.fr \
  110. // -Dsonar.login=sqp_09ee9072c917af8212864baf0f75c950afc14c64"
  111. // }
  112. // }
  113. // stage('Build Docker MEAN Stack(Test Deployment)')
  114. // {
  115. // sh 'docker-compose -v'
  116. // sh 'docker-compose build'
  117. // sh 'docker-compose up -d'
  118. // }
  119. stage('Fin du Pipeline')
  120. {
  121. sh 'echo "Félicitation tout c\'est bien déroulé!"'
  122. }
  123. }