822ecab7d0
The approach is pretty straigh forward, it consists of one new module handling the project-type "flow". It supports the only field needed by this kind of project an XML block containing the flow description in a custom DSL. Change-Id: I5195391609b3058ae9e24a59024e0cc7a69b16a0 Implements: blueprint jenkins-job-builder-flow
48 lines
1.3 KiB
Python
48 lines
1.3 KiB
Python
# Copyright (C) 2013 eNovance SAS <licensing@enovance.com>
|
|
#
|
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
# you may not use this file except in compliance with the License.
|
|
# You may obtain a copy of the License at
|
|
#
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
#
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
|
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
|
# License for the specific language governing permissions and limitations
|
|
# under the License.
|
|
|
|
|
|
"""
|
|
The flow Project module handles creating Jenkins flow projects.
|
|
You may specify ``flow`` in the ``project-type`` attribute of
|
|
the :ref:`Job` definition.
|
|
|
|
Requires the Jenkins `Build Flow Plugin.
|
|
<https://wiki.jenkins-ci.org/display/JENKINS/Build+Flow+Plugin>`_
|
|
|
|
Example::
|
|
|
|
job:
|
|
name: test_job
|
|
project-type: flow
|
|
dsl: |
|
|
build("job1")
|
|
parallel (
|
|
{ build("job2a") },
|
|
{ build("job2b") }
|
|
)
|
|
"""
|
|
|
|
import xml.etree.ElementTree as XML
|
|
import jenkins_jobs.modules.base
|
|
|
|
|
|
class Flow(jenkins_jobs.modules.base.Base):
|
|
sequence = 0
|
|
|
|
def root_xml(self, data):
|
|
xml_parent = XML.Element('com.cloudbees.plugins.flow.BuildFlow')
|
|
XML.SubElement(xml_parent, 'dsl').text = data['dsl']
|
|
return xml_parent
|