"The Protocol Master" is an infrastructure simulator to test effortlessy your app in minutes (with no coding) supporting HTTP, HTTPS, Postgres, MySQL, Redis, Mqtt, RabbitMQ, AMQP 091 ... and all the compatible ones!
- Simulate wrong scenarios
- Block troubles before production
- Simulate whole infrastructure
- Make untestable apps testable
- Easy Chaos engineering
Effortlessy and with zero budget
Look at "The Protocol Master Samples" repository to create a complete docker environment to have a gimplse of the features in various languages and environments
- Python/MySQL/RabbitMQ
- .Net Core/Entity Framework/MySQL
- Go/Redis/Postgres
- Java/Spring/MySQL/MQTT
It's simple it's a multiprotocol proxy on your box (or wetheaver you want) Independent from the stack you are using
- Simulate what-if without hitting real servers
- Testing resiliency, errors and wrong data
- Security analisys (what goes on the wire)
- Test new APIs easily
- Understand all consequences of changes
You can build your own plugins, just place the Jar into the plugins dir and intercept all it's intercepted by TPM. Add headers, change data, simulate specific needs
Open a http/s proxy on port 9999 and record everything that goes through
java -jar protocol-runner.jar -protocol http -proxy 9999 \
-record
Create a local postgres "forward proxy" to a real one and record everything
java -jar protocol-runner.jar -protocol postgres \
-connection jdbc:postgresql://REALSERVER:5432 \
-login REALLOGIN -password REALPWD \
-record
Open a http/s proxy on port 9999 and return a 503 error, on 50% of calls
java -jar protocol-runner.jar -protocol http -proxy 9999 \
-showError 503 -errorPercent 40
- Language independent: use the native protocols without drivers
- Run on all OSs
- Windows
- Linux
- macOs
- Native protocol for (and all compatibles):
- anything that goes through http/https
- postgres
- mysql
- mongoDB
- redis 3,redis 2
- mqtt
- rabbitmq/Amqp 0.9
- Mocked flow (all)
- Support gzip,brotli,jacksonSmile,multipart and more (http/s)
- Mocked error response (http/s)
- Mocked (optionally parametrized) responses (http/s,mysql,postgres) (nth, and count)
- Internal rewrite queries and urls (http/s,mysql,postgres)
- Record/replay activity-Gold standards-Zero infrastructure (all)
- Handle callback mocks during replay automagically (mqtt,amqp,redis)
- Custom transparent proxy (all)
- Translate postgres and MySQL to any Jdbc supported db like Oracle!
- Plugin-based architecture
- Custom maven repository on https://maven.kendar.org
- More than 70% Test coverage
The configuration is based on command line parameters or a json properties file for the usage check here
For the api usage here is the swagger: http//localhost:apisPort/swagger-ui/index.html
If you want to go on the specific functions by protocol:
- Http
- Support Http and Https as Man In The Middle
- Custom proxy to intercept without DNS changes
- PostgresSQL Usable for most db (for hibernate you should set the final db dialect of
course)
- Support for simple and extended query protocol
- Transactions
- Simple authentication (could add an "auth provider")
- MySQL
- Support for cached queries and stored procedures
- Simple authentication (could add an "auth provider")
- MongoDB
- Basic authentication
- RabbitMq/AMQP 0.9.1
- Support for all kind of publish/consume
- Channels multiplexing
- Redis
- Support for subscriptions
- Support for push parsing
- RESP2 and RESP3 supported out of the box
- Mqtt
- Support QOS 1,2,3
- Support 3.x and 5.x protocols
The Protocol Master
un unattended Unattended run (default false)
cfg config Load config file
pld pluginsDir Plugins directory (default plugins)
dd datadir Data directory (default data)
ll loglevel Log4j loglevel (default ERROR)
ap apis The port TPM controllers (default 0, as not active)
lt logType The log type (default file)
h help Show help
p protocol The protocols to start
Options: amqp091|mqtt|http|mysql|mongodb|postgres|redis
Amqp 0.9.1 Protocol
po port Listening port (default 5672)
pc connection Connection (example amqp://localhost:5372)
pt timeout Timeout (deafult 30)
pu login Remote login
pw password Remote password
record Record Calls
replay Replay calls
Mqtt Protocol
po port Listening port (default 1883)
pc connection Connection (example tcp://localhost:1884)
pt timeout Timeout (deafult 30)
pu login Remote login
pw password Remote password
record Record Calls
replay Replay calls
http Protocol
ht http Http port (default 80
hs https Https port (default 443
prx proxy Proxy port (default 9999
cn cname Cname (default C=US,O=Local Development,CN=local.org
der Der file (default resource://certificates/ca.der
key Key file (default resource://certificates/ca.key
rew rewrite Path of the rewrite queries file
record Record Calls
replay Replay calls
errors Random errors
latency Random latency
mysql Protocol
po port Listening port (default 3306)
pc connection Connection (example jdbc:mysql://localhost:3306)
pt timeout Timeout (deafult 30)
pu login Remote login
pw password Remote password
js schema Force schema name
rew rewrite Path of the rewrite queries file
record Record Calls
replay Replay calls
MongoDb Protocol
po port Listening port (default 27018)
pc connection Connection (example mongodb://localhost:27018)
pt timeout Timeout (deafult 30)
pu login Remote login
pw password Remote password
record Record Calls
replay Replay calls
postgres Protocol
po port Listening port (default 5432)
pc connection Connection (example jdbc:postgresql://localhost:5432/db?ssl=false)
pt timeout Timeout (deafult 30)
pu login Remote login
pw password Remote password
js schema Force schema name
rew rewrite Path of the rewrite queries file
record Record Calls
replay Replay calls
Redis Protocol
po port Listening port (default 6379)
pc connection Connection (example redis://localhost:5372)
pt timeout Timeout (deafult 30)
record Record Calls
replay Replay calls
I had an always missing QA environment and all changes should be checked by legal (it was in Electronic ID field). I needed to simulate APIs, Database calls, and full scenarios, from UI to the DB.
I started developing a series of docker container in PHP to intercept all incoming and outgoing HTTP/S call, with DNS server and certificates, you can find it here.
Becoming the thing too hard to cope with i started the development of a Java integrated version with fancy UI and all integrated service, the HttpAnsweringMachine based on Spring-Boot and leveraging a custom routing system, dns server and so on.
But that was too really hard to interact with. I started developing a JDBC->HTTP->JDBC driver, Janus-Jdbc from scratch, then started creating a similar thing for .NET, thing went rogues in a short time with Janus-Ado. But i started understanding Postgres protocol.
I started then with a command line utility to parse and translate binary protocols and that's how "The Protocol Master" was born. Always with a plugin-based architecture. Then i started adapting all the knowledge of HttpAnsweringMachine inside it to handle HTTP/S.
The state machine (or better the Behaviour tree fsm) is based on
- States (extending ProtoState) able to interact with events
- Events (extending BaseEvent) to invoke action on states
- Context (extending ProtoContext) it is the memory storage for the current execution (connection) and the current state
When bytes arrives to the TM they are transformed in a "BytesEvent" and then consumed by the specific connection thread, then all the child states of the current state are verified. They have the responsibility to check if the message is of the correct type and then if the content is matching the signature.
When a state is hit it can send events or response messages. When an execution runs without errors then the "executed incoming buffer" is purged from the received bytes
The events are immediatly executed. If no bytes are present or there are not enough bytes to read, the events queue is seeked for "BytesEvent" and then the execution is retried.