Testar se meu aplicativo lida com a limitação corretamente
O teste de limitação é difícil porque ocorre raramente, somente quando o servidor que hospeda a API está sob carga pesada. Usando o Dev Proxy, você pode simular a limitação em qualquer API e verificar se o aplicativo lida com isso corretamente.
Para simular a limitação em qualquer API, use o GenericRandomErrorPlugin. Se a API que você usa retornar um Retry-After
cabeçalho, use o RetryAfterPlugin para verificar se o aplicativo recua conforme instruído pela API.
Simular limitação em qualquer API
Para começar, habilite o no arquivo de configuração do GenericRandomErrorPlugin
Dev Proxy.
{
"$schema": "https://raw.githubusercontent.com/microsoft/dev-proxy/main/schemas/v0.20.0/rc.schema.json",
"plugins": [
{
"name": "GenericRandomErrorPlugin",
"enabled": true,
"pluginPath": "~appFolder/plugins/dev-proxy-plugins.dll",
"configSection": "errorsContosoApi",
"urlsToWatch": [
"https://api.contoso.com/*"
]
}
]
}
Em seguida, configure o plug-in para usar um arquivo que contenha os erros que você deseja simular.
{
"$schema": "https://raw.githubusercontent.com/microsoft/dev-proxy/main/schemas/v0.20.0/rc.schema.json",
"plugins": [
{
"name": "GenericRandomErrorPlugin",
"enabled": true,
"pluginPath": "~appFolder/plugins/dev-proxy-plugins.dll",
"configSection": "errorsContosoApi",
"urlsToWatch": [
"https://api.contoso.com/*"
]
}
],
"errorsContosoApi": {
"errorsFile": "errors-contoso-api.json"
}
}
No arquivo de erros, defina a resposta de limitação para que ela corresponda à resposta de limitação real da API:
{
"$schema": "https://raw.githubusercontent.com/microsoft/dev-proxy/main/schemas/v0.20.0/genericrandomerrorplugin.schema.json",
"errors": [
{
"request": {
"url": "https://api.contoso.com/*"
},
"responses": [
{
"statusCode": 429,
"headers": [
{
"name": "Content-Type",
"value": "application/json"
}
],
"body": {
"code": "TooManyRequests",
"message": "Too many requests"
}
}
]
}
]
}
Inicie o Dev Proxy com seu arquivo de configuração e teste seu aplicativo para ver como ele lida com a limitação.
Teste o recuo correto com o Retry-After
cabeçalho
Muitas APIs usam o Retry-After
cabeçalho de resposta para instruir o aplicativo a recuar por um período específico. Ao simular respostas de limitação usando o Dev Proxy, você pode configurar o Retry-After
cabeçalho para um valor estático ou usar um valor dinâmico que testa se o aplicativo está aguardando conforme as instruções antes de chamar a API novamente.
Para configurar o Retry-After
cabeçalho para um valor estático, adicione o cabeçalho à sua resposta de limitação:
{
"$schema": "https://raw.githubusercontent.com/microsoft/dev-proxy/main/schemas/v0.20.0/genericrandomerrorplugin.schema.json",
"errors": [
{
"request": {
"url": "https://api.contoso.com/*"
},
"responses": [
{
"statusCode": 429,
"headers": [
{
"name": "Content-Type",
"value": "application/json"
},
{
"name": "Retry-After",
"value": "60"
}
],
"body": {
"code": "TooManyRequests",
"message": "Too many requests"
}
}
]
}
]
}
Neste exemplo, o Retry-After
cabeçalho é definido como 60 segundos. Quando você configura o cabeçalho para um valor estático, o Dev Proxy não controla se o aplicativo está aguardando antes de chamar a API novamente.
Para testar se o aplicativo está aguardando corretamente antes de chamar a API novamente, altere o valor do cabeçalho para @dynamic
:
{
"$schema": "https://raw.githubusercontent.com/microsoft/dev-proxy/main/schemas/v0.20.0/genericrandomerrorplugin.schema.json",
"errors": [
{
"request": {
"url": "https://api.contoso.com/*"
},
"responses": [
{
"statusCode": 429,
"headers": [
{
"name": "Content-Type",
"value": "application/json"
},
{
"name": "Retry-After",
"value": "@dynamic"
}
],
"body": {
"code": "TooManyRequests",
"message": "Too many requests"
}
}
]
}
]
}
Além disso, estenda a configuração do Proxy de Desenvolvimento com o RetryAfterPlugin
.
{
"$schema": "https://raw.githubusercontent.com/microsoft/dev-proxy/main/schemas/v0.20.0/rc.schema.json",
"plugins": [
{
"name": "RetryAfterPlugin",
"enabled": true,
"pluginPath": "~appFolder/plugins/dev-proxy-plugins.dll",
"urlsToWatch": [
"https://api.contoso.com/*"
]
},
{
"name": "GenericRandomErrorPlugin",
"enabled": true,
"pluginPath": "~appFolder/plugins/dev-proxy-plugins.dll",
"configSection": "errorsContosoApi",
"urlsToWatch": [
"https://api.contoso.com/*"
]
}
],
"errorsContosoApi": {
"errorsFile": "errors-contoso-api.json"
}
}
Cuidado
Adicione o RetryAfterPlugin
antes do GenericRandomErrorPlugin
em seu arquivo de configuração. Se você adicioná-lo depois, a solicitação será falhada GenericRandomErrorPlugin
pelo antes que ele RetryAfterPlugin
tenha a chance de tratá-la.
Esse plug-in acompanha as respostas de limitação e falha com força nas solicitações emitidas para APIs que ainda estão limitadas.