Sök…


Jenkins 2.0+ pipeline script

Moderna versioner av Jenkins (version 2.x) kommer med ett "Build Pipeline Plugin" som kan användas för att utforma komplexa CI-uppgifter utan att skapa en mängd sammankopplade jobb och låter dig enkelt versionskontrollera din build / testkonfiguration.

Du kan installera detta manuellt i ett "Pipeline" -jobb, eller om ditt projekt är värd på Github kan du använda "GitHub Organization Folder Plugin" för att automatiskt ställa in jobb för dig.

Här är en enkel konfiguration för Django-webbplatser som endast kräver att webbplatsens specificerade pythonmoduler installeras.

#!/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

Här är ett exempel på ett pipeline-skript som bygger en Docker-behållare och sedan kör testen inuti den. Ingångspunkten antas vara antingen manage.py eller invoke / fabric med ett runtests tillgängligt.

#!/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
Licensierat under CC BY-SA 3.0
Inte anslutet till Stack Overflow