Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/ckpack/mock-axios

Mock axios requests for testing and development
https://github.com/ckpack/mock-axios

axios mock mock-axios moxios

Last synced: 8 days ago
JSON representation

Mock axios requests for testing and development

Awesome Lists containing this project

README

        

# mock-axios


中文
|
ENGLISH

拦截`Axios`请求返还`Mock`数据, 用于测试和开发。

## 接口

### mockAxios

`(mockDatas: MockConfig[], mockOptions?: MockOptions | undefined) => void`: Mock `Axios`

+ `mockDatas`: 一个数组, 当`axios`请求时,会检查对应的`url`、 `method`,当匹配时会返回对应的`response`数据。
+ `url`: `string | RegExp`类型, 需要匹配的url, 可以是字符串或正则表达式。当是字符串时会检查`axios`请求的`url`是否包含有该`url`。当是正则表达式时会检查`axios`请求的`url`是否匹配该`url`。
+ `method`: `GET` | `POST` | `PUT` | `DELETE` | `PATCH`, 默认为空即匹配所有类型的请求
+ `timeout`: `number`类型, 默认值: `300`, 单位: `ms`, 返回结果的延迟的时间
+ `response`: 返回的mock的数据对象
+ `adapter`: 自定义的适配器函数,参考[adapter](https://github.com/axios/axios/tree/master/lib/adapters), 该函数接受两个参数一个是`config`,一个是匹配到的`mockData`对象,返回值为`response`的数据对象,通过该参数你可以更自由的定义返回的数据(如验证接口权限)。
+ `mockOptions`
+ `isUseDefaultAdapter`: `Boolean`, 默认为 `true`, 如果开启,没有拦截到的请求会以`axios`默认方式发送请求
+ `isEffect`: `Boolean`, 默认为 `true`, 通过该参数你可以在测试环境中打开`mockAxios`,在生产环境中关闭`mockAxios`
+ `isLog`: `Boolean`, 默认为 `true`, 是否打印`mockAxios`的请求日志
+ `logger`: `Function`, 替换默认的日志函数

```js
import { mockAxios } from '@ckpack/mock-axios';

mockAxios([{
url: 'https://test.com/v1/user/1',
response: {
data: {
id: 1,
name: 'admin',
},
},
}], {
isEffect: process.env.NODE_ENV === 'development',
});
```

### defineConfig

`(mockDatas: MockConfig[]) => MockConfig[]`: 构造mockDatas的辅助函数。该函数可以配合IDE来获取类型提示

+ `mockDatas`: 同`mockAxios`的`mockDatas`参数。

```js
import { defineConfig } from '@ckpack/mock-axios';

const mockDatas = defineConfig([
{
url: 'https://test.com/v1/user/1',
response: {
data: {
id: 1,
name: 'admin',
},
},
},
]);
```

## 例子

```ts
// mockAxios.js
import { mockAxios } from '@ckpack/mock-axios';

mockAxios([{
method: 'GET',
url: /https:\/\/test.com\/v1\/user\/\d+/,
response: {
data: [{
id: 1,
name: 'admin',
}],
},
}, {
method: 'POST',
url: 'https://test.com/v1/user/create',
adapter: (axiosConfig) => {
return {
data: axiosConfig.data,
};
},
}]);
```

在其他文件中

```ts
import axios from 'axios';
import './mockAxios.js';

await axios.get('https://test.com/v1/user/1');
// 返回 { data: [{ id: 1, name: 'admin' }] }

await axios.post('https://test.com/v1/user/create', {
id: 1,
name: 'admin',
});
// 返回 { data: { id: 1, name: 'admin' } }
await axios.post('https://test.com/v1/user/create', {
id: 2,
name: 'test',
});
// 返回 { data: { id: 2, name: 'test' } }
```