Skip to main content

No project description provided

Project description

PyPi Build Status PyPI

pytest integration for


from PyPi

pip install pytest-ngrok

or from git

pip install -e git+


import pytest

from urllib.error import HTTPError
from urllib.request import urlopen

def test_ngrok(ngrok, httpserver):
    remote_url = ngrok(httpserver.port)
    assert urlopen(remote_url + "/foobar").read() == b'ok'

def test_ngrok_context_manager(ngrok, httpserver):
    # example local server
    with ngrok(httpserver.port) as remote_url:
        _test_url = str(remote_url) + '/foobar'
        assert urlopen(_test_url).read() == b'ok'

    # Connection closes
    pytest.raises(HTTPError, urlopen, _test_url)

With pytest-django can use fixture live_server_ngrok

def test_server(live_server_ngrok):
    assert live_server_ngrok.url.endswith('')


fixture lookup binary ngrok in $PATH or download binary to $HOME/.local/bin/ngrok by default.

for override it use ngrok_bin fixture

import pytest

def ngrok_bin():
    return '/path/to/writable/bin/ngrok'


run example app

pip install -r requirements-dev.txt

run tests

pip install -r requirements-dev.txt

Update version

python bumpversion

publish pypi

python publish

Project details

Download files

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

Files for pytest-ngrok, version 0.0.2
Filename, size File type Python version Upload date Hashes
Filename, size pytest_ngrok-0.0.2-py2.py3-none-any.whl (6.7 kB) File type Wheel Python version py2.py3 Upload date Hashes View
Filename, size pytest-ngrok-0.0.2.tar.gz (5.3 kB) File type Source Python version None Upload date Hashes View

Supported by

Pingdom Pingdom Monitoring Google Google Object Storage and Download Analytics Sentry Sentry Error logging AWS AWS Cloud computing DataDog DataDog Monitoring Fastly Fastly CDN DigiCert DigiCert EV certificate StatusPage StatusPage Status page