Zuul can communicate results and progress back to configurable protocols. For example, after succeeding in a build a pipeline can be configured to post a positive review back to Gerrit.
There are three stages when a report can be handled. That is on: Start, Success or Failure. Each stage can have multiple reports. For example, you can set verified on Gerrit and send an email.
Zuul works with standard versions of Gerrit by invoking the gerrit command over an SSH connection. It reports back to Gerrit using SSH.
The dictionary passed to the Gerrit reporter is used for gerrit review arguments, with the boolean value of true simply indicating that the argument should be present without following it with a value. For example, verified: 1 becomes gerrit review --verified 1 and submit: true becomes gerrit review --submit.
A connection ArbitraryName that uses the gerrit driver must be supplied to the trigger.
A simple email reporter is also available.
A connection ArbitraryName that uses the smtp driver must be supplied to the reporter.
zuul.conf contains the SMTP server and default to/from as described in zuul.conf.
Each pipeline can overwrite the subject or the to or from address by providing alternatives as arguments to the reporter. For example,
pipelines:
- name: post-merge
manager: IndependentPipelineManager
source: my_gerrit
trigger:
my_gerrit:
- event: change-merged
success:
outgoing_smtp:
to: [email protected]
failure:
internal_smtp:
to: [email protected]
from: [email protected]
subject: Change {change} failed
This reporter is used to store results in a database.
A connection ArbitraryName that uses the sql driver must be supplied to the reporter.
zuul.conf contains the database connection and credentials. To store different reports in different databases you’ll need to create a new connection per database.
The sql reporter is used to store the results from individual builds rather than the change. As such the sql reporter does nothing on “start” or “merge-failure”.
For example
pipelines:
- name: post-merge
manager: IndependentPipelineManager
source: my_gerrit
trigger:
my_gerrit:
- event: change-merged
success:
mydb_conn:
score: 1
failure:
mydb_conn:
score: -1