Zoeken…


Jenkins 2.0+ Pipeline Script

Moderne versies van Jenkins (versie 2.x) worden geleverd met een "Build Pipeline Plugin" die kan worden gebruikt om complexe CI-taken te orkestreren zonder een groot aantal onderling verbonden taken te creëren, en waarmee u eenvoudig uw build / testconfiguratie kunt beheren.

U kunt dit handmatig installeren in een "Pipeline" -taak of, als uw project wordt gehost op Github, kunt u de "GitHub Organisation Folder Plugin" gebruiken om automatisch taken voor u in te stellen.

Hier is een eenvoudige configuratie voor Django-sites waarvoor alleen de opgegeven python-modules van de site moeten worden geïnstalleerd.

#!/usr/bin/groovy

node {
  // If you are having issues with your project not getting updated, 
  // try uncommenting the following lines.
  //stage 'Checkout'
  //checkout scm
  //sh 'git submodule update --init --recursive'

  stage 'Update Python Modules'
  // Create a virtualenv in this folder, and install or upgrade packages
  // specified in requirements.txt; https://pip.readthedocs.io/en/1.1/requirements.html
  sh 'virtualenv env && source env/bin/activate && pip install --upgrade -r requirements.txt'
  
  stage 'Test'
  // Invoke Django's tests
  sh 'source env/bin/activate && python ./manage.py runtests'
}

Jenkins 2.0+ Pipeline Script, Docker Containers

Hier is een voorbeeld van een pijplijnscript dat een Docker-container bouwt en vervolgens de tests erin uitvoert. De entrypoint wordt aangenomen dat ofwel manage.py of invoke / fabric met een runtests commando beschikbaar.

#!/usr/bin/groovy

node {
  stage 'Checkout'
  checkout scm
  sh 'git submodule update --init --recursive'

  imageName = 'mycontainer:build'
  remotes = [
    'dockerhub-account',
  ]

  stage 'Build'
  def djangoImage = docker.build imageName

  stage 'Run Tests'
  djangoImage.run('', 'runtests')

  stage 'Push'
  for (int i = 0; i < remotes.size(); i++) {
      sh "docker tag ${imageName} ${remotes[i]}/${imageName}"
      sh "docker push ${remotes[i]}/${imageName}"
   }
}


Modified text is an extract of the original Stack Overflow Documentation
Licentie onder CC BY-SA 3.0
Niet aangesloten bij Stack Overflow