Skip to main content

A benchmark utility to make requests to a REST API.

Project description

pine

A benchmark utility to make requests to a REST API.

Pine makes requests to URLs a bunch of times and computes some statistics about how those requests were responded to. This is ideally useful to run on every change to your codebase so you can identify changes early.

Pine isn’t a load testing tool. If you’re trying to solve C10K, this won’t help you. Pine (currently) runs requests serially.

Documentation

Documentation is available at http://pine.readthedocs.io/en/latest/

Installation

Under normal circumstances you would just do pip install pine.

However, until PyYAML supports Python 3.7 in a released version, one extra step is required so we can install PyYAML from GitHub:

pip install git+https://github.com/yaml/pyyaml.git

https://github.com/briancurtin/pine/issues/1 and https://github.com/yaml/pyyaml/issues/126 are tracking this issue.

Usage

pine -c myconfig.yaml is the simplest way to begin. This will run your configuration and output the results to stdout. If you’d like to write the output to a file, -o myoutputfile.json will do it. If you’d like to specify a particular run ID, other than the default of the current timestamp, -i 32a63ab will do it. That’s useful for tracking the commit hash of what you’re testing.

Run pine -h for complete details.

Configuration

Pine uses YAML for configuration. See conf/example.yaml for an example.

Output

Pine writes its results in JSON, either to stdout or the path you specified in -o. It looks like the following:

{"results": [
    {"timeouts": 0, "failures": [], "name": "get_all_things",
     "description": "Get all of the things", "version": "1.0",
     "mean": 1.668359371049998,
     "median": 1.580882219500005,
     "stdev": 0.0969358463985873},
    {"timeouts": 0, "failures": [], "name": "get_one_thing",
     "description": "Get one thing", "version": "1.0",
     "mean": 0.856881387399993,
     "median": 0.508042131499991,
     "stdev": 0.0646515285845596},
 ],
 "id": "7155eb"}

Requirements

Pine uses aiohttp on Python 3.7.

Thanks

Thanks to Francis Horsman for the pine package name.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

pine-0.5.tar.gz (4.9 kB view details)

Uploaded Source

Built Distribution

pine-0.5-py2.py3-none-any.whl (10.9 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file pine-0.5.tar.gz.

File metadata

  • Download URL: pine-0.5.tar.gz
  • Upload date:
  • Size: 4.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for pine-0.5.tar.gz
Algorithm Hash digest
SHA256 721fc4d4986d7fce7f4e7212cbfc73bd3e21bcedf2c53d35072c6fe19124b08a
MD5 b7af95a738bb1a3a98c02fe99d8765af
BLAKE2b-256 ac33b6e9480c27ee40f75c8220cf2356fc765f83dce50e11e261e9f3d2332564

See more details on using hashes here.

Provenance

File details

Details for the file pine-0.5-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for pine-0.5-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 e314dbb7c8b94688a8800fa2ed786d7f3ec9b0b7c2f805d0ea808a805360b87a
MD5 b38d95a0c29ce25323c9d3bf469deafc
BLAKE2b-256 d07e26b7e9cd1168fa288a65209f6657cf097f2a702df4516604e0d0b8a860e0

See more details on using hashes here.

Provenance

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page