This repo is an exploration into creating a simulated API implementation for Azure OpenAI (AOAI).
WARNING: This is a work in progress!
The OpenAI Simulated API is a tool that allows you to easily deploy endpoints that simulate the OpenAI API. A common use-case for the OpenAI Simulated API is to test the behaviour your application under load. Let's illustrate this with an example...
Let's assume that you have build a chatbot that uses the OpenAI API to generate responses to user queries. Before your chatbot becomes popular, you want to ensure that it can handle a large number of users. One of the factors that will impact whether your chatbot can gracefully handle such load will be the way that your chatbot handles calls to OpenAI. However, when load testing your chatbot there are a number of reasons why you might not want to call the OpenAI API directly:
- Cost: The OpenAI API is a paid service, and running load tests against it can be expensive.
- Consistency: The OpenAI API is a live service, and the responses you get back can change over time. This can make it difficult to compare the results of load tests run at different times.
- Rate Limits: The OpenAI API has rate limits, and running load tests against it can cause you to hit these limits.
- Latency: The latency of OpenAI API calls might change over time, and this can impact the results of your load tests.
In fact, when considering Rate Limits and Latency, these might be things that you'd like to control. You may also want to inject latency, or inject rate limit issues, so that you can test how your chatbot deals with these issues.
This is where the OpenAI Simulater API plays it's part!
By using the OpenAI Simulated API, you can reduce the cost of running load tests against the OpenAI API and ensure that your application behaves as expected under different conditions.
The simulated API has two approaches to simulating API responses: record/replay and generators. If you don't have any requirements around the content of the responses, the generator approach is probably the easiest for you to use. If you need to simulate specific responses, then the record/replay approach is likely the best fit for you.
With record/replay, the API can be run in record mode to act as a proxy between your application and Azure OpenAI, and it will record requests that are sent to it along with the corresponding response from OpenAI.
Once recorded, the API can be run in replay mode to use the saved responses without forwarding to Azure OpenAI. The recordings are stored in YAML files which can be edited if you want to customise the responses.
The simulated API can also be run in generator mode, where responses are generated on the fly. This is useful for load testing scenarios where it would be costly/impractical to record the full set of responses.
There are various options for running and deploying the simulator, including running in Docker and deploying to Azure Container Apps.
There are a range of configuration options that can be applied to control the simulator behavior.
The simulated API supports extensions that allow you to customise the behaviour of the API. Extensions can be used to modify the request/response, add latency, or even generate responses.
For a list of tagged versions and changes, see the CHANGELOG.md file.