Skip to main content

Simulating poor network connections.

Project description

PyPI PyPI - Python Versions PyPI - Implementation Documentation PyPI - License Pipeline Status Coverage

Poorconn is a Python package that simulates poor network conditions. It is suitable for testing purposes, for both Python and non-Python projects.

It is capable of simulating the following poor network conditions:

  • Throttled network connections. (delay_before_sending, delay_before_sending_upon_acceptance)

  • Servers that cut off connections immediately upon accepting them. (close_upon_accepting)

  • Connections that are initially slow, but become normal subsequently. (delay_before_sending_once, delay_before_sending_upon_acceptance_once)

Quickstart

Install this package via

$ pip install 'poorconn[full]'  # or "pip install poorconn" if you don't need pytest support

The following example starts a local HTTP server at port 8000 that always closes connections upon accepting them:

from http.server import HTTPServer, SimpleHTTPRequestHandler
from poorconn import close_upon_accepting, make_socket_patchable

# Start a local HTTP server that always closes connections upon established
with HTTPServer(("localhost", 8000), SimpleHTTPRequestHandler) as httpd:
    httpd.socket = make_socket_patchable(httpd.socket)
    close_upon_accepting(httpd.socket)
    httpd.serve_forever()

After running the code above, connections from a client would establish but fail to communicate subsequently:

$ wget -t 1 http://127.0.0.1:8000
Connecting to 127.0.0.1:8000... connected.
HTTP request sent, awaiting response... No data received.
Giving up.

For another example, to start a local HTTP server that always throttle connections upon accepting them, simply replace close_upon_accepting(s) above with delay_before_sending_upon_acceptance(s, t=1, length=1024) and adjust imports (here, poorconn.delay_before_sending_upon_acceptance delays roughly 1 seconds for every 1024 bytes sent):

$ wget http://127.0.0.1:8000
Connecting to 127.0.0.1:8000... connected.
HTTP request sent, awaiting response... 200 OK
Length: 1609 (1.6K) [text/html]
Saving to: 'index.html'

index.html    1.57K   804 B/s    in 2.0s  <====== NOTE the time

'index.html' saved [1609/1609]

(Output above is abridged.)

See the poorconn module API references for a list of such simulation functions.

Integration with Pytest

If you use pytest, you can also take advantage of poorconn fixtures in poorconn.pytest_plugin. The following example gets you started with testing against a slow HTTP server:

pytest_plugins = ('poorconn',)

from pathlib import Path
import time
import requests
import pytest

@pytest.mark.poorconn_http_server_config(t=2, length=1024)
def test_slow_http_server(poorconn_http_server, tmp_path):
    "Test GETing from a slow local http server that delays 2 seconds to send every 1024 bytes."
    (tmp_path / 'index.txt').write_bytes(b'h' * 1024)
    starting_time = time.time()
    # Replace the following line with the program you want to test
    content = requests.get(f'{poorconn_http_server.url}/index.txt').content
    ending_time = time.time()
    assert ending_time - starting_time > 2

Bug Reports and Feature Requests

Please open a ticket on the GitLab Issue Tracker.

Contributing

Contributions are welcome! To get started, check out CONTRIBUTING.

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

poorconn-0.1.1.tar.gz (39.3 kB view details)

Uploaded Source

Built Distribution

poorconn-0.1.1-py3-none-any.whl (44.5 kB view details)

Uploaded Python 3

File details

Details for the file poorconn-0.1.1.tar.gz.

File metadata

  • Download URL: poorconn-0.1.1.tar.gz
  • Upload date:
  • Size: 39.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.3.0 pkginfo/1.6.1 requests/2.25.1 setuptools/50.3.2 requests-toolbelt/0.9.1 tqdm/4.55.1 CPython/3.7.3

File hashes

Hashes for poorconn-0.1.1.tar.gz
Algorithm Hash digest
SHA256 fc9b8f59cffe290a56a20bfb622aee35a15cf59fef07af2167b2250482ae7fcd
MD5 ea801c89fbd0a0456cdc1a18cf1ea8a6
BLAKE2b-256 0339ad38542a31f5b3902f26a26f973becfb8adfe9c8ca1351f4aaff268d3aca

See more details on using hashes here.

File details

Details for the file poorconn-0.1.1-py3-none-any.whl.

File metadata

  • Download URL: poorconn-0.1.1-py3-none-any.whl
  • Upload date:
  • Size: 44.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.3.0 pkginfo/1.6.1 requests/2.25.1 setuptools/50.3.2 requests-toolbelt/0.9.1 tqdm/4.55.1 CPython/3.7.3

File hashes

Hashes for poorconn-0.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 9ebdec75c9e4b2c6a2132db7af2674744c5c2a375eb8983562680da3c05833e6
MD5 2476965eff0bdb5b3fffe6e07472ac92
BLAKE2b-256 d2c4fccc3b48ec613d8f037a7fe079d58c16f0a6e283a15724629453e78bcc8b

See more details on using hashes here.

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