Simular erros a partir de APIs OpenAI
Quando utiliza as APIs OpenAI na sua aplicação, deve testar a forma como a sua aplicação lida com erros de API. O Proxy de Programador permite-lhe simular erros em qualquer API OpenAI com o GenericRandomErrorPlugin.
Dica
Transfira esta predefinição ao executar na linha de comandos devproxy preset get openai-throttling
.
Na pasta de instalação do Dev Proxy, localize a presets
pasta. Na pasta, crie um novo ficheiro com o presets
nome openai-errors.json
. Abra o ficheiro num editor de código.
Crie um novo objeto na plugins
matriz que referencia o GenericRandomErrorPlugin
. Defina o URL da API OpenAI para o plug-in para watch e adicione uma referência à configuração do plug-in.
{
"$schema": "https://raw.githubusercontent.com/microsoft/dev-proxy/main/schemas/v0.14.1/rc.schema.json",
"plugins": [
{
"name": "GenericRandomErrorPlugin",
"enabled": true,
"pluginPath": "~appFolder/plugins/dev-proxy-plugins.dll",
"configSection": "openAIAPI",
"urlsToWatch": [
"https://api.openai.com/*"
]
}
]
}
Crie o objeto de configuração do plug-in para fornecer ao plug-in a localização das respostas de erro.
{
"$schema": "https://raw.githubusercontent.com/microsoft/dev-proxy/main/schemas/v0.14.1/rc.schema.json",
"plugins": [
{
"name": "GenericRandomErrorPlugin",
"enabled": true,
"pluginPath": "~appFolder/plugins/dev-proxy-plugins.dll",
"configSection": "openAIAPI",
"urlsToWatch": [
"https://api.openai.com/*"
]
}
],
"openAIAPI": {
"errorsFile": "errors-openai.json"
}
}
Na mesma pasta, crie o errors-openai.json
ficheiro. Este ficheiro contém as possíveis respostas de erro que podem ser devolvidas quando o plug-in envia uma resposta de erro.
{
"responses": [
{
"statusCode": 429,
"headers": [
{
"name": "content-type",
"value": "application/json; charset=utf-8"
}
],
"body": {
"error": {
"message": "Rate limit reached for default-text-davinci-003 in organization org-K7hT684bLccDbBRnySOoK9f2 on tokens per min. Limit: 150000.000000 / min. Current: 160000.000000 / min. Contact support@openai.com if you continue to have issues. Please add a payment method to your account to increase your rate limit. Visit https://beta.openai.com/account/billing to add a payment method.",
"type": "tokens",
"param": null,
"code": null
}
}
},
{
"statusCode": 429,
"headers": [
{
"name": "content-type",
"value": "application/json; charset=utf-8"
}
],
"body": {
"error": {
"message": "Rate limit reached for default-text-davinci-003 in organization org-K7hT684bLccDbBRnySOoK9f2 on requests per min. Limit: 60.000000 / min. Current: 70.000000 / min. Contact support@openai.com if you continue to have issues. Please add a payment method to your account to increase your rate limit. Visit https://beta.openai.com/account/billing to add a payment method.",
"type": "requests",
"param": null,
"code": null
}
}
},
{
"statusCode": 429,
"addDynamicRetryAfter": true,
"headers": [
{
"name": "content-type",
"value": "application/json; charset=utf-8"
}
],
"body": {
"error": {
"message": "The engine is currently overloaded, please try again later.",
"type": "requests",
"param": null,
"code": null
}
}
}
]
}
Inicie o Proxy de Programador com o ficheiro de configuração:
devproxy --config-file "~appFolder/presets/openai-errors.json"
Quando utiliza a sua aplicação a chamar APIs OpenAI, o Proxy deV devolve aleatoriamente uma das respostas de erro que definiu no errors-openai.json
ficheiro.
Saiba mais sobre o GenericRandomErrorPlugin.