Proxy Verifier is an HTTP replay tool designed to verify the behavior of HTTP proxies. It builds a verifier-client binary and a verifier-server binary which each read a set of YAML or JSON files that specify the HTTP traffic for the two to exchange.
Proxy Verifier supports the HTTP replay of the following protocols:
- Replay of HTTP and HTTPS traffic.
- Replay of HTTP/1.x traffic by both the client and the server.
- Replay of client-side HTTP/2 traffic.
In addition to replaying HTTP traffic, Proxy Verifier implements proxy traffic verification via field verification rules specified in the YAML traffic files. Each header field specification can verify one of the following:
- The absence of a field with the specified name.
- The presence of a field with the specified name.
- Both the presence of a field with the specified name and value (matched cases sensitively).
Thus the following JSON field specification requests no field verification:
- [ X-Forwarded-For, 10.10.10.2 ]
The following specifies that the HTTP field X-Forwarded-For
with any value should not have been sent by the proxy:
- [ X-Forwarded-For, 10.10.10.2, absent ]
The following specifies that X-Forwarded-For
should have been received from the proxy with the exact value "10.10.10.2":
- [ X-Forwarded-For, 10.10.10.2, equal ]
These instructions will get you a copy of the project up and running on your local machine for development and testing purposes.
Building and running Proxy Verifier requires the following to be installed on the system:
OpenSSL and Nghttp2 are linked against dynamically and have their own SCons arguments to point to their locations.
pipenv shell
pipenv install scons scons-parts
scons -j8 --with-ssl=/path/to/openssl --with-nghttp2=/path/to/nghttp2 --cfg=release proxy-verifier
This will build verifier-client
verifier-server
in the bin/
directory at the root of the repository.
To build and run the unit tests, use the run_utest
Scons target (this assumes
you are in the pipenv shell you used to build Proxy Verifier, see above):
scons -j8 --with-ssl=/path/to/openssl --with-nghttp2=/path/to/nghttp2 --cfg=release run_utest::
Proxy Verifier ships with a set of automated end to end tests written using the
AuTest
framework. To run them, simply run the autest.sh
script:
cd test/autests
./autest.sh
This sets up the pipenv shell each time which takes a few seconds. When
developing, after the first autest.sh
run, things can be expedited by
entering the shell and running the tests from in that shell:
cd test autests
pipenv shell
autest -D gold_tests
The -f
option can be used to run a particular test:
# Within the pipenv shell, as described above:
autest -D gold_tests -f https
At a high level, Proxy Verifier is run in the following manner:
- Run the verifier-server with the set of HTTP and HTTPS ports to listen on configured though the command line. The directory containing the replay file is also configured through a command line argument.
- Configure and run the proxy to listen on a set of HTTP and HTTPS ports and to proxy those connections to the listening verifier-server ports.
- Run the verifier-client with the sets of HTTP and HTTPS ports on which to connect configured though the command line. The directory containing the replay file is also configured through a command line argument.
Here's an example invocation of the verifier-server, configuring it to listen on localhost port 8080 for HTTP connections and localhost port 4443 for HTTPS connections:
verifier-server \
run \
--listen 127.0.0.1:8080 \
--listen-https 127.0.0.1:4443 \
--cert <key_and_cert_pem> \
<replay_file_directory>
Here's an example invocation of the verifier-client, configuring it to connect to the proxy which has been configured to listen on localhost port 8081 for HTTP connections and localhost port 4444 for HTTPS connections:
verifier-client \
run \
<replay_file_directory> \
127.0.0.1:8081 \
127.0.0.1:4444
With these two invocations, the verifier-client and verifier-server will replay the
sessions and transactions in <replay_file_directory>
and perform any field
verification described therein.
--keys
can be passed to the verifier-client to specify a subset of keys from
the replay file to run. Only the transactions from the space-separated list of
keys will be replayed. For example, the following invocation will only run the
transactions with keys whose values are 3 and 5:
verifier-client \
run \
<replay_file_diretory> \
127.0.0.1:8082 \
127.0.0.1:4443 \
--keys 3 5
This is a client-side only option.
Proxy Verifier has four levels of verbosity that it can run with:
Verbosity | Description |
---|---|
error | Transactions either failed to run or failed verification. |
warning | A non-failing problem occurred but something is likely to go wrong in the future. |
info | High level test execution information. |
diag | Low level debug information. |
Each level implies the ones above it. Thus, if a user specifies a verbosity
level of warning
, then both warning and error messages are reported.
By default, Proxy Verifier runs at info
verbosity, only producing summary
output by both the client and the server along with any warnings and errors it
found. This can be tweaked via the --verbose
flag. Here's an example of requesting
the most verbose level of logging (diag
):
verifier-client \
run \
<replay_file_diretory> \
127.0.0.1:8082 \
127.0.0.1:4443 \
--verbose diag
As explained above, replay files contain traffic information for both client to proxy traffic and proxy to server traffic. Under certain circumstances it may be helpful to run the Verifier client directly against the Verifier server. This can be useful while developing Proxy Verifier itself, for example, allowing the developer to do some limited testing without requiring the setup of a test proxy.
To support this, the Verifier client has the --no-proxy
option. If this
option is used, then the client has its expectations configured such that it
assumes it is run against the Verifier server rather than a proxy. Effectively
this means that instead of trying to run the client to proxy traffic, it will
instead act as the proxy host for the Verifier server and will run the proxy to
server traffic. Concretely, this means that the Verifier client will replay the
proxy-request
and proxy-response
nodes rather than the client-request
and
client-response
nodes.
This is a client-side only option.
Generally, very little about the replayed traffic is verified except what is
explicitly specified via field verification (see above). This is by design,
allowing the user to replay traffic with only the requested content being
verified. In high-volume cases, such as situations where Proxy Verifier is
being used to scale test the proxy, traffic verification may be considered
unimportant or even unnecessarily noisy. If, however, the user wants every
field to be verified regardless of specification, then the --strict
option
can be passed to either or both the Proxy Verifier client and server to report
any verification issues against every field specified in the replay file.
Please refer to CONTRIBUTING for information about how to get involved. We welcome issues, questions, and pull requests.
This project is licensed under the terms of the Apache 2.0 open source license. Please refer to LICENSE for the full terms.