-
Notifications
You must be signed in to change notification settings - Fork 6
/
Copy pathopenai_mock.py
79 lines (63 loc) · 2.39 KB
/
openai_mock.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
# mock_openai.py
import time
from collections import namedtuple
import random
def start_choice():
return {"delta": {"role": "assistant"}, "finish_reason": None, "index": 0}
def stop_choice():
return {"delta": {}, "finish_reason": "stop", "index": 0}
class MockChatCompletion:
@classmethod
def create(cls, model, messages, stream=False, pl_tags=None):
response_template = {
"id": "mocked_openai_id",
"object": "chat.completion",
"created": int(time.time()),
"model": model,
"usage": {
"prompt_tokens": len(messages),
"completion_tokens": len(messages),
},
"choices": [
{"delta": {"role": "assistant", "content": "This is a mock response."}}
],
}
if stream:
mock_response = "You're seeing a mock response so that we can avoid paying API fees under development."
# generate mock_responses to be an array of words from full_response
mock_chunks = mock_response.split()
response_template["choices"][0] = start_choice()
yield response_template
for content in mock_chunks:
time.sleep(0.4) # simulate delay
response_template["choices"][0]["delta"]["content"] = (
content + " "
) # Set 'delta' content
yield response_template
response_template["choices"][0] = stop_choice()
yield response_template
else:
time.sleep(0.5) # simulate delay
yield namedtuple("Struct", response_template.keys())(
*response_template.values()
)
class MockCompletion:
@classmethod
def create(cls, engine, prompt, temperature, max_tokens):
# generate a mock title with a random number
mock_title = f"Convo {random.randint(0, 1000)}"
response = {
"id": "mocked_openai_id",
"object": "text.completion",
"created": int(time.time()),
"model": engine,
"usage": {
"prompt_tokens": len(prompt.split()),
"completion_tokens": max_tokens,
},
"choices": [{"text": mock_title}],
}
return response
class MockOpenAI:
ChatCompletion = MockChatCompletion
Completion = MockCompletion