Mmock
Mmock is a testing and fast prototyping tool for developers:
Easy and fast HTTP mock server.
- Download Mmock
- Create a mock definition.
- Configure your application endpoints to use Mmock
- Receive the expected responses
- Inspect the requests in the web UI
- Release it to a real server
Built with Go - Mmock runs without installation on multiple platforms.
Features
- Easy mock definition via JSON or YAML
- Variables in response (fake or request data, including regex support)
- Persist request body and load response from file or MongoDB
- Ability to send message to AMQP server
- Glob matching ( /a/b/* )
- Match request by method, URL params, headers, cookies and bodies.
- Mock definitions hot replace (edit your mocks without restart)
- Web interface to view requests data (method,path,headers,cookies,body,etc..)
- Proxy mode
- Fine grain log info in web interface
- Real-time updates using WebSockets
- Priority matching
- Crazy mode for failure testing
- Public interface auto discover
- Lightweight and portable
- No installation required
Example
Mock definition file example:
{
"request": {
"method": "GET",
"path": "/hello/*"
},
"response": {
"statusCode": 200,
"headers": {
"Content-Type":["application/json"]
},
"body": "{\"hello\": \"{{request.query.name}}, my name is {{fake.FirstName}}\"}"
}
}
Or
---
request:
method: GET
path: "/hello/*"
response:
statusCode: 200
headers:
Content-Type:
- application/json
body: '{"hello": "{{request.query.name}}, my name is {{fake.FirstName}}"}'
You can see more complex examples here.
Getting started
Either:
Run it from Docker using the provided Dockerfile
or from Docker Hub
go get github.com/jmartin82/mmock
docker build -t mmock/mmock .
docker run -v YOUR_ABS_PATH:/config -p 8082:8082 -p 8083:8083 mmock/mmock
Or run mmock locally from the command line.
go get github.com/jmartin82/mmock
mmock -h
To configure Mmock, use command line flags described in help.
Usage of ./mmock:
-cconsole-port int
Console server Port (default 8082)
-config-path string
Mocks definition folder (default "execution_path/config")
-config-persist-path
Path to the folder where requests can be persisted or connection string to mongo database starting with mongodb:// and having database at the end /DatabaseName (default "execution_path/data")
-console
Console enabled (true/false) (default true)
-console-ip string
Console Server IP (default "public_ip")
-server-ip string
Mock server IP (default "public_ip")
-server-port int
Mock Server Port (default 8083)
Mock
Mock definition:
{
"description": "Some text that describes the intended usage of the current configuration",
"request": {
"method": "GET|POST|PUT|PATCH|...",
"path": "/your/path/*",
"queryStringParameters": {
"name": ["value"],
"name": ["value", "value"]
},
"headers": {
"name": ["value"]
},
"cookies": {
"name": "value"
},
"body": "Expected Body"
},
"response": {
"statusCode": "int (2xx,4xx,5xx,xxx)",
"headers": {
"name": ["value"]
},
"cookies": {
"name": "value"
},
"body": "Response body",
},
"persist" : {
"entity" : "/users/user-{{request.url./your/path/(?P<value>\\d+)}}.json",
"collection" : "users",
"actions"{
"delete":"true",
"append":"text",
"write":"text"
}
},
"notify":{
"amqp": {
"url": "amqp://guest:guest@localhost:5672/myVHost",
"body": "{{ response.body }}",
"delay": 2,
"exchange": "myExchange",
"type": "MockType",
"correlationId": "9782b88f-0c6e-4879-8c23-4699785e6a95",
"routingKey": "routing",
"contentType": "application/json",
"contentEncoding": "",
"priority": 0,
"replyTo": "",
"expiration": "",
"messageId": "",
"timestamp": "2016-01-01T00:00:00Z",
"userId": "",
"appId": ""
},
"http":[
{
"method": "GET|POST|PUT|PATCH|...",
"path": "/relative/path/to/call/{{request.url./your/path/(?P<value>\\d+)}}",
"headers": {
"name": ["value"]
},
"cookies": {
"name": "value"
},
"body": "body in request"
},
{
"method": "GET|POST|PUT|PATCH|...",
"path": "http://absolute.path/to/call/{{request.url./your/path/(?P<value>\\d+)}}",
"headers": {
"name": ["value"]
},
"cookies": {
"name": "value"
},
"body": "body in request"
},
]
}
"control": {
"proxyBaseURL": "string (original URL endpoint)
"delay": "int (response delay in seconds)",
"crazy": "bool (return random 5xx)",
"priority": "int (matching priority)"
}
}
Request
This mock definition section represents the expected input data. I the request data match with mock request section, the server will response the mock response data.
- method: Request http method. Mandatory
- path: Resource identifier. It allows * pattern. Mandatory
- queryStringParameters: Array of query strings. It allows more than one value for the same key.
- headers: Array of headers. It allows more than one value for the same key.
- cookies: Array of cookies.
- body: Body string. It allows * pattern.
To do a match with queryStringParameters, headers, cookies. All defined keys in mock will be present with the exact value.
Response (Optional on proxy call)
- statusCode: Request http method.
- headers: Array of headers. It allows more than one value for the same key and vars.
- cookies: Array of cookies. It allows vars.
- body: Body string. It allows vars.
Persist (Optional)
- entity: The relative path from config-persist-path to the file where the response body to be loaded from or the collection name and id if you are using MongoDB. It allows vars.
- collection: Used for returning or deleting more than one record. Represents the relative path from config-persist-path to the folder or the name of the mongo collection from where the records should be selected. Regex or glob can be used for filtering entities as well. Examples for the usage of collections can be found here.
- actions: Actions to take over the entity (Append,Write,Delete)
Notify (Optional)
-
amqp: Configuration for sending message to AMQP server. If such configuration is present a message will be sent to the configured server.
AMQP (Optional)
- url: Url to the amqp server e.g. amqp://guest:guest@localhost:5672/vhost Mandatory.
- exchange: The name of the exchange to post to Mandatory.
- delay: message send delay in seconds.
- routingKey: The routing key for posting the message.
- body: Payload of the message. It allows vars.
- bodyAppend: Text or JSON to be appended to the body. It allows vars.
- contentType: MIME content type.
- contentEncoding: MIME content encoding.
- priority: Priority from 0 to 9.
- correlationId: Correlation identifier.
- replyTo: Address to to reply to (ex: RPC).
- expiration: Message expiration spec.
- messageId: Message identifier.
- timestamp: Message timestamp.
- type: Message type name.
- userId: Creating user id - ex: "guest".
- appId: Creating application id.
-
http: An array of requests to be made from the mock. This can be useful if you want to create more than one entity when calling an endpoint - that endpoint may call additional endpoints to init other entities related to this one. An example usage can be found in post-user-orders-call-users.json
Control (Optional)
- proxyBaseURL: If this parameter is present, it sends the request data to the BaseURL and resend the response to de client. Useful if you don't want mock a the whole service. NOTE: It's not necessary fill the response field in this case.
- delay: Delay the response in seconds. Simulate bad connection or bad server performance.
- crazy: Return random server errors (5xx) in some request. Simulate server problems.
- priority: Set the priority to avoid match in less restrictive mocks.
You can use variable data (random data or request data) in response. The variables will be defined as tags like this {{nameVar}}
Request data:
- request.query."key"
- request.cookie."key"
- request.url
- request.body
- response.body
- request.url."regex to match value"
- request.body."regex to match value"
- response.body."regex to match value"
- persist.entity.content
- persist.entity.name
- persist.entity.name."regex to match value"
- persist.collection.content
- storage.Sequence(name, increaseWith) - generates next sequence with a given name, useful when auto generating id, if no increaseWith is passed or increaseWith = 0 the sequence won't be increased but the latest value will be returned
- storage.SetValue(key, value) - stores a value corresponding to a given key and returns the value. This is useful if you have some entities requested by both id and name, so that you can store the mapping between than and later retrieve it. You can check the sample in users-storage-post.json, users-storage-get-by-id.json and users-storage-get-by-username.json
- storage.GetValue(key) - returns the value corresponding to the given key
Regex: The regex should contain a group named value which will be matched and its value will be returned. E.g. if we want to match the id from this url /your/path/4
the regex should look like /your/path/(?P<value>\\d+)
. Note that in golang the named regex group match need to contain a P symbol after the question mark. The regex should be prefixed either with request.url., request.body. or response.body. considering your input. When setting the Persist.Collection field the regex can match multiple records from it's input, which is useful for cases like users-delete-passingids.json
Fake data:
-
fake.Brand
-
fake.Character
-
fake.Characters
-
fake.CharactersN(n)
-
fake.City
-
fake.Color
-
fake.Company
-
fake.Continent
-
fake.Country
-
fake.CreditCardVisa
-
fake.CreditCardMasterCard
-
fake.CreditCardAmericanExpress
-
fake.Currency
-
fake.CurrencyCode
-
fake.Day
-
fake.Digits
-
fake.DigitsN(n)
-
fake.EmailAddress
-
fake.FirstName
-
fake.FullName
-
fake.LastName
-
fake.Gender
-
fake.IPv4
-
fake.Language
-
fake.Model
-
fake.Month
-
fake.Year
-
fake.Paragraph
-
fake.Paragraphs
-
fake.ParagraphsN(n)
-
fake.Phone
-
fake.Product
-
fake.Sentence
-
fake.Sentences
-
fake.SentencesN(n)
-
fake.SimplePassword
-
fake.State
-
fake.StateAbbrev
-
fake.Street
-
fake.StreetAddress
-
fake.UserName
-
fake.WeekDay
-
fake.Word
-
fake.Words
-
fake.WordsN(n)
-
fake.Zip
-
fake.Int(n) - random positive integer less than or equal to n
-
fake.Float(n) - random positive floating point number less than n
-
fake.UUID - generates a unique id
Persistence
Currently the tool supports two persistence modes:
File system
If you want to use that mode you need to pass the path to the folder where you want to store your data to the following argument - config-persist-path. The default value is set to the data folder under your current execution path. In this mode the entity name in the Persist defines the relative path to the file where the request data will be stored and retrieved from.
MongoDB
To use MongoDB persistence you need to set the url connection string to the config-persist-path. The format of that url should be in the following format:
mongodb://[user:pass@]host1[:port1][,host2[:port2],...]/database
For example if you are using your local mongo the connection string might be mongodb://localhost/mmock
. In this mode the entity name in the Persist define in which collection and with what ID the records to be stored and retrieved from. To achieve this the names should be in the following format:
collectionName/itemId
You can check the sample configurations for persistence in the following files:
That configurations are going to work either with File system or MongoDB modes.
Contributors
Contributing
Clone this repository to $GOPATH/src/github.com/jmartin82/mmock
and type go get .
.
Requires Go 1.4+ to build.
If you make any changes, run go fmt ./...
before submitting a pull request.
Licence
Copyright © 2016 - 2017, Jordi Martín (http://jordi.io)
Released under MIT license, see LICENSE for details.