Parrot API mocking

#5 / 5 rate

Parrot API mocking

316 users

2020-12-26

Ruud Landman

Extension Information

5 star
100%
4 star
0%
3 star
0%
2 star
0%
1 star
0%

Supported Languages

Permissions

Hot Permissions

Description

Hassle-free mocking of xhr and fetch calls.

Mocking your API responses like a pro. Parrot allows you to mock any asynchronous API call you want. It does this by patching both Fetch and XMLHttpRequest in such way that the actual call will always be done, but the response will be substituted by the mock data you specified.

💡 When to use this extension?

🔸 You are developing a front end that needs to connect to some back end API, but that back end API has not yet been developed or is down.

🔸 You want to give a live demo but the back end API needed is currently not available or broken.

🔸 You would not only like to test the happy flow, but would also like to see how your front end behaves given any possible alternate scenario or edge case.

🔸 You are experiencing a nasty bug but have no way of reproducing it easily using the real back end system. You would like to tweak the response to check if any unexpected response could be the cause of your issue.

💡 How to use this extension?

Start by just pressing the Add button to define a mocked response for a specific request. A line will show up on which you can define the HTTP verb/method and the URL-fragment of the request you would like to be mocked. The URL fragment is defined with a regular expression, allowing you to make any matching requirement as loose or strict as you would like it to be.

NB
In cases where the request also has a payload (like POST), the content of that payload can be used for determining if mocking should take place.

On that same line you can then define the status code of your response, the exact response type and the payload to be returned.

Once the extension detects the method/URL you expressed, the regular call will still be done. However, once the actual response has been received, no matter it's actual result, it will be replaced by the mocked response you defined.

NB
Next to being JSON, for any response also SCRIPTcan be specified. In this case plain JavaScript statements can be defined with which the original response can be modified (you can just reference the contextual variable "response").Parrot will wrap your Javascript in a function that receives the response and returns the response after modification.

Example (note that no function or return statement is needed):

response.someProperty = 'someValue';
response.someArray.push('blabla');

💡 Multiple mock rules

When determining the mock data to be substituted, there can be multiple rules matching the given URL and method. In this case, Parrot will just use the last available mock rule in top-down order.

💡 Timing your calls by adding a delay

Particularly for checking for, or debugging of, potential race condition issues, for any request a delay (expressed in milliseconds) can be specified. This delay will be taken into account before the response is returned to the client that made the request. By carefully timing request/response cycles you can make sure that responses will be received in the exact order you would like them to be.

💡 Export and Import your mock rules

The set of mock rules can also be exported to the file system using the Export button. This allows you to share your mock data with others and also allows you to create/maintain sets of mock rules. Exported files can easily be reimported by using the Import button. Imported files will be appended to any currently existing mock rules in the extension, allowing you to stack multiple sets on top of each other.

💡 Notification when mock data has been used

Every time mock data has been substituted, a small notification will show up. This behavior can be turned off using the popup dialog. The notification will show the path that's being mocked, the number of mock rules applied on it's response and, if applicable, the delay that was taken into account.

💡 Network viewer

Parrot will show all asynchronous calls in a compact view directly attached to your content page. This network view offers you the possibility to show and mock any response with the click of one single button. The overview also directly shows which responses were mocked and which responses were original. In case of a mocked response, opening the mock dialog will show you the response that resulted after applying all involved mock rules.

💡 Localhost

Localhost resources will not be mocked by Parrot.

Reviews

Muhammad Aqeel Irshad
Muhammad Aqeel Irshad

Amazing! I want to you to add capability to edit response header as well. I am getting an issue. I could not use original response on mocking request body.

Michael Hinrichs
Michael Hinrichs

PLESE let me move the network viewer window! It's in the way! This app is perfect for any website that DOES'NT have something i need to click on in the bottom right corner. Edit: Thank you. Five stars.

Peter Brons
Peter Brons

Great tool! Real easy to use and handles the mocking like charm. 5 out of 5!

Similar extensions

Parrot Devtools
Parrot Devtools

American Express

xhr-devtool
xhr-devtool

https://www.2e33.com

Mimic , mock http requests
Mimic , mock http requests

Almog Sade

tweak: mock and modify HTTP requests
tweak: mock and modify HTTP requests

https://tweak-extension.com

ModResponse - Mock and replay API
ModResponse - Mock and replay API

https://modheader.com

Mokku
Mokku

Mukul Jain

Oh-my-Mock
Oh-my-Mock

Lucas Caljé

Mock Proxy
Mock Proxy

jaredliu233

MockMan - mock APIs
MockMan - mock APIs

sudobird

API Interceptor
API Interceptor

Anshul Nema

Mock:Intercept and directly return data
Mock:Intercept and directly return data

xiangmingcsyr

Rest API Inspector
Rest API Inspector

dassum