Skip to content

Commit

Permalink
Revert "[Evals] Update the errors we except for retries (#1406)"
Browse files Browse the repository at this point in the history
This reverts commit a06a07b.
  • Loading branch information
andrew-openai committed Nov 15, 2023
1 parent a06a07b commit 10360e8
Show file tree
Hide file tree
Showing 5 changed files with 24 additions and 23 deletions.
5 changes: 5 additions & 0 deletions evals/cli/oaieval.py
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,8 @@
import sys
from typing import Any, Mapping, Optional, Union, cast

import openai

import evals
import evals.api
import evals.base
Expand Down Expand Up @@ -266,6 +268,9 @@ def main() -> None:
filename=args.log_to_file if args.log_to_file else None,
)
logging.getLogger("openai").setLevel(logging.WARN)

if hasattr(openai.error, "set_display_cause"): # type: ignore
openai.error.set_display_cause() # type: ignore
run(args)


Expand Down
4 changes: 2 additions & 2 deletions evals/elsuite/make_me_say/autoeval.py
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@
from typing import Callable, Optional, Union

import backoff
from openai import BadRequestError
from openai.error import InvalidRequestError

from evals.api import CompletionFn, CompletionResult
from evals.elsuite.make_me_say.core import Game, Message, Player
Expand All @@ -17,7 +17,7 @@
)


@backoff.on_exception(backoff.constant, BadRequestError, max_tries=3)
@backoff.on_exception(backoff.constant, InvalidRequestError, max_tries=3)
def run(
codeword: str,
manipulator_completion_fn: CompletionFn,
Expand Down
10 changes: 4 additions & 6 deletions evals/elsuite/make_me_say/utils.py
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@

import backoff
import openai
import openai.error
import urllib3.exceptions

from evals.api import CompletionResult
Expand All @@ -11,12 +12,9 @@
@backoff.on_exception(
backoff.expo,
(
openai.APIError,
openai.APIStatusError,
openai.RateLimitError,
openai.APITimeoutError,
openai.APIConnectionError,
openai.InternalServerError,
openai.error.RateLimitError,
openai.error.ServiceUnavailableError,
openai.error.TryAgain,
urllib3.exceptions.TimeoutError,
),
)
Expand Down
2 changes: 1 addition & 1 deletion evals/registry.py
Original file line number Diff line number Diff line change
Expand Up @@ -99,7 +99,7 @@ def add_registry_paths(self, paths: Sequence[Union[str, Path]]) -> None:
def api_model_ids(self) -> list[str]:
try:
return [m["id"] for m in openai.Model.list()["data"]]
except openai.OpenAIError as err: # type: ignore
except openai.error.OpenAIError as err: # type: ignore
# Errors can happen when running eval with completion function that uses custom
# API endpoints and authentication mechanisms.
logger.warning(f"Could not fetch API model IDs from OpenAI API: {err}")
Expand Down
26 changes: 12 additions & 14 deletions evals/utils/api_utils.py
Original file line number Diff line number Diff line change
Expand Up @@ -14,12 +14,11 @@
@backoff.on_exception(
wait_gen=backoff.expo,
exception=(
openai.APIError,
openai.APIStatusError,
openai.RateLimitError,
openai.APITimeoutError,
openai.APIConnectionError,
openai.InternalServerError,
openai.error.ServiceUnavailableError,
openai.error.APIError,
openai.error.RateLimitError,
openai.error.APIConnectionError,
openai.error.Timeout,
),
max_value=60,
factor=1.5,
Expand All @@ -32,7 +31,7 @@ def openai_completion_create_retrying(*args, **kwargs):
result = openai.Completion.create(*args, **kwargs)
if "error" in result:
logging.warning(result)
raise openai.APIError(result["error"])
raise openai.error.APIError(result["error"])
return result


Expand All @@ -53,12 +52,11 @@ def request_with_timeout(func, *args, timeout=EVALS_THREAD_TIMEOUT, **kwargs):
@backoff.on_exception(
wait_gen=backoff.expo,
exception=(
openai.APIError,
openai.APIStatusError,
openai.RateLimitError,
openai.APITimeoutError,
openai.APIConnectionError,
openai.InternalServerError,
openai.error.ServiceUnavailableError,
openai.error.APIError,
openai.error.RateLimitError,
openai.error.APIConnectionError,
openai.error.Timeout,
),
max_value=60,
factor=1.5,
Expand All @@ -71,5 +69,5 @@ def openai_chat_completion_create_retrying(*args, **kwargs):
result = request_with_timeout(openai.ChatCompletion.create, *args, **kwargs)
if "error" in result:
logging.warning(result)
raise openai.APIError(result["error"])
raise openai.error.APIError(result["error"])
return result

0 comments on commit 10360e8

Please sign in to comment.