blob: c7b0119f3219d3d9c727299db3c251170432c1da [file] [log] [blame] [view]
---
title: " Gerrit Code Review - REST API Developers' Notes"
sidebar: gerritdoc_sidebar
permalink: dev-rest-api.html
---
This document is about developing the REST API. For details of the
actual APIs available in Gerrit, please see the [REST API interface
reference](rest-api.html).
## Testing REST API Functionality
### Basic Testing
Basic testing of REST API functionality can be done with `curl`:
```
curl http://localhost:8080/path/to/api/
```
By default, `curl` sends `GET` requests. To test APIs with `PUT`,
`POST`, or `DELETE`, an additional argument is required:
```
curl -X PUT http://localhost:8080/path/to/api/
curl -X POST http://localhost:8080/path/to/api/
curl -X DELETE http://localhost:8080/path/to/api/
```
### Sending Data in the Request
Some REST APIs accept data in the request body of `PUT` and `POST`
requests.
Test data can be included from a local
file:
```
curl -X PUT -d@testdata.txt --header "Content-Type: application/json" http://localhost:8080/path/to/api/
```
Note that the `-d` option will remove the newlines from the content of
the local file. If the content should be sent as-is then use the
`--data-binary` option
instead:
```
curl -X PUT --data-binary @testdata.txt --header "Content-Type: text/plain" http://localhost:8080/path/to/api/
```
Example to set a Gerrit projects
[description](rest-api-projects.html#set-project-description):
```
curl -X PUT --user john:2LlAB3K9B0PF --data-binary @project-desc.txt --header "Content-Type: application/json; charset=UTF-8" http://localhost:8080/a/projects/myproject/description
```
### Authentication
To test APIs that require authentication, the username and password must
be specified on the command line:
```
curl --user username:password http://localhost:8080/a/path/to/api/
```
This makes it easy to switch users for testing of permissions.
It is also possible to test with a username and password from the
`.netrc` file (on Windows, `_netrc`):
```
curl -n http://localhost:8080/a/path/to/api/
```
In both cases, the password should be the users [HTTP
password](user-upload.html#http).
### Verifying Header Content
To verify the headers returned from a REST API call, use `curl` in
verbose mode:
```
curl -v -n -X DELETE http://localhost:8080/a/path/to/api/
```
The headers on both the request and the response will be printed.
## GERRIT
Part of [Gerrit Code Review](index.html)
## SEARCHBOX