mountebank pronounces it with a plain and unpretentious accent,
reflecting his humble roots as a man of the people.
How can I post-process a response, for example, to add a custom header to
a proxied response or add a current timestamp into the response
See the decorate behavior for general purpose decoration.
You can inject headers into proxied responses using the injectHeaders field
How can I split my imposters into multiple files and have them automatically
loaded when mb restarts?
See the --configfile command line option
It can either be a single file containing the JSON that you get back when you call
GET /imposters?replayable=true
or multiple files that will be collected via templating. Alternatively, starting mb
with the --datadir command line option will load all previously saved imposters
in the database.
I'm adding mountebank as an npm dependency to my project. Why isn't npm shrinkwrap working?
This is actually a npm issue, not a bug in mountebank. Mountebank is published using npm v3, which
modifies the behavior of where npm dependencies are installed. npm v2 does not expect this, and will
throw errors because of it when trying to shrinkwrap. Upgrading to npm v3 solves this issue.
If for some reason you are stuck on npm v2, there is an only moderately inconvenient workaround.
Add all of mountebanks top level dependencies to your own package.json. Then, between npm install
and npm shrinkwrap, delete the node_modules/mountebank/node_modules folder. This workaround works
for grunt-mountebank, if you are using that as well (thanks Adam Kalman for the explanation).
I'm proxying to a server that returns gzipped (compressed) data, but I'd like to save the
data uncompressed. Is there a way to do that?
Yes! Using the injectHeaders field on the proxy,
add an 'Accept-Encoding: identity' header. That's an HTTP-based way of the proxy client telling
the server that it won't accept compressed data.
Can I use mountebank for load testing?
Yes, and field reports have indicated that mountebank may be the only open source
service virtualization tool that performs under significant load. For any long-running process, make
sure you run with the --datadir command line option so mountebank doesn't leak memory
during proxy recording or saving requests. You'll also want to use keepalive connections
for HTTP connections, so consider setting the defaultResponse
to make all Connection headers as Keep-Alive. As long as you set up each mb
instance with the same configuration, you can run multiple instances behind a load balancer (they should all
share the same volume for the --datadir option). A common
strategy is to set up a proxy in proxyAlways or proxyTransparent mode
and to capture the downstream latency by using the addWaitBehavior field to the proxy.
When you replay the saved responses, they will add the perform with roughly the same latency the
downstream services had.
Why did you misspell impostor?
mountebank is not an educated man, having spent the waking hours of his
youth caring for the poor and the sick.