Interactive Testing: Introduction
Get to know the learning objectives of this chapter.
We'll cover the following
Introduction
In this chapter, we will review interactive testing with HTTPie and introduce pytest, which is a great way to create Python tests. We’ll also address the challenges that come up with testing a Flask application.
How to use HTTPie
In Server-Side API Creation with Flask , we look at how to use HTTPie to interact with our web API.
$ http POST 0.0.0.0:3000/my-api number=1729 description="First taxi-cab number"
This uses the POST
method on the local server at the route /my-api
with the JSON payload:
{
"number" : 1729,
"description" : "First taxi-cab number"
}
The response is headers, then a single number, which is the ID of the new record. An alternative approach would be to return an object like {"newId":4}
instead of just the number 4
- this additional information makes it easier to use and provides context to the number returned. We’ve chosen to use the number to emphasize that JSON data is not required to be an object but can also be a string, number, null, boolean, or list.
In the example, we specify data fields using the =
sign. By default, the values are viewed as strings. Use :=
instead of =
to submit a value as a number, as shown here for the number
field.
$ http POST 0.0.0.0:3000/my-api number:=1729 description="First taxi-cab number"
Because the Flask route expects an integer, it will attempt to convert strings to integers first, so the input can be either a string or an integer and produce the same effect. HTTPie also makes it easy to specify HTTP headers using a colon, such as X-API-Token:e034a8c
, which can be useful for testing authentication methods. HTTPie can treat the key-value pairs as form input if we include the --form
or -f
option.
$ http --form POST 0.0.0.0:3000/my-api number=1105 description="First Carmichael number"
Get hands-on with 1400+ tech skills courses.