2015-01-23 10:02:08 -08:00
|
|
|
README
|
|
|
|
======
|
2012-09-21 21:34:22 +02:00
|
|
|
|
2015-07-27 22:49:41 -07:00
|
|
|
Jenkins Job Builder takes simple descriptions of Jenkins_ jobs in YAML_ or JSON_
|
|
|
|
format and uses them to configure Jenkins. You can keep your job descriptions in
|
|
|
|
human readable text format in a version control system to make changes and
|
|
|
|
auditing easier. It also has a flexible template system, so creating many
|
|
|
|
similarly configured jobs is easy.
|
2012-09-21 21:34:22 +02:00
|
|
|
|
2012-11-19 17:39:28 -05:00
|
|
|
To install::
|
|
|
|
|
2015-12-08 15:43:06 -07:00
|
|
|
$ pip install --user jenkins-job-builder
|
2012-09-21 21:34:22 +02:00
|
|
|
|
|
|
|
Online documentation:
|
|
|
|
|
2019-12-22 17:44:46 +01:00
|
|
|
* https://jenkins-job-builder.readthedocs.io/en/latest/
|
2012-11-19 17:39:28 -05:00
|
|
|
|
|
|
|
Developers
|
2015-02-04 11:54:30 +00:00
|
|
|
----------
|
2012-11-19 17:39:28 -05:00
|
|
|
Bug report:
|
|
|
|
|
2014-11-11 15:18:47 -08:00
|
|
|
* https://storyboard.openstack.org/#!/project/723
|
2012-09-21 21:34:22 +02:00
|
|
|
|
2015-01-23 10:02:08 -08:00
|
|
|
Repository:
|
|
|
|
|
2019-11-05 09:28:44 +01:00
|
|
|
* https://opendev.org/jjb/jenkins-job-builder
|
2015-01-23 10:02:08 -08:00
|
|
|
|
2015-02-24 21:06:19 +00:00
|
|
|
Cloning::
|
2012-09-21 21:34:22 +02:00
|
|
|
|
2019-11-05 09:28:44 +01:00
|
|
|
git clone https://opendev.org/jjb/jenkins-job-builder.git
|
2012-09-21 21:34:22 +02:00
|
|
|
|
2018-06-19 18:52:32 +01:00
|
|
|
Install pre-commit from https://pre-commit.com/#intro in order to run some
|
|
|
|
minimal testing on your commits.
|
|
|
|
|
2015-12-08 15:43:06 -07:00
|
|
|
A virtual environment is recommended for development. For example, Jenkins
|
|
|
|
Job Builder may be installed from the top level directory::
|
|
|
|
|
|
|
|
$ virtualenv .venv
|
|
|
|
$ source .venv/bin/activate
|
|
|
|
$ pip install -r test-requirements.txt -e .
|
|
|
|
|
2012-11-19 17:39:28 -05:00
|
|
|
Patches are submitted via Gerrit at:
|
|
|
|
|
2019-11-05 09:28:44 +01:00
|
|
|
* https://review.opendev.org
|
2012-09-21 21:34:22 +02:00
|
|
|
|
2014-04-19 08:28:15 -07:00
|
|
|
Please do not submit GitHub pull requests, they will be automatically closed.
|
|
|
|
|
2018-05-21 09:54:37 -06:00
|
|
|
Mailing list:
|
|
|
|
|
|
|
|
* https://groups.google.com/forum/#!forum/jenkins-job-builder
|
|
|
|
|
|
|
|
IRC:
|
|
|
|
|
2021-06-01 16:21:09 -04:00
|
|
|
* ``#openstack-jjb`` on OFTC
|
2018-05-21 09:54:37 -06:00
|
|
|
|
2012-09-21 21:34:22 +02:00
|
|
|
More details on how you can contribute is available on our wiki at:
|
|
|
|
|
2020-01-22 17:14:50 -05:00
|
|
|
* https://docs.openstack.org/infra/manual/developers.html
|
2012-11-19 17:39:28 -05:00
|
|
|
|
|
|
|
Writing a patch
|
2015-02-04 11:54:30 +00:00
|
|
|
---------------
|
2012-10-30 18:03:42 +01:00
|
|
|
|
2014-04-19 08:44:17 -07:00
|
|
|
We ask that all code submissions be pep8_ and pyflakes_ clean. The
|
|
|
|
easiest way to do that is to run tox_ before submitting code for
|
|
|
|
review in Gerrit. It will run ``pep8`` and ``pyflakes`` in the same
|
2012-10-30 18:03:42 +01:00
|
|
|
manner as the automated test suite that will run on proposed
|
|
|
|
patchsets.
|
|
|
|
|
|
|
|
When creating new YAML components, please observe the following style
|
|
|
|
conventions:
|
|
|
|
|
2014-04-07 14:41:32 -07:00
|
|
|
* All YAML identifiers (including component names and arguments)
|
|
|
|
should be lower-case and multiple word identifiers should use
|
|
|
|
hyphens. E.g., "build-trigger".
|
|
|
|
* The Python functions that implement components should have the same
|
|
|
|
name as the YAML keyword, but should use underscores instead of
|
|
|
|
hyphens. E.g., "build_trigger".
|
2012-10-30 18:03:42 +01:00
|
|
|
|
|
|
|
This consistency will help users avoid simple mistakes when writing
|
|
|
|
YAML, as well as developers when matching YAML components to Python
|
|
|
|
implementation.
|
|
|
|
|
2016-01-21 19:40:26 +00:00
|
|
|
Unit Tests
|
|
|
|
----------
|
|
|
|
|
|
|
|
Unit tests have been included and are in the ``tests`` folder. Many unit
|
|
|
|
tests samples are included as examples in our documentation to ensure that
|
|
|
|
examples are kept current with existing behaviour. To run the unit tests,
|
|
|
|
execute the command::
|
|
|
|
|
2022-04-11 10:00:41 -07:00
|
|
|
tox -e py38
|
2016-01-21 19:40:26 +00:00
|
|
|
|
2022-06-15 11:12:23 +03:00
|
|
|
Unit tests could be run in parallel, using pytest-parallel pytest plugin::
|
|
|
|
|
|
|
|
tox -e py38 -- --workers=auto
|
|
|
|
|
2016-01-21 19:40:26 +00:00
|
|
|
* Note: View ``tox.ini`` to run tests on other versions of Python,
|
|
|
|
generating the documentation and additionally for any special notes
|
|
|
|
on running the test to validate documentation external URLs from behind
|
|
|
|
proxies.
|
|
|
|
|
2012-11-19 17:39:28 -05:00
|
|
|
Installing without setup.py
|
2015-02-04 11:54:30 +00:00
|
|
|
---------------------------
|
2012-09-21 21:34:22 +02:00
|
|
|
|
2014-04-19 08:44:17 -07:00
|
|
|
For YAML support, you will need libyaml_ installed.
|
2012-09-21 21:34:22 +02:00
|
|
|
|
2012-11-19 17:39:28 -05:00
|
|
|
Mac OS X::
|
2012-09-21 21:34:22 +02:00
|
|
|
|
2012-11-19 17:39:28 -05:00
|
|
|
$ brew install libyaml
|
2012-09-21 21:34:22 +02:00
|
|
|
|
2014-04-19 08:44:17 -07:00
|
|
|
Then install the required python packages using pip_::
|
2012-09-21 21:34:22 +02:00
|
|
|
|
2012-11-19 17:39:28 -05:00
|
|
|
$ sudo pip install PyYAML python-jenkins
|
2014-04-19 08:44:17 -07:00
|
|
|
|
2016-01-21 19:39:09 +00:00
|
|
|
.. _Jenkins: https://jenkins.io/
|
2020-01-22 17:14:50 -05:00
|
|
|
.. _YAML: https://yaml.org
|
2015-07-27 22:49:41 -07:00
|
|
|
.. _JSON: http://json.org/
|
2020-01-22 17:14:50 -05:00
|
|
|
.. _pep8: https://pypi.org/project/pep8
|
|
|
|
.. _pyflakes: https://pypi.org/project/pyflakes
|
|
|
|
.. _tox: https://tox.readthedocs.io/en/latest
|
|
|
|
.. _libyaml: https://pyyaml.org/wiki/LibYAML
|
|
|
|
.. _pip: https://pypi.org/project/pip
|