Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/appiumtestdistribution/appium-interceptor-plugin
Appium 2.0 plugin to mock api calls for android apps
https://github.com/appiumtestdistribution/appium-interceptor-plugin
appium appium-plugin http-interceptor mocking network proxy-server
Last synced: 5 days ago
JSON representation
Appium 2.0 plugin to mock api calls for android apps
- Host: GitHub
- URL: https://github.com/appiumtestdistribution/appium-interceptor-plugin
- Owner: AppiumTestDistribution
- Created: 2023-12-28T11:06:49.000Z (about 1 year ago)
- Default Branch: master
- Last Pushed: 2024-11-18T05:56:58.000Z (about 1 month ago)
- Last Synced: 2024-12-22T08:12:04.633Z (10 days ago)
- Topics: appium, appium-plugin, http-interceptor, mocking, network, proxy-server
- Language: TypeScript
- Homepage:
- Size: 10.8 MB
- Stars: 31
- Watchers: 3
- Forks: 12
- Open Issues: 17
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# appium-interceptor-plugin
This is an Appium plugin designed to intercept API response and mocking easy.
This plugin uses mitmproxy## Prerequisite
1. Appium version 2.0
2. Intercepting API requests from android requires CA certificate to be installed on the device. Follow the instructions in [How to install CA certificate on android](./docs/certificate-installation.md) section and install the CA certificate.## Installation - Server
Install the plugin using Appium's plugin CLI, either as a named plugin or via NPM:
```shell
appium plugin install --source=npm appium-interceptor
```## Activation
The plugin will not be active unless turned on when invoking the Appium server:
`appium server -ka 800 --use-plugins=appium-interceptor -pa /wd/hub`
## what does this plugin do?
For every appium session, interceptor plugin will start a proxy server and updates the device proxy settings to pass all network traffic to proxy server. Mocking is disabled by default and can be enabled from the test by passing `appium:intercept : true` in the desired capability while creating a new appium session.
Please refer to the [commands](/docs/commands.md) sections for detailed usage.
## Supported Platforms
💚 `Android`
**Mocking support**
1. Update outgoing request URL
2. Fully Replace or partially modify the request payload (POST Body)
3. Update the request headers
4. Update the response headers
5. Fully Replace or partially modify the response body
6. Update the response status code.## Usage
Refer Examples [here](./test/plugin.spec.js)
## Troubleshooting
In certain instances where the session terminates abruptly, the device proxy state may persist without being cleared, leading to a non-functional network connection. To rectify this issue and reset the device proxy state, execute the following adb command.
`adb shell settings put global http_proxy :0`
## Build local
`npm install`
`npm run build`
## Credits
A special thanks to creators and maintainers of [node-http-mitm-proxy](https://github.com/joeferner/node-http-mitm-proxy). Their efforts have laid the foundation for the capabilities embedded in this plugin.