Observação
O acesso a essa página exige autorização. Você pode tentar entrar ou alterar diretórios.
O acesso a essa página exige autorização. Você pode tentar alterar os diretórios.
Falha nas solicitações com um erro selecionado aleatório no arquivo que contém erros simulados.
Exemplo de configuração
{
"$schema": "https://raw.githubusercontent.com/dotnet/dev-proxy/main/schemas/v2.2.0/rc.schema.json",
"plugins": [
{
"name": "GenericRandomErrorPlugin",
"enabled": true,
"pluginPath": "~appFolder/plugins/DevProxy.Plugins.dll",
"configSection": "genericRandomErrorPlugin"
}
],
"urlsToWatch": [
"https://api.openai.com/*"
],
"genericRandomErrorPlugin": {
"$schema": "https://raw.githubusercontent.com/dotnet/dev-proxy/main/schemas/v2.2.0/genericrandomerrorplugin.schema.json",
"errorsFile": "errors.json"
}
}
Propriedades de configuração
| Propriedade | Descrição | Inadimplência |
|---|---|---|
errorsFile |
Caminho para o arquivo que contém respostas de erro. | Nenhum padrão |
rate |
O percentual de solicitações a falhar com um erro aleatório. Valor entre 0 e 100. | 50 |
retryAfterInSeconds |
O número de segundos a aguardar antes de repetir a solicitação. Incluído no cabeçalho de resposta Retry-After para limitação dinâmica. |
5 |
Opções de linha de comando
| Nome | Descrição | Inadimplência |
|---|---|---|
-f, --failure-rate <failure rate> |
O percentual de solicitações a falhar com um erro aleatório. Valor entre 0 e 100. | 50 |
Observações
Valores por resposta Retry-After
Por padrão, o Retry-After cabeçalho usa o valor global retryAfterInSeconds . Você pode substituir esse valor por resposta usando a @dynamic=N sintaxe no arquivo de respostas de erro, onde N está o número de segundos a aguardar antes de tentar novamente.
{
"$schema": "https://raw.githubusercontent.com/dotnet/dev-proxy/main/schemas/v2.2.0/genericrandomerrorplugin.errorsfile.schema.json",
"errors": [
{
"request": {
"url": "https://api.openai.com/*"
},
"responses": [
{
"statusCode": 429,
"headers": [
{
"name": "Retry-After",
"value": "@dynamic=17"
}
],
"body": {
"error": {
"message": "Rate limit exceeded. Wait 17 seconds."
}
}
}
]
}
]
}
Neste exemplo, o Retry-After cabeçalho usa segundos 17 para essa resposta, independentemente da configuração global retryAfterInSeconds . O valor incrementa em cada solicitação limitada subsequente, como com o token sem formatação @dynamic .