544937921c
Change-Id: I45d881bb87e465e826884dd0286b4900fb93059a
90 lines
2.2 KiB
Plaintext
90 lines
2.2 KiB
Plaintext
Gerrit Code Review - REST API Developers' Notes
|
|
===============================================
|
|
|
|
This document is about developing the REST API. For details of the
|
|
actual APIs available in Gerrit, please see the
|
|
link:rest-api.html[REST API interface reference].
|
|
|
|
|
|
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/
|
|
----
|
|
|
|
|
|
Authentication
|
|
~~~~~~~~~~~~~~
|
|
|
|
To test APIs that require authentication, the username and password must be specified on
|
|
the command line:
|
|
|
|
----
|
|
curl --digest --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 --digest -n http://localhost:8080/a/path/to/api/
|
|
----
|
|
|
|
In both cases, the password should be the user's link:user-upload.html#http[HTTP password].
|
|
|
|
|
|
Verifying Header Content
|
|
~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
To verify the headers returned from a REST API call, use `curl` in verbose mode:
|
|
|
|
----
|
|
curl -v -n --digest -X DELETE http://localhost:8080/a/path/to/api/
|
|
----
|
|
|
|
The headers on both the request and the response will be printed.
|
|
|
|
|
|
GERRIT
|
|
------
|
|
Part of link:index.html[Gerrit Code Review]
|
|
|