blob: 39e2c9d4f06f717a9a1b4dc0f19127f9ea16631f [file] [log] [blame]
:linkattrs:
= Gerrit Code Review - JavaScript Plugin Checks API
This API is provided by link:pg-plugin-dev.html#plugin-checks[plugin.checks()].
It allows plugins to contribute to the "Checks" tab and summary:
image::images/user-checks-overview.png[width=800]
Each plugin can link:#register[register] a checks provider that will be called
when a change page is loaded. Such a call would return a list of `Runs` and each
run can contain a list of `Results`.
`Results` messages will render as markdown. It follows the
[CommonMark](https://commonmark.org/help/) spec except inline images and direct
HTML are not rendered and kept as plaintext.
The details of the ChecksApi are documented in the
link:https://gerrit.googlesource.com/gerrit/+/master/polygerrit-ui/app/api/checks.ts[source code].
Note that this link points to the `master` branch and might thus reflect a
newer version of the API than your Gerrit installation.
If no plugins are registered with the ChecksApi, then the Checks tab will be
hidden.
You can read about the motivation, the use cases and the original plans in the
link:https://www.gerritcodereview.com/design-docs/ci-reboot.html[design doc].
Here are some examples of open source plugins that make use of the Checks API:
* link:https://gerrit.googlesource.com/plugins/checks/+/master/gr-checks/plugin.js[Gerrit Checks Plugin]
* link:https://chromium.googlesource.com/infra/gerrit-plugins/buildbucket/+/main/web/plugin.ts[Chromium Buildbucket Plugin]
* link:https://chromium.googlesource.com/infra/gerrit-plugins/code-coverage/+/main/web/plugin.ts[Chromium Coverage Plugin]
[[register]]
== register
`checksApi.register(provider, config?)`
.Params
- *provider* Must implement a `fetch()` interface that returns a
`Promise<FetchResponse>` with runs and results. See also documentation in the
link:https://gerrit.googlesource.com/gerrit/+/master/polygerrit-ui/app/api/checks.ts[source code].
- *config* Optional configuration values for the checks provider.
[[announceUpdate]]
== announceUpdate
`checksApi.announceUpdate()`
Tells Gerrit to call `provider.fetch()`.
[[updateResult]]
== updateResult
`checksApi.updateResult(run: CheckRun, result: CheckResult)`
Updates an individual result. This can be used for lazy laoding detailled
information. For example, if you are using the
link:pg-plugin-endpoints.html#_check_result_expanded[`check-result-expanded`
endpoint], then you can load more result details when the user expands a result
row.
The parameter `run` is only used to *find* the correct run for updating the
result. It will only be used for comparing `change`, `patchset`, `attempt` and
`checkName`. Its properties other than `results` will not be updated.
For us being able to identify the result that you want to update you have to
set the `externalId` property. An undefined `externalId` will result in an
error.
An example usage can be found in link:https://chromium.googlesource.com/infra/gerrit-plugins/buildbucket/+/main/web/checks-result.ts[Chromium Buildbucket Plugin].