From 3cd56ef3b3c62a5a87a926a089192a399b7183cd Mon Sep 17 00:00:00 2001 From: Jesse Glick Date: Thu, 6 Aug 2015 18:33:04 -0400 Subject: [PATCH] Copying http://developer-blog.cloudbees.com/2015/08/workflow-19-and-multibranch-beta.html information into the tutorial. --- TUTORIAL.md | 20 ++++++++++++++++++++ 1 file changed, 20 insertions(+) diff --git a/TUTORIAL.md b/TUTORIAL.md index 16cd9ed3b..5d89ab350 100644 --- a/TUTORIAL.md +++ b/TUTORIAL.md @@ -673,6 +673,26 @@ In this case `devQAStaging` runs on the same node as the main source code checko Injection of function and class names into a flow before it runs is handled by plugins, and one is bundled with workflow that allows you to get rid of the above boilerplate and keep the whole script (except one “bootstrap” line) in a Git server hosted by Jenkins. A [separate document](cps-global-lib/README.md) has details on this system. +## Multibranch projects + +A new _Workflow: Multibranch_ plugin (as of this writing still in beta) offers an even better way of versioning your Workflow, and managing your project generally. +You need to create a distinct project type, _Multibranch Workflow_. + +When you have a multibranch workflow, the configuration screen will resemble _Groovy CPS DSL from SCM_ in that your Workflow script comes from source control, not the Jenkins job configuration. +The difference is that you do not configure a single branch, but a _set_ of branches, and Jenkins creates a subproject for each branch it finds in your repository. + +For example, if you select _Git_ as the branch source (Subversion and Mercurial are also supported already), you will be prompted for the usual connection information, +but then rather than a fixed refspec you will enter a branch name pattern (use the defaults to look for any branch). +Jenkins expects to find a script named `jenkins.groovy` in branches it can build. +From this script, the command `checkout scm` suffices to check out your project’s source code inside some `node {}`. + +Say you start with just a `master` branch, then you want to experiment with some changes, so you `git checkout -b newfeature` and push some commits. +Jenkins will automatically detect the new branch in your repository and create a new subproject for it—with its own build history unrelated to trunk, so no one will mind if it has red/yellow balls for a while. +(If you like, you can ask for the subproject to be automatically removed after the branch is merged and deleted.) + +The neat thing is that if you want to change your Workflow script—for example, to add a new Jenkins publisher step corresponding to reports your `Makefile`/`pom.xml`/etc. is newly creating—you just edit `jenkins.groovy` in your change. +The Workflow script is always synchronized with the rest of the source code you are working on: `checkout scm` checks out the same revision as the script is loaded from. + # Exploring available steps There are a number of workflow steps not discussed in this document, and plugins can add more.