Source code

Revision control

Copy as Markdown

Other Tools

:mod:`mozproxy` --- Provides an HTTP proxy
==========================================
Mozproxy let you launch an HTTP proxy when we need to run tests against
third-part websites in a reliable and reproducible way.
Mozproxy provides an interface to a proxy software, and the currently
supported backend is **mitmproxy** for Desktop and Android.
Mozproxy is used by Raptor to run performance test without having to interact
with the real web site.
Mozproxy provide a function that returns a playback class. The usage pattern is
.. rstcheck: ignore-languages=python
.. code-block:: python
from mozproxy import get_playback
config = {'playback_tool': 'mitmproxy'}
pb = get_playback(config)
pb.start()
try:
# do your test
finally:
pb.stop()
**config** is a dict with the following options:
- **playback_tool**: name of the backend. can be "mitmproxy", "mitmproxy-android"
- **playback_version**: playback tool version
- **playback_files**: playback recording path/manifest/URL
- **binary**: path of the browser binary
- **obj_path**: build dir
- **platform**: platform name (provided by mozinfo.os)
- **run_local**: if True, the test is running locally.
- **app**: tested app. Can be "firefox", "geckoview", "refbrow", "fenix" or "firefox"
- **host**: hostname for the policies.json file
- **local_profile_dir**: profile dir
Supported environment variables:
- **MOZPROXY_DIR**: directory used by mozproxy for all data files, set by mozproxy
- **MOZ_UPLOAD_DIR**: upload directory path
- **GECKO_HEAD_REPOSITORY**: used to find the certutils binary path from the CI
- **GECKO_HEAD_REV**: used to find the certutils binary path from the CI
- **HOSTUTILS_MANIFEST_PATH**: used to find the certutils binary path from the CI